Stoff
Der Titel ist Entwicklung, aber gleichzeitig müssen Sie Entwicklungs-, Test- und Betriebs- und Wartungsarbeiten durchführen ... Warum ist die Aufgabe*3 nicht Gehalt * 3 (o(╯ □╰)o)
In letzter Zeit habe ich immer mehr Dinge übernommen. Die Freigabe-, Betriebs- und Wartungsarbeiten sind ziemlich mechanisch und die Häufigkeit ist ziemlich hoch, was zu Zeitverschwendung führt, aber viele Vorteile.
Fehler beheben, testen, Repository übermitteln (2 Minuten), SSH zur Testumgebung für Pull-Bereitstellung (2 Minuten), Rsync zu den Online-Maschinen A, B, C, D, E (1 Minute), SSH an die fünf Maschinen von ABCDE senden und eine nach der anderen neu starten (8-10 Minuten) = 13-15 Minuten
Das Frustrierende ist, dass jede Operation gleich ist, der Befehl derselbe ist und das Das Schlimmste ist, dass es auf mehreren Maschinen schwierig ist, dies mit einem Skript auf dieser Maschine zu tun. Die meiste Zeit wird mit SSH, dem Eingeben von Befehlen und dem Schreiben als Skript verschwendet. Es kann mit einem Klick ausgeführt werden. Nehmen Sie sich zwei Minuten Zeit, um sich die Ausführungsergebnisse anzusehen
, bis Sie die Fabric
Funktion
Ein sehr leistungsfähiges Werkzeug
Sie können die Befehle für festigen Automatisierte Bereitstellung oder Mehrmaschinenbetrieb in einem Skript
und einige Die Betriebs- und Wartungstools sind mir sehr ähnlich, hauptsächlich weil Python...
einfach, benutzerfreundlich und leicht ist zu verwenden
Natürlich können Sie auch verschiedene Shell-Befehle kombinieren, einschließlich alter Artefakte und moderner Waffen.
Umgebungskonfiguration
Installieren Sie das entsprechende Paket auf dem lokalen Computer und der Zielcomputer (beachten Sie, dass beide erforderlich sind)
sudo easy_install fabric
Es ist derzeit Version 1.6 (oder verwenden Sie pip install, Gleiches)
Nach der Installation können Sie überprüfen, ob die Installation erfolgreich war
[ken@~$] which fab /usr/local/bin/fab
Nach der Installation können Sie die offizielle Dokumentation durchsuchen: http://docs.fabfile.org/en/1.6/
Dann können Sie beginnen
Hallo Welt
Führen Sie zunächst eine einfache Bedienung der Maschine durch und verschaffen Sie sich ein vorläufiges Verständnis. Die Quelle des Beispiels stammt von der offiziellen Website
Erstellen Sie ein neues py-Skript: fabfile.py
def hello(): print("Hello world!")
Befehlszeilenausführung:
[ken@~/tmp/fab$] fab hello Hello world! Done.
Beachten Sie, dass hier nicht Fabfile als Dateiname verwendet werden muss, sondern die Datei
[ken@~/tmp/fab$] mv fabfile.py test.py fabfile.py -> test.py [ken@~/tmp/fab$] fab hello Fatal error: Couldn't find any fabfiles! Remember that -f can be used to specify fabfile path, and use -h for help. Aborting. [ken@~/tmp/fab$] fab -f test.py hello Hello world! Done.
Mit Parametern:
fabfile.py-Skript ändern:
def hello(name, value): print("%s = %s!" % (name, value))
Ausführen
[ken@~/tmp/fab$] fab hello:name=age,value=20 age = 20! Done. [ken@~/tmp/fab$] fab hello:age,20 age = 20! Done.
Native Operation ausführen
Einfache lokale Operation:
from fabric.api import local def lsfab(): local('cd ~/tmp/fab') local('ls')
Ergebnis:
[ken@~/tmp/fab$] pwd;ls /Users/ken/tmp/fab fabfile.py fabfile.pyc test.py test.pyc [ken@~/tmp/fab$] fab -f test.py lsfab [localhost] local: cd ~/tmp/fab [localhost] local: ls fabfile.py fabfile.pyc test.py test.pyc Done.
Der eigentliche Kampf beginnt:
Gehen Sie davon aus, dass Sie jeden Tag eine Konfigurationsdatei mit den Einstellungen übermitteln müssen. py in das Repository (Konflikte werden hier nicht berücksichtigt)
Wenn es sich um einen manuellen Vorgang handelt:
cd /home/project/test/conf/ git add settings.py git commit -m 'daily update settings.py' git pull origin git push origin
Mit anderen Worten, Sie müssen diese Befehle einmal täglich manuell eingeben Der so genannte tägliche Job ist ein mechanisierter Job, der jeden Tag wiederholt werden muss. Sehen wir uns an, wie man Fabric verwendet, um eine Ein-Klick-Abwicklung zu erreichen: (Eigentlich kann dies direkt mit einem Shell-Skript erledigt werden, der Vorteil von Fab ist jedoch nicht gegeben Der Hauptort hier ist die lokale + Vorbereitung für Remote-Operationen. Schließlich erleichtert das Schreiben eines Skripts für Operationen an zwei Orten die Wartung.
from fabric.api import local def setting_ci(): local("cd /home/project/test/conf/") local("git add settings.py") #后面你懂的,懒得敲了…..
Mischung und Anpassung zur Integration von Remote-Operationen
Angenommen, Sie möchten zu diesem Zeitpunkt zu Maschine A gehen /home/ken/project Aktualisieren Sie die Konfigurationsdatei im entsprechenden Projektverzeichnis
#!/usr/bin/env python # encoding: utf-8 from fabric.api import local,cd,run env.hosts=['user@ip:port',] #ssh要用到的参数 env.password = 'pwd' def setting_ci(): local('echo "add and commit settings in local"') #刚才的操作换到这里,你懂的 def update_setting_remote(): print "remote update" with cd('~/temp'): #cd用于进入某个目录 run('ls -l | wc -l') #远程操作用run def update(): setting_ci() update_setting_remote()
Führen Sie es dann aus:
[ken@~/tmp/fab$] fab -f deploy.py update [user@ip:port] Executing task 'update' [localhost] local: echo "add and commit settings in local" add and commit settings in local remote update [user@ip:port] run: ls -l | wc -l [user@ip:port] out: 12 [user@ip:port] out: Done.
Beachten Sie: Wenn env.password nicht deklariert ist, führen Sie es auf dem entsprechenden Computer aus. Es erscheint eine Interaktion, die nach einem Passwort fragt
Multi-Server-Mashup
Um mehrere Server zu betreiben, müssen Sie mehrere Hosts konfigurieren
#!/usr/bin/env python # encoding: utf-8 from fabric.api import * #操作一致的服务器可以放在一组,同一组的执行同一套操作 env.roledefs = { 'testserver': ['user1@host1:port1',], 'realserver': ['user2@host2:port2', ] } #env.password = '这里不要用这种配置了,不可能要求密码都一致的,明文编写也不合适。打通所有ssh就行了' @roles('testserver') def task1(): run('ls -l | wc -l') @roles('realserver') def task2(): run('ls ~/temp/ | wc -l') def dotask(): execute(task1) execute(task2)
Ergebnisse:
[ken@~/tmp/fab$] fab -f mult.py dotask [user1@host1:port1] Executing task 'task1' [user1@host1:port1] run: ls -l | wc -l [user1@host1:port1] out: 9 [user1@host1:port1] out: [user2@host2:port2] Executing task 'task2' [user2@host2:port2] run: ls ~/temp/ | wc -l [user2@host2:port2] out: 11 [user2@host2:port2] out: Done.
Erweiterungen
1. Farbe
Sie können die Farbe drucken , was beim Anzeigen der Operationsergebnisinformationen auffälliger und praktischer ist
aus Stofffarbenimport *
def show():
print green('success')
rot drucken('fail')
gelb drucken('gelb')
#fab - f color.py show
1.Host, Benutzer, Port, Passwort-Konfigurationsliste, alles eingeschrieben eine Datei
oder direkt in das Skript, das ist natürlich mehr... ....
env.hosts = [ 'host1', 'host2' ] env.passwords = { 'host1': "pwdofhost1", 'host2': "pwdofhost2", }
oder
env.roledefs = { 'testserver': ['host1', 'host2'], 'realserver': ['host3', ] } env.passwords = { 'host1': "pwdofhost1", 'host2': "pwdofhost2", 'host3': "pwdofhost3", }
2. Parsen Sie es in Verschachtelung entsprechend dem Schlüssel zuordnen und in „Deploy“ einfügen
Darüber hinaus kann der Befehl auch in einer Liste von cmds verfestigt werden...
Weitere Artikel im Zusammenhang mit Hinweisen zur Python-Fabric-Nutzung finden Sie unter Bitte achten Sie auf die chinesische PHP-Website!