Fabric-Installation
Fabric unterstützt die Installation von Pip, Easy_Install oder Quellcode, was sehr praktisch ist, um das Problem der Paketabhängigkeit zu lösen (Je nach Benutzerumgebung können Sie Pip oder Easy_Install wählen)
Pip install fabric
easy_install Fabric
Die Installation des Quellcodes wird nicht eingeführt.
Überprüfen Sie das Installationsergebnis. Wenn beim Importieren des Moduls keine Ausnahme angezeigt wird, ist die Installation erfolgreich:
root@Python_S6:~# python
Python 2.7.5+ (Standard, 19. September 2013). , 13: 48:49)
[GCC 4.8.1] unter Linux2
Geben Sie „Hilfe“, „Copyright“, „Credits“ oder „Lizenz“ ein, um weitere Informationen zu erhalten.
>>> Stoff importieren
>>>
Die offizielle Website bietet ein einfaches Beispiel für den Einstieg:
root@Python_S6:/home/chart7/test/fabric# cat farbic.py #!/usr/bin/env python # -*- coding: utf-8 -*- from fabric.api import run def host_type(): #定义一个任务函数,通过run方法实现远程执行'uname -s'命令 run('uname -s')
Das Laufergebnis ist wie in der Abbildung dargestellt Abbildung unten
Der vom Befehl referenzierte Standarddateiname ist fabfile.py. Wenn ein nicht standardmäßiger Dateiname verwendet wird, muss er mit „-f“ angegeben werden. B.: fab -H 192.168.1.23,192.168.1.24 - f host_type.py host_type. Wenn der Verwaltungscomputer und der Zielhost nicht mit der Schlüsselauthentifizierungsvertrauensstellung konfiguriert sind, werden Sie aufgefordert, das Anmeldekennwort des entsprechenden Kontos einzugeben des Zielhosts.
1. Häufig verwendete Parameter von fab
fab bietet als Befehlseingang des Fabric-Programms eine Fülle von Parameteraufrufen:
fab [Optionen ]
Im Folgenden sind einige häufig verwendete Parameter aufgeführt, die Sie mit fab verwenden können. Hilfe zum Anzeigen.
-l, den Namen der definierten Aufgabenfunktion anzeigen;
-f, die Fab-Eintragsdatei angeben, der Standard-Eintragsdateiname ist
-g, das Gateway-Gerät angeben, Geben Sie beispielsweise in der Bastion-Host-Umgebung einfach die Bastion-Host-IP ein. Geben Sie den Zielhost an. Mehrere Hosts werden durch „,“ getrennt. Führen Sie mehrere Host-Aufgaben im asynchronen und parallelen Modus aus , der Standardwert ist der serielle Betrieb;
-R, Rolle angeben, Rollennamen verwenden, um Geräte verschiedener Geschäftsgruppen zu unterscheiden;
-T, festlegen Zeitüberschreitung bei der Ausführung des Remote-Host-Befehls;
-w, wenn die Befehlsausführung fehlschlägt, wird eine Warnung ausgegeben, anstatt die Aufgabe standardmäßig zu beenden
2. Fabfile schreiben
Verwenden Sie beim Zitieren das Python-Modifikatorformular. Schauen wir uns ein Beispiel an:
env.host,定义目标主机,可以用IP或主机名表示,以Python的列表形式定义,如env.hosts=['192.168.1.23,192.168.1.24']. env.exculde_hosts,排除指定主机,如env.exclude_hosts=['192.168.1.23'] env.user,定义用户名,如env.user="root" env.port,定义目标主机端口,如env.port = '22' env.password,定义密码,如env.password='123456' env.passwords,与password功能一样,区别在于不同主机不同密码的应用场景,需要注意的是,配置passwords时需要配置用户,主机,端口等信息,如:env.passwords = {'root@192.168.1.21:22':'123456', 'root@192.168.1.23:22':'3234234', 'root@192.168.1.24:23':'09887', } env.gateway,定义网关(中转,堡垒机)IP,如env.gateway = '192.168.1.1' env.roledefs,定义角色分组,比如web组与db组主机区分开来,定义如下: env.roledefs = { 'webservers':['192.168.1.21','192.168.1.22','192.168.1.23'], 'dbservers':['192.168.1.24','192.168.1.25'], }
@roles('webservers') def webtask(): run('/etc/init.d/nginx start') @roles('dbservers'): def dbtask(): run('/etc/init.d/mysql start') @roles('webservers','dbservers') def publictask(): run('uptime') def deploy(): execute(webtask) execute(dbtask) execute(publictask)
Beispiel 1: Lokale und Remote-Host-Informationen anzeigen
Dieses Beispiel ruft die Methode local() auf, um lokale Befehle auszuführen, und fügt die Änderung „@runs_once“ hinzu, um sicherzustellen, dass die Aufgabe funktioniert nur einmal ausgeführt. Rufen Sie die run()-Methode auf, um Remote-Befehle auszuführen.local,执行本地命令,如local:('uname -s'); lcd,切换本地目录,如lcd:('/home'); cd,切换远程目录,如cd:('/data/logs/'); run,执行远程命令,如:run('free -m') sudo,sudo方式执行远程命令,如:sudo('/etc/init.d/httpd start'); put,上传本地文件到远程主机,如:put('/home/user.info','/data/user.info'); get,从远程主机下载文件到本地,如:get('/home/user.info','/data/user.info'); prompt,获得用户输入信息,如:prompt('please input user password:'); confirm,获得提示信息确认,如:confirm('Test failed,Continue[Y/N]'); reboot,重启远程主机,如reboot(); @task,函数修饰符,标识符的函数为fab可调用,非标记对fab不可见,纯业务逻辑; @runs_once,函数修饰符,标识符的函数只会执行一次,不受多台主机影响;
#!/usr/bin/env python # -*- coding: utf-8 -*- from fabric.api import * env.user = 'root' env.hosts = ['192.168.1.43','192.168.1.23','192.168.1.24'] env.port = '22' env.password = '123456' @runs_once #查看本地系统信息,当有多台主机时只运行一次 def local_task(): #本地任务函数 local('uname -a') def remote_task(): with cd('/data'): #with的作用是让后面的表达式语句继承当前状态,实现cd /var && ls -l的效果 run('ls -l')
Das Ergebnis zeigt [192.168.1.23] Ausführung der Aufgabe „local_task“, aber tatsächlich wird die Aufgabe nicht auf dem Host 192.168.1.23 ausgeführt, sondern der Ausführungseffekt von „uname -a“ lokal zum Fabric-Host wird zurückgegeben
Das Ausführungsergebnis des Aufrufs der Aufgabenfunktion remtoe_task ist in der Abbildung unten dargestelltBeispiel 2; dynamisch abrufen VerzeichnislisteIn diesem Beispiel wird der Modifikator „@task“ verwendet, um den Eintrag zu markieren. Auf die Funktion go() kann extern zugegriffen werden. Sie arbeitet mit dem Symbol „@runs_once“ zusammen, um auf Benutzereingaben zu warten Die Funktion wird aufgerufen, um die Remote-Befehlsausführung zu implementieren.
#!/usr/bin/env python # -*- coding: utf-8 -*- from fabric.api import * env.user = 'root' env.hosts = ['192.168.1.23','192.168.1.24'] env.password = '123456' @runs_once #在主机遍历过程中,只有一台出发此函数 def input_raw(): return prompt("please input direcotry name:",default="/home") def worktask(dirname): run("ls -l %s" %dirname) @task def go(): getdirname = input_raw() worktask(getdirname)
Datei-Upload und Ausführung
Weitere Artikel zur Verwendung des Betriebs- und Wartungsmanagers Fabric finden Sie auf der chinesischen PHP-Website!