Heim  >  Artikel  >  Backend-Entwicklung  >  Hinweise zur Verwendung von Python-Stoffen

Hinweise zur Verwendung von Python-Stoffen

高洛峰
高洛峰Original
2017-01-16 17:37:591075Durchsuche

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.
während der Ausführung angegeben werden muss

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!


Stellungnahme:
Der Inhalt dieses Artikels wird freiwillig von Internetnutzern beigesteuert und das Urheberrecht liegt beim ursprünglichen Autor. Diese Website übernimmt keine entsprechende rechtliche Verantwortung. Wenn Sie Inhalte finden, bei denen der Verdacht eines Plagiats oder einer Rechtsverletzung besteht, wenden Sie sich bitte an admin@php.cn