Ansible – Wie kann man jeden Linux-Prozess, der auf einem Remote-Host läuft, grep (ps -few) und beenden?
Veröffentlicht: 2022-02-24Ansible ist ein ziemlich erstaunliches Systemverwaltungstool. Wir haben in den letzten Wochen eine Reihe von Artikeln auf Ansible veröffentlicht, in denen es um das Kopieren von Dateien auf einem Remote-Host, das Ausführen von Befehlen auf Remote-Hosts, das Installieren von Java, Python auf einem Remote-Host usw. geht.
In diesem Tutorial erfahren Sie, wie Sie einen Java-Prozess, der auf einem Remote-Host ausgeführt wird, grep und diesen Remote-Prozess mit einem einfachen Ansible-Playbook beenden.
Hier sind die Schritte, die wir in diesem Tutorial ausführen werden:
- Führen Sie auf dem Remote-Host CrunchifyAlwaysRunningProgram.java aus
- Folgen Sie dem Tutorial zum dauerhaften Ausführen eines Programms in Java
- Ausführen des Java-Programms mit
nohup java CrunchifyAlwaysRunningProgram &
1 2 3 |
ubuntu @ ip - 172 - 31 - 10 - 150 : ~ $ nohup java CrunchifyAlwaysRunningProgram & [ 1 ] 18174 ubuntu @ ip - 172 - 31 - 10 - 150 : ~ $ nohup : ignoring input and appending output to 'nohup.out' |
Wie überprüfe ich, ob der Prozess gestartet wurde und auf dem Remote-Host ausgeführt wird?
Überprüfen Sie die Prozess ID 18174
.
1 2 3 |
ubuntu @ ip - 172 - 31 - 10 - 150 : ~ $ ps - few | grep CrunchifyAlwaysRunningProgram ubuntu 18174 15069 1 15 : 15 pts / 0 00 : 00 : 00 java CrunchifyAlwaysRunningProgram ubuntu 18187 15069 0 15 : 16 pts / 0 00 : 00 : 00 grep -- color = auto CrunchifyAlwaysRunningProgram |
- Erstellen Sie eine Datei
crunchify-hosts
, die eine entfernte Host-IP hat - Erstellen Sie die Datei
crunchify-grep-kill-process.yml
mit ansiblen Aufgaben für den Grep- und Kill-Java-Prozess - Befehl ausführen: ansible-playbook -i ./crunchify-hosts crunchify-grep-kill-process.yml
- Überprüfen Sie das Ergebnis auf der macOS-Terminalkonsole
crunchify-hosts-Datei
1 2 3 4 5 6 7 8 9 10 |
[ local ] localhost ansible_connection = local ansible_python_interpreter = python [ crunchify ] 3.16.83.84 [ crunchify : vars ] ansible_ssh_user = ubuntu ansible_ssh_private_key_file =/ Users / crunchify / Documents / ansible / crunchify . pem ansible_python_interpreter =/ usr / bin / python3 |
Die Datei enthält die Remote-IP-Adresse und Anmeldeinformationen, die es ermöglichen, sich ohne Passwort anzumelden.
crunchify-grep-kill-process.yml-Datei
1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 |
--- - hosts : crunchify become : yes tasks : - name : Get running processes list from remote host ignore_errors : yes shell : "ps -few | grep CrunchifyAlwaysRunningProgram | awk '{print $2}'" register : running_processes - name : Kill running processes ignore_errors : yes shell : "kill {{ item }}" with_items : "{{ running_processes.stdout_lines }}" - wait_for : path : "/proc/{{ item }}/status" state : absent with_items : "{{ running_processes.stdout_lines }}" ignore_errors : yes register : crunchify_processes - name : Force kill stuck processes ignore_errors : yes shell : "kill -9 {{ item }}" with_items : "{{ crunchify_processes.results | select('failed') | map(attribute='item') | list }}" |
Hier erhält die ansible Playbook-Datei alle Java-Prozesse und beendet sie mit dem einfachen Befehl kill -9
.

Ansible Playbook ausführen:
1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 |
bash1 . 2 $ ansible - playbook - i . / crunchify - hosts crunchify - grep - kill - process . yml PLAY [ crunchify ] ************************************************************************************************************************************************************** TASK [ Gathering Facts ] ******************************************************************************************************************************************************** ok : [ 3.16.83.84 ] TASK [ Get running processes list from remote host ] **************************************************************************************************************************** changed : [ 3.16.83.84 ] TASK [ Kill running processes ] ************************************************************************************************************************************************* changed : [ 3.16.83.84 ] = > ( item = 18174 ) failed : [ 3.16.83.84 ] ( item = 18342 ) = > { "changed" : true , "cmd" : "kill 18342" , "delta" : "0:00:00.002602" , "end" : "2019-05-10 15:20:36.957062" , "item" : "18342" , "msg" : "non-zero return code" , "rc" : 1 , "start" : "2019-05-10 15:20:36.954460" , "stderr" : "/bin/sh: 1: kill: No such process" , "stderr_lines" : [ "/bin/sh: 1: kill: No such process" ] , "stdout" : "" , "stdout_lines" : [ ] } failed : [ 3.16.83.84 ] ( item = 18344 ) = > { "changed" : true , "cmd" : "kill 18344" , "delta" : "0:00:00.002648" , "end" : "2019-05-10 15:20:38.479354" , "item" : "18344" , "msg" : "non-zero return code" , "rc" : 1 , "start" : "2019-05-10 15:20:38.476706" , "stderr" : "/bin/sh: 1: kill: No such process" , "stderr_lines" : [ "/bin/sh: 1: kill: No such process" ] , "stdout" : "" , "stdout_lines" : [ ] } . . . ignoring TASK [ wait_for ] *************************************************************************************************************************************************************** ok : [ 3.16.83.84 ] = > ( item = 18174 ) ok : [ 3.16.83.84 ] = > ( item = 18342 ) ok : [ 3.16.83.84 ] = > ( item = 18344 ) TASK [ Force kill stuck processes ] ********************************************************************************************************************************************* PLAY RECAP * ******************************************************************************************************************************************************************* 3.16.83.84 : ok = 4 changed = 2 unreachable = 0 failed = 0 |
Wie verifizieren?
Versuchen Sie einfach, den grep-Prozess auf dem Remote-Host erneut auszuführen.
1 2 |
ubuntu @ ip - 172 - 31 - 10 - 150 : ~ $ ps - few | grep CrunchifyAlwaysRunningProgram ubuntu 18484 15069 0 15 : 22 pts / 0 00 : 00 : 00 grep -- color = auto CrunchifyAlwaysRunningProgram |
Wie Sie bemerken, sehen Sie die process ID 18174
nicht in der Liste und es wird kein Java-Prozess ausgeführt.
Das ist es.
Dies ist der einfachste Weg, Java-Prozesse mit Ansible zu verarbeiten und zu beenden. Lassen Sie mich wissen, wenn beim Ausführen dieses Ansible playbook
.