


Recently, I have taken over more and more things. The work of release and operation and maintenance is quite mechanical, and the frequency is quite high, which leads to a waste of time but has many advantages. Fix bugs, test, submit the repository (2 minutes), ssh to the test environment for pull deployment (2 minutes), rsync to online machines A, B, C, D, E (1 minute), ssh to ABCDE5 respectively Each machine is restarted one by one (8-10 minutes) = 13-15 minutes. The frustrating thing is that each operation is the same and the command is the same. The terrible thing is that on multiple machines, it is difficult to do it with one script on this machine. The main time was wasted on ssh, typing commands, and writing them into scripts, which can be executed with one click. It took two minutes to look at the execution results until I discovered that fabric can solidify commands for automated deployment or multi-machine operations. Into a script is very similar to some operation and maintenance tools. The main reason for using it is that it is simple, easy to use and easy to use. Of course, you can also combine various shell commands. The difference between ancient artifacts and modern weapons
Environment Configuration
Install the corresponding package on the local machine and the target machine (note, both must be present)
sudo easy_install fabric
It is currently version 1.6 (or use pip install, the same )
After the installation is completed, you can check whether the installation is successful
[ken@~$] which fab /usr/local/bin/fab
After the installation is completed, you can browse the official documentation
Then, you can get started
hello world
First perform simple operations on this machine and have a preliminary understanding. The source of the example is from the official website
Create a new py script: fabfile.py
def hello(): print("Hello world!")
Command line execution:
[ken@~/tmp/fab$] fab hello Hello world!
Done.
Note that fabfile does not need to be used as the file name here, but the file needs to be specified when executing[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.With parameters:
Modify the fabfile.py script :
def hello(name, value): print("%s = %s!" % (name, value))
Execute
[ken@~/tmp/fab$] fab hello:name=age,value=20 age = 20! Done. [ken@~/tmp/fab$] fab hello:age,20 age = 20!
Done.
Perform native operationSimple local operation
from fabric.api import local def lsfab(): local('cd ~/tmp/fab') local('ls')
Result:
[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.
Actual combat begins:
Assume that you have to submit a configuration file settings.py to the repository every day (conflicts are not considered here)
If it is a manual operation:
cd /home/project/test/conf/ git add settings.py git commit -m 'daily update settings.py' git pull origin git push origin
In other words, you have to type these commands manually once a day. The so-called daily job is a mechanized job that needs to be repeated every day. Let us see how to use fabric to achieve one-click completion: (It is actually practical Shell scripts can be done directly, but the advantage of fab is not here. Here we mainly prepare for local + remote operations. After all, writing one script for operations in two places is easy to maintain)
from fabric.api import local def setting_ci(): local("cd /home/project/test/conf/") local("git add settings.py") #后面你懂的,懒得敲了…..
Mix and match to integrate remote operations Operation
At this time, assume that you want to go to the project directory corresponding to machine A's /home/ken/project to update the configuration file#!/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()
Then execute:
[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.
Note that if env.password is not declared, an interaction requiring password input will pop up when executing to the corresponding machine
Multiple server mashup
#!/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)
Result:
[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.
Extension1. Color
You can print the color, which is more eye-catching and convenient when viewing the operation result information
from fabric.colors import * def show(): print green('success') print red('fail') print yellow('yellow') #fab -f color.py show
2. Errors and exceptions
About error handling
By default, a set of commands will not continue to execute after the previous command fails to execute
After failure Different processing can also be performed. The document
is not used at the moment. Please read it if you use it later
3. Password management
See the document
A better way to manage passwords. I’m a bit unsophisticated and haven’t gotten through it. The main reason is that the server list changes frequently. My solution is:
1. Host, user, port, password configuration list, all written in A file
or directly into the script, of course this is more...
env.hosts = [ 'host1', 'host2' ] env.passwords = { 'host1': "pwdofhost1", 'host2': "pwdofhost2", }
or
env.roledefs = { 'testserver': ['host1', 'host2'], 'realserver': ['host3', ] } env.passwords = { 'host1': "pwdofhost1", 'host2': "pwdofhost2", 'host3': "pwdofhost3", }
2. Parse into map nesting based on key , put it in deploy
In addition, the command can also be solidified into a cmds list...
For more python fabric implementation examples of remote operation and deployment related articles, please pay attention to the PHP Chinese website!

Implementing factory pattern in Python can create different types of objects by creating a unified interface. The specific steps are as follows: 1. Define a basic class and multiple inheritance classes, such as Vehicle, Car, Plane and Train. 2. Create a factory class VehicleFactory and use the create_vehicle method to return the corresponding object instance according to the type parameter. 3. Instantiate the object through the factory class, such as my_car=factory.create_vehicle("car","Tesla"). This pattern improves the scalability and maintainability of the code, but it needs to be paid attention to its complexity

In Python, the r or R prefix is used to define the original string, ignoring all escaped characters, and letting the string be interpreted literally. 1) Applicable to deal with regular expressions and file paths to avoid misunderstandings of escape characters. 2) Not applicable to cases where escaped characters need to be preserved, such as line breaks. Careful checking is required when using it to prevent unexpected output.

In Python, the __del__ method is an object's destructor, used to clean up resources. 1) Uncertain execution time: Relying on the garbage collection mechanism. 2) Circular reference: It may cause the call to be unable to be promptly and handled using the weakref module. 3) Exception handling: Exception thrown in __del__ may be ignored and captured using the try-except block. 4) Best practices for resource management: It is recommended to use with statements and context managers to manage resources.

The pop() function is used in Python to remove elements from a list and return a specified position. 1) When the index is not specified, pop() removes and returns the last element of the list by default. 2) When specifying an index, pop() removes and returns the element at the index position. 3) Pay attention to index errors, performance issues, alternative methods and list variability when using it.

