Узнайте, почему Apache перестает работать каждое воскресное утро
Я установил Apache на Ubuntu 16.04.4 LTS.
По какой-то причине, примерно в одно и то же время каждое воскресное утро Apache останавливается.
Когда он останавливается, я бегу systemctl status apache2
и посмотреть:
Mar 04 06:25:24 xxxxxx apache2[11178]: * Stopping Apache httpd web server apache2
Так что как-то Apache был остановлен. Когда он остановлен, ничего нет /var/log/apache2/error.log
, Когда я снова запускаю Apache, я вижу:
[Sun Mar 04 09:44:10.875444 2018] [core:warn] [pid 22442:tid 140355746498432] AH00098: pid file /var/run/apache2/apache2.pid overwritten -- Unclean shutdown of previous Apache run?
От /var/log/syslog
похоже, что Apache был перезагружен (также ProFTPD), а затем остановлен на 06:25:24
:
Mar 4 06:25:11 xxxxxx systemd[1]: Reloading LSB: Apache2 web server.
Mar 4 06:25:11 xxxxxx apache2[11014]: * Reloading Apache httpd web server apache2
Mar 4 06:25:11 xxxxxx apache2[11014]: *
Mar 4 06:25:11 xxxxxx systemd[1]: Reloaded LSB: Apache2 web server.
Mar 4 06:25:18 xxxxxx systemd[1]: Stopping LSB: Starts ProFTPD daemon...
Mar 4 06:25:18 xxxxxx proftpd[11083]: * Stopping ftp server proftpd
Mar 4 06:25:18 xxxxxx proftpd[11083]: ...done.
Mar 4 06:25:18 xxxxxx systemd[1]: Stopped LSB: Starts ProFTPD daemon.
Mar 4 06:25:18 xxxxxx systemd[1]: Starting LSB: Starts ProFTPD daemon...
Mar 4 06:25:18 xxxxxx proftpd[11094]: * Starting ftp server proftpd
Mar 4 06:25:18 xxxxxx proftpd[11094]: 2018-03-04 06:25:18,666 xxxxxx proftpd[11104]: mod_dso/0.5: module 'mod_tls.c' already loaded
Mar 4 06:25:18 xxxxxx proftpd[11094]: 2018-03-04 06:25:18,667 xxxxxx proftpd[11104]: mod_dso/0.5: module 'mod_sftp.c' already loaded
Mar 4 06:25:19 xxxxxx proftpd[11094]: ...done.
Mar 4 06:25:19 xxxxxx systemd[1]: Started LSB: Starts ProFTPD daemon.
Mar 4 06:25:24 xxxxxx apache2[11178]: * Stopping Apache httpd web server apache2
Mar 4 06:25:24 xxxxxx apache2[11178]: *
Как мне узнать, почему Apache останавливается или какой процесс останавливает Apache (по какой причине), чтобы я мог предотвратить его повторение?
1 ответ
Проблема была вызвана logrotate
, который останавливает Apache при вращении бревен.
Проблема была решена путем редактирования /etc/logrotate.d/apache2
меняется reload
в graceful
,
Оригинал:
postrotate
if /etc/init.d/apache2 status > /dev/null ; then \
/etc/init.d/apache2 reload > /dev/null; \
fi;
endscript
Отредактировано:
postrotate
if /etc/init.d/apache2 status > /dev/null ; then \
/etc/init.d/apache2 graceful > /dev/null; \
fi;
endscript