`

Linux下apache(优雅)停止、重启方式

阅读更多
优雅重启:apachectl -k graceful
在windows下http -t 可是检查语法,但是没有找到同样效果的优雅重启命令,哪位知道请回复,谢谢。

简介

为了停止或者重新启动Apache ,你必须向正在运行的httpd进程发送信号。有两种发送信号的方法。第一种方法是直接使用UNIX的kill命令向运行中的进程发送信号。你也许你会注意到你的系统里运行着很多httpd进程。但你不应该直接对它们中的任何一个发送信号,而只要对已经在PidFile中记载下了自身PID的父进程发送信号。也就是说,你不必对父进程以外的任何进程发送信号。你可以向父进程发送三种信号:TERMHUPUSR1 ,我们过一会儿再进行详细的说明。

你可以用下面这样的命令来向父进程发送信号:

kill -TERM `cat /usr/local/apache2/logs/httpd.pid`

第二种方法是使用下面将要描述的httpd二进制可执行文件的 -k 命令行选项:stoprestartgracefulgraceful-stop 。不过我们推荐你使用apachectl控制脚本来向httpd二进制可执行文件传递这些选项。

当你向httpd发送信号后,你可以这样来读取它的进行过程:

tail -f /usr/local/apache2/logs/error_log

你可以修改这些示例以适应你的ServerRootPidFile设置。

top

立即停止

信号:TERM
apachectl -k stop

发送TERMstop信号到父进程可以使它立刻杀死所有子进程。这将花费一些时间来杀死所有子进程。然后父进程自己也退出。所有进行中的请求将被强行中止,而且不再接受其它请求。

top

优雅重启

信号:USR1
apachectl -k graceful

USR1graceful信号使得父进程建议子进程在完成它们现在的请求后退出(如果他们没有进行服务,将会立刻退出)。父进程重新读入配置文件并重新打开日志文件。每当一个子进程死掉,父进程立刻用新的配置文件产生一个新的子进程并立刻开始伺服新的请求。

重启代码的设计能够确保MPM进程控制指令的正常运作,也就是在重启过程中确保有适当数量的进程和线程以响应客户端的请求。它是这样StartServers的:如果在一秒钟以后还没有新创建StartServers个子进程,则创建出足够完成现在任务的子进程个数。因此,代码除了保有能够维持服务器的现有负载数量的子进程外,也确保StartServers按你的意愿运作。

使用mod_status的用户会注意到在USR1信号发出后,服务器的统计信息没有被清零。代码被写成既能将你服务器无法伺服新请求的时间降至最少(这些请求将被操作系统放到队列里,使得它们不会丢失),又能遵从你的参数优化。为了做到这一点,它将在重新生成子进程的过程中,在scoreboard上保存所有子进程的状态。

mod_status还会将那些在优雅重启前就已经开始而没有结束伺服请求的子进程用一个"G"来标志。

目前,日志滚动脚本还无法使用USR1来确定所有写入预重启日志的子进程都已结束。我们建议你在发出了USR1信号后等待一个适当的时间,然后再对旧的日志做处理。比如说如果对于一个窄带用户来说,大部分的点击处理将在10分钟之内完成,那么你应该在处理旧的日志前等待15分钟。

如 果Apache重启时发现配置文件有误,那么父进程将不会重启,而是报错并退出。在优雅重启的情况下,它将在处理中的子进程存在的情况下维持它的存在(就 是那些被要求在处理完它们的请求后"优雅退出"的子进程)。如果你要重启服务器,这将导致一些问题:它将不能绑定到它的监听端口。在执行重启之前,你可以 用 -t 命令行参数来检查配置文件语法的正确性(参见httpd)。但这仍然不能保证服务器一定可以正确的重启。为了从语法和语义两方面检查配置文件,你可以用一个非root用户来启动httpd。如果没有错误,它将尝试去打开套接字和日志文件,继而因没有root权限而失败(或是因为现在运行的httpd已经绑定了这些端口)。如果是因为其他原因那么就可能是一个配置文件产生的错误,你就应当在进行优雅重启之前改正这个错误。
top

立即重启

信号:HUP
apachectl -k restart

向父进程发送HUPrestart信号会使它象收到TERM信号一样杀掉所有的子进程,不同之处在于父进程本身并不退出。它重新读入配置文件、重新打开日志文件。然后产生一系列新的子进程来继续服务。

使用mod_status的用户会注意到在HUP信号发出后,服务器统计信息会被清零。

如果你重启时配置文件有误,那么父进程将不会重启,而是报错并退出。参见上文中避免的方法。
top

优雅停止

信号:WINCH
apachectl -k graceful-stop

WINCHgraceful-stop信号使得父进程建议子进程在完成它们现在的请求后退出(如果他们没有进行服务,将会立刻退出)。然后父进程删除PidFile并停止在所有端口上的监听。父进程仍然继续运行并监视正在处理请求的子进程,一旦所有子进程完成任务并退出或者超过由GracefulShutdownTimeout指令规定的时间,父进程将会退出。在超时的情况下,所有子进程都将接收到TERM信号并被强制退出。

在"优雅"状态下,TERM信号将会立即中止父进程和所有子进程。由于PidFile已经被删除,你将无法使用apachectlhttpd发送该信号。

graceful-stop允许你同时运行多个相同配置的httpd实例。这在对Apache进行平滑升级的时候是一个非常有用的特性。不过它在某些配置的情况下同样可能会导致死锁和竞争条件。

必须注意确保诸如LockfileScriptSock之类的磁盘文件包含服务器的PID ,并且能够安全的共存。然而如果一个配置指令、第三方模块或持久CGI使用任何磁盘锁或状态文件,必须注意确保多个httpd运行实例之间不会争抢文件。

你还必须防止潜在的竞争条件,比如使用rotatelogs风格的管道日志。运行中的多个rotatelogs实例企图同时滚动同一个日志文件可能会导致互相破坏对方的日志文件。

top

附录:信号和竞争条件

在Apache 1.2b9 之前,有很多关于重启和死亡信号的竞争条件。关 于竞争条件的一个简单描述是:一个时间敏感的问题,如果一些事情在不适当的时间或以不恰当的顺序发生,它将作出你不期望的反应;如果同样的事情在恰当的时 间发生,则不会出现异常。凭借那些拥有"正确"特性设置的体系结构,我们尽量避免了它们的出现。但值得注意的是,仍然有一些竞争条件存在于这样的体系结构 中。

使用物理磁盘的ScoreBoardFile就有损坏ScoreBoard的潜在危险。这将发生在"bind: Address already in use"(HUP之后)或"long lost child came home!"(USR1之后)时。前者是一个致命错误,而后者则会使服务器丢失ScoreBoard的一个记录。所以我们建议多使用优雅重启,偶尔使用硬重启。这些问题很难解决,但幸运的是大多数结构并不需要ScoreBoard文件。而如果你需要这样的结构,你可以参考ScoreBoardFile文档。

当 每个子进程在一个HTTP的持续连接(KeepAlive)中涉及到第二个并发的请求时,所有的结构都会或多或少存在竞争状态的问题。它将在读取了请求而 没有读取任何请求头之后立刻退出。这个修复对于1.2来说来得太晚了。但因为持续连接的客户端已经考虑到网络延时和服务器超时会造成类似的情况,所以理论 上说,这不是一个太大的问题。而实际上似乎也没有任何影响:在一个测试案例中服务器在一秒之内被重启了20次,而客户端却成功的浏览了网站,而且没有任何 破损的图片或空文档。

原文地址:http://lamp.linux.gov.cn/Apache/ApacheMenu/stopping.html

类别:apache+tomcat?查看评论
分享到:
评论

相关推荐

    Linux下重启apache的方法.docx

    本文将详细介绍Linux系统下Apache服务器的启动、重启和停止方法。 一、启动Apache服务器 在Linux系统中,启动Apache服务器可以使用以下命令: ``` # /etc/init.d/apache2 start 或 $ sudo /etc/init.d/apache2 ...

    Linux系统下操作Apache最基本的启动停止和重启命令

    了解如何启动、停止和重启Apache是运维工作中的基础技能。在本文中,我们将深入探讨在Linux环境下操作Apache的基本命令,这对于网站搭建和管理至关重要。 首先,我们需要知道Apache的安装目录。在示例中,Apache被...

    实战Nginx:取代Apache的高性能Web服务器 第一章

    - `nginx -s quit`:优雅停止。 #### 2.7 Nginx的平滑升级 平滑升级是指在不中断服务的情况下更新Nginx版本。通常的做法是在新版本启动后,将旧版本的连接转移到新版本上,然后关闭旧版本。 以上内容为第一章的...

    coreCmd-dmp-web_linux一键部署命令_

    "coreCmd-dmp-web_linux一键部署命令_"这个标题指的是一个专门为Linux环境设计的自动化部署工具,它简化了web应用程序的部署过程,允许用户通过简单的命令来启动、停止、重启服务,以及检查服务状态。下面我们将深入...

    Linux 命令-网络通讯

    例如,使用`apachectl configtest`可以检查配置文件的语法是否正确,`apachectl start`则用于启动服务器,而`apachectl graceful`则会在不中断现有连接的情况下优雅地重启服务器。 其次,`arpwatch`命令用于监视...

    apache+php+mysql

    还可以使用 `-k restart`、`-k graceful`、`-k stop`、`-k graceful-stop` 分别表示重启、平滑重启、停止和优雅地停止服务。 ### 三、安装 MySQL 由于提供的内容中没有具体描述 MySQL 的安装过程,这里仅提供基本...

    Tomcat停止与启动shell

    - **启动**:通常在Tomcat安装目录下的`bin`目录下,有`startup.sh`(Linux/Unix)或`startup.bat`(Windows)脚本用于启动Tomcat。执行这个脚本会启动Tomcat的服务进程。 - **停止**:对应地,`shutdown.sh`或`...

    commons-daemon-native.tar.gz

    Jsvc可以管理Java应用的启动、停止、重启等操作,并能处理信号传递,如SIGTERM用于优雅地停止服务。 4. **Procrun工具**:对于Windows平台,Apache Commons Daemon提供了Procrun工具,它允许Java应用程序作为...

    Plesk-rebootfix:重新启动Plesk服务器后可解决问题Linux脚本

    该脚本通过执行以下操作缓解了此类问题: 停止NGINX 要求Apache优雅地停止重新启动Apache 重新启动NGINX 我曾经手动发出所有四个命令,但是运行一个小脚本要快得多。 遗憾的是,默认情况下,Plesk不会执行此操作。...

    jsvc.tar.gz

    jsvc是Apache Commons Daemon项目的一部分,主要用于在Unix类系统(包括Linux)上以系统服务的方式启动、停止或管理Java应用程序,比如Apache Tomcat。这个工具通常与Java Development Kit (JDK)一起使用,因为它是...

    MySQL服务器的启动与停止的解析

    停止MySQL服务器时,可以使用mysql.server stop或者kill命令发送特定信号给MySQL进程来优雅地关闭服务。在系统维护和更新时,理解这些启动和停止机制是非常重要的,以确保数据库的稳定性和数据的安全性。此外,还...

    nginx1.13.9

    10. **启动与停止**:在命令行中,可以使用`nginx -s stop`快速停止服务,`nginx -s quit`优雅停止(等待当前请求处理完再停止),`nginx -t`测试配置文件是否正确,`nginx`命令启动服务。 11. **配置文件重载**:...

    tomcat启动管理工具

    2. 管理:在Tomcat的管理中,主要涉及启动、停止、重启、查看日志、配置服务器参数、部署和卸载Web应用等操作。 【详细说明】: 1. **启动Tomcat**:通常,Tomcat可以通过执行`bin/startup.sh`(Unix/Linux)或`...

    Nginx 核心模块与配置实践1

    - `./nginx -s quit`:优雅停止Nginx,等待当前请求处理完毕后关闭。 - `./nginx -s reload`:热加载配置文件,无需重启服务即可应用新的配置。 Nginx的配置文件`nginx.conf`包含了服务器的全局配置、HTTP服务器...

    Jetty权威指南.pdf

    除了静态部署外,Jetty还支持动态热部署,即在不重启服务器的情况下更新Web应用。这通常是通过配置`ReloadHandler`来实现的。 **5.4 Servlet 2.5新特性** 随着Servlet规范的不断升级,Jetty也紧跟技术发展趋势,...

Global site tag (gtag.js) - Google Analytics