У меня это есть в моем httpd.conf:
Listen 216.XX.YY.ZZZZ:80
Чтобы убедиться, я убедился, что httpd включен при загрузке:
systemctl httpd enable
Когда система сапоги, У меня есть:
systemctl status httpd
● httpd.service - The Apache HTTP Server
Loaded: loaded (/usr/lib/systemd/system/httpd.service; enabled; vendor preset: disabled)
Active: failed (Result: exit-code) since Thu 2017-02-23 22:21:03 PST; 8min ago
Process: 719 ExecStart=/usr/sbin/httpd $OPTIONS -DFOREGROUND (code=exited, status=1/FAILURE)
Main PID: 719 (code=exited, status=1/FAILURE)
Feb 23 22:21:00 centosXXXXXX.aspadmin.net systemd[1]: Starting The Apache HTTP Server...
Feb 23 22:21:03 centosXXXXXX.aspadmin.net httpd[719]: (99)Cannot assign requested address: AH00072: make_sock: could not bind to address 216.XX.YY.XXX:80
Feb 23 22:21:03 centosXXXXXX.aspadmin.net httpd[719]: no listening sockets available, shutting down
Feb 23 22:21:03 centosXXXXXX.aspadmin.net httpd[719]: AH00015: Unable to open logs
Feb 23 22:21:03 centosXXXXXX.aspadmin.net systemd[1]: httpd.service: main process exited, code=exited, status=1/FAILURE
Feb 23 22:21:03 centosXXXXXX.aspadmin.net systemd[1]: Failed to start The Apache HTTP Server.
Feb 23 22:21:03 centosXXXXXX.aspadmin.net systemd[1]: Unit httpd.service entered failed state.
Feb 23 22:21:03 centosXXXXXX.aspadmin.net systemd[1]: httpd.service failed.
Затем я могу запустить его, запустив:
systemctl start httpd
И все работает:
systemctl status httpd
● httpd.service - The Apache HTTP Server
Loaded: loaded (/usr/lib/systemd/system/httpd.service; enabled; vendor preset: disabled)
Active: active (running) since Thu 2017-02-23 22:31:53 PST; 3s ago
Main PID: 2804 (httpd)
Status: "Processing requests..."
CGroup: /system.slice/httpd.service
├─2804 /usr/sbin/httpd -DFOREGROUND
├─2805 /usr/sbin/httpd -DFOREGROUND
├─2806 /usr/sbin/httpd -DFOREGROUND
├─2808 /usr/sbin/httpd -DFOREGROUND
├─2824 /usr/sbin/httpd -DFOREGROUND
└─2831 /usr/sbin/httpd -DFOREGROUND
Feb 23 22:31:53 centosXXXXXX.aspadmin.net systemd[1]: Starting The Apache HTTP Server...
Feb 23 22:31:53 centosXXXXXX.aspadmin.net httpd[2804]: AH00558: httpd: Feb 23 22:31:53 centosXXXXXX.aspadmin.net systemd[1]: Started The Apache HTTP Server.
Hint: Some lines were ellipsized, use -l to show in full.
IP-адрес назначается eth0 с помощью обычного сетевого скрипта в /etc/sysconfig/network-scripts/ifcfg-eth0
.
Проверка /lib/systemd/system/httpd.service
У меня есть:
[Unit]
Description=The Apache HTTP Server
After=network.target remote-fs.target nss-lookup.target
Единственная подобная проблема в сети здесь: https://unix.stackexchange.com/questions/207063/apache-httpd-failing-to-start-on-boot-centos-7 Однако их совет:
systemctl enable NetworkManager-wait-online.service
Failed to execute operation: No such file or directory
Кажется, не работает.
Я полностью потерялся.
Как оказалось, вам нужно использовать NetworkManager, чтобы это работало, так как вы хотите дождаться, пока IP-адреса фактически быть доступным. NetworkManager не установлен по умолчанию в CentOs 7.
Так:
# yum install NetworkManager
Включите это:
systemctl enable NetworkManager-wait-online
Затем:
# systemctl edit httpd.service
И добавить:
After=network.target NetworkManager-wait-online.service remote-fs.target nss-lookup.target
На этом этапе HTTPD запустится только после того, как IP-адрес будет назначен интерфейсу и бинго, он будет фактически Начало.