web-dev-qa-db-fra.com

Comment savoir si httpd est en cours d'exécution ou non via la ligne de commande?

Je travaille sur un petit panneau de contrôle pour mon serveur. J'ai besoin d'une commande qui dira si httpd est en cours d'exécution ou arrêté.

Utilisera probablement le même code pour d'autres services également.

30
user70804

La plupart des gens exécutent leur httpd (Apache, Nginx, etc.) via un système init. C'est presque certainement le cas si vous avez installé à partir d'un package. Presque tous ces systèmes d'initialisation ont une méthode qui fonctionne si elle est en cours d'exécution. Dans mon cas, j'utilise nginx qui expédie un script init de style SysV et qui accepte un argument status, comme ceci:

$ /etc/init.d/nginx status
 * nginx is running

Évidemment, si vous utilisez un autre httpd, script ou système d'initialisation, vous aurez une syntaxe légèrement différente, mais à moins que vous ne lanciez manuellement le httpd vous-même (ce qui semble être la pire idée du monde), vous êtes en utilisant probablement un script de démarrage géré et agréable qui vous permettra d'interroger l'état.

réponse de slm a plus sur ce type de requête init mais le problème avec la confiance est qu'il ne vous indique vraiment que si un processus est toujours en cours d'exécution. Le processus principal de votre httpd pourrait être en cours d'exécution mais en quelque sorte bloqué. Il est très logique d'ignorer les tests initiaux simples et de passer aux tests comportementaux.

Une chose que nous savons sur httpds, c'est qu'ils écoutent. Habituellement sur le port *:80, mais si ce n'est pas le cas, vous pouvez adapter le code suivant le code. Ici, je suis juste awking la sortie de netstat pour voir si elle écoute sur le bon port.

$ Sudo netstat -ntlp | awk '$4=="0.0.0.0:80"'
tcp        0      0 0.0.0.0:80              0.0.0.0:*               LISTEN      2079/nginx

Nous pourrions également vérifier quel processus est également en cours d'exécution pour nous assurer que le est correct httpd est en cours d'exécution. Nous pourrions faire toutes sortes de vérifications. Cela dépend de la paranoïaque que vous voulez être :)

Mais même cela n'est que le reflet d'un httpd. Vous voulez vraiment le tester? Eh bien, essayons .

$ wget --spider -S "http://localhost" 2>&1 | awk '/HTTP\// {print $2}'
200

Je regarde juste le code de réponse (200 signifie "A-Ok!") Mais encore une fois, nous pourrions creuser et tester la sortie pour nous assurer qu'elle est générée correctement.

Mais même ce n'est pas si complet. Vous vérifiez localhost et cela rapporte 200, rien de mal? Et si les castors mâchaient le câble réseau qui alimente le httpd (mais pas le reste du système)? Alors quoi?! Vous signalez une disponibilité lorsque vous êtes réellement en panne. Peu de choses semblent plus non professionnelles que des données d'état incorrectes.

Parlons donc à un serveur externe (idéalement sur une connexion complètement différente, dans une autre galaxie très loin) et demandons-lui d'interroger notre serveur:

$ ssh tank 'wget --spider -S "http://bert" 2>&1' | awk '/HTTP\// {print $2}'
200

À ce stade, tous les problèmes signalés sont soit des problèmes in-app (qui peuvent avoir leur propre gestion et rapport d'erreurs, soit ils sont à la fin du client).

Une combinaison de ces tests peut également aider à déterminer où se situe le problème.

28
Oli

Vous pouvez utiliser la commande services universellement sur la plupart des distributions Linux.

$ service <service> status

Exemple

$ service httpd status
httpd (pid  23569) is running...

Cette même commande peut être utilisée pour tous les services qui s'exécutent sur une base individuelle ou pour trouver l'état de tous les services.

$ service --status-all
python is stopped
automount (pid 22457) is running...
Avahi daemon is not running
Avahi DNS daemon is not running
crond (pid  23577) is running...
gpm is stopped
hald is stopped
httpd (pid  23569) is running...
...

Les différentes méthodes de SysVinit, Systemd et Upstart pour répertorier les services

Si vous utilisez l'un des cadres de gestion de services les plus courants, vous pouvez utiliser les méthodes suivantes pour répertorier les services dans chacun d'eux.

SysVinit

$  ls -l /etc/init.d/ | head -10
total 220
-rwxr-xr-x 1 root root  1422 Jan 13  2009 ajaxterm
-rwxr-xr-x 1 root root  3052 Apr 20  2012 autofs
-rwxr-xr-x 1 root root  1877 Apr 13  2011 avahi-daemon
-rwxr-xr-x 1 root root  1824 Apr 13  2011 avahi-dnsconfd
-rwxr-xr-x 1 root root  1926 Feb 22  2012 crond
-rwxr-xr-x 1 root root 14291 Dec 19  2011 functions
-rwxr-xr-x 1 root root  1778 Jan  6  2007 gpm
-rwxr-xr-x 1 root root  1586 Mar  5  2011 haldaemon
-rwxr-xr-x 1 root root  5742 Dec 19  2011 halt

Systemd

$ systemctl list-unit-files --type=service | head -10
UNIT FILE                                   STATE   
abrt-ccpp.service                           enabled 
abrt-oops.service                           enabled 
abrt-pstoreoops.service                     disabled
abrt-vmcore.service                         enabled 
abrt-xorg.service                           enabled 
abrtd.service                               enabled 
accounts-daemon.service                     enabled 
alsa-restore.service                        static  
alsa-state.service                          static  

Débutant

$ initctl list | head -10
avahi-daemon start/running, process 1090
mountall-net stop/waiting
nmbd start/running, process 2045
passwd stop/waiting
rc stop/waiting
rsyslog start/running, process 1088
tty4 start/running, process 1211
udev start/running, process 483
upstart-udev-bridge start/running, process 480
ureadahead-other stop/waiting

Références

25
slm