This article describes how to use the batch remote management and deployment tool Fabric in Python. The example analyzes the features and usage of Fabric, you can refer to the following example to describe how to use the batch remote management and deployment tool Fabric of Python. Share it with you for your reference. The details are as follows: 
 
Fabric is a powerful batch remote management and deployment tool in Python. it is often used to execute SSH tasks in batches on multiple remote PCs.
 
The common usage methods are summarized as follows:
 
1. First, you need to write the tasks executed in batches to a fabfile. py file,
 
 The code is as follows:
 
#-*-Coding: UTF-8 -*-
 
From fabric. api import run, local, roles, env, cd
Env. hosts = [
'1970. 168.1.110 ',
'1970. 168.1.111 ',
'1970. 168.1.112'
]
Env. user = "username"
Env. password = "password"
Env. port = 22
# Env. parallel = True
# Env. skip_bad_hosts = True
# Env. timeout = 1
# Env. warn_only = True
 
# Local is used to execute commands on the local PC.
# Run is used to execute commands in a remote PC.
Def ls ():
With cd ('/home/workspace/Project '):
Local ('Touch 1. log ')
With cd ('/home/workspace/project2 '):
Local ('Touch 2. log ')
 
# @ Parallel: you can set whether to execute in parallel.
# @ Serial
Def pull ():
With cd ('/home/workspace/Project '):
Run ('Git pull ')
 
Def clean ():
With cd ('/home/workspace/Project '):
Run ('bash clean. sh ')
 
@ Hosts ('1970. 168.1.113 ')
Def robot (device ):
With cd ('/home/workspace/Project '):
Run ('bash run. sh % s robot & sleep 1' % device)
 
The above is a simple fabfile. py, and the defined functions correspond to the executable commands in a fab. 
There are two small considerations: 
 
A. In the run. sh of A remote machine, if you want to execute some non-common tools, you 'd better specify them as absolute paths and use the nohup method as appropriate.
 
B. It is best to add sleep after executing other scripts or commands to prevent Fabric from prematurely closing the session connected to the remote PC, resulting in task execution failure.
 
2. execution process: fabric execution selects the fabfile. py file in the current directory by default,
 
 The code is as follows:
 
Fab clean
Fab pull
Fab robot: hosts = "192.168.1.115", device = 5560
 
You can pass the specified remote PC to fabric through the hosts parameter. the hosts parameter has a higher priority than env. hosts. 
 
You can also pass parameters to commands in fab, such as device.
 
In addition, you can use fab-f otherFabFile. py clean to specify other fabric files.
 
If parallel execution is required, you can also pass parameters such as fab-P-z 15 pull, and 15 indicates the number of PCs in parallel execution.
 
The above, just some simple usage, if you need more advanced usage, you can pay attention to the github home page of the project https://github.com/fabric/fabric.
 
I hope this article will help you with Python programming.