Python mainly uses two major libraries Pillow and OpenCV for image processing. Pillow is suitable for simple image processing, such as adding watermarks, and the code is simple and easy to use; OpenCV is suitable for complex image processing and computer vision, such as edge detection, with superior performance but attention to memory management is required.

Implementing PCA in Python can be done by writing code manually or using the scikit-learn library. Manually implementing PCA includes the following steps: 1) centralize the data, 2) calculate the covariance matrix, 3) calculate the eigenvalues and eigenvectors, 4) sort and select principal components, and 5) project the data to the new space. Manual implementation helps to understand the algorithm in depth, but scikit-learn provides more convenient features.

Calculating logarithms in Python is a very simple but interesting thing. Let's start with the most basic question: How to calculate logarithm in Python? Basic method of calculating logarithm in Python The math module of Python provides functions for calculating logarithm. Let's take a simple example: importmath# calculates the natural logarithm (base is e) x=10natural_log=math.log(x)print(f"natural log({x})={natural_log}")# calculates the logarithm with base 10 log_base_10=math.log10(x)pri

To implement linear regression in Python, we can start from multiple perspectives. This is not just a simple function call, but involves a comprehensive application of statistics, mathematical optimization and machine learning. Let's dive into this process in depth. The most common way to implement linear regression in Python is to use the scikit-learn library, which provides easy and efficient tools. However, if we want to have a deeper understanding of the principles and implementation details of linear regression, we can also write our own linear regression algorithm from scratch. The linear regression implementation of scikit-learn uses scikit-learn to encapsulate the implementation of linear regression, allowing us to easily model and predict. Here is a use sc


Hot AI Tools

Undresser.AI Undress
AI-powered app for creating realistic nude photos

AI Clothes Remover
Online AI tool for removing clothes from photos.

Undress AI Tool
Undress images for free

Clothoff.io
AI clothes remover

Video Face Swap
Swap faces in any video effortlessly with our completely free AI face swap tool!

Hot Article

Hot Tools

Zend Studio 13.0.1
Powerful PHP integrated development environment

WebStorm Mac version
Useful JavaScript development tools

SublimeText3 English version
Recommended: Win version, supports code prompts!

SublimeText3 Chinese version
Chinese version, very easy to use

PhpStorm Mac version
The latest (2018.2.1) professional PHP integrated development tool
