Heim >Backend-Entwicklung >Python-Tutorial >So verwenden Sie den Betriebs- und Wartungsmanager Fabric

So verwenden Sie den Betriebs- und Wartungsmanager Fabric

高洛峰
高洛峰Original
2017-01-16 17:47:341287Durchsuche

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

So verwenden Sie den Betriebs- und Wartungsmanager Fabric

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 ] [: arg1,arg2=val2,host=foo,hosts='h1;h2',....]
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

Der Fab-Befehl wird verwendet in In Verbindung mit der von uns geschriebenen fabfile.py (andere Dateinamen müssen durch Hinzufügen von -f Dateiname referenziert werden) können einige Befehlszeilenparameter durch entsprechende Methoden ersetzt werden, um sie flexibler zu machen, z. B. „-H 192.168.1.23,192.168.1.24“. ". Wir können dies erreichen, indem wir env.hosts definieren, z. B. "env.hosts=[192.168 .1.23,192.168.1.24]". Der Hauptteil von .fabfile besteht aus mehreren benutzerdefinierten Aufgabenfunktionen. Verschiedene Aufgabenfunktionen implementieren unterschiedliche Betriebslogik . Das Folgende ist eine detaillierte Einführung

3. Globale Attributeinstellungen

Die Rolle des env-Objekts besteht darin, die globalen Einstellungen der Fabfile zu definieren, einschließlich Zielhost und Benutzer , Passwortrolle. Die Beschreibung jedes Attributs lautet wie folgt:

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)
Im Command Execution Fab Deploy können verschiedene Rollen unterschiedliche Aufgabenfunktionen ausführen.

Häufig verwendete APIs

Fabric bietet eine Reihe einfacher, aber leistungsstarker Fabric.api-Befehlssätze. Durch einfaches Aufrufen dieser API können die meisten Anwendungsszenarioanforderungen erfüllt werden. Die Beschreibung lautet wie folgt :

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')
Rufen Sie die Task-Funktion local_task über den Befehl fab auf. Der Ausführungseffekt ist in der folgenden Abbildung dargestellt

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 So verwenden Sie den Betriebs- und Wartungsmanager Fabric

Das Ausführungsergebnis des Aufrufs der Aufgabenfunktion remtoe_task ist in der Abbildung unten dargestellt

Beispiel 2; dynamisch abrufen VerzeichnislisteSo verwenden Sie den Betriebs- und Wartungsmanager FabricIn 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)
Dieses Beispiel implementiert eine Funktion zur dynamischen Eingabe des Remote-Verzeichnisnamens und zum Abrufen der Verzeichnisliste Um die Listeninformationen des Verzeichnisses auf allen Hosts anzuzeigen, wird eine Unterfunktion input_raw (gleichzeitig konfiguriert) aufgerufen, um diesen Zweck zu erreichen. Das Ausführungsergebnis ist wie unten gezeigt

Datei-Upload und AusführungSo verwenden Sie den Betriebs- und Wartungsmanager Fabric

Weitere Artikel zur Verwendung des Betriebs- und Wartungsmanagers Fabric finden Sie auf der chinesischen 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