什么是Fabric
Fabric是一个用Python开发的部署工具,最大特点是不用登录远程服务器,在本地运行远程命令,几行Python脚本就可以轻松部署。
安装
- 版本区别,如果你安装的是旧版的 Fabric,那么新版的 Fabric 是不兼容旧版的,最新的 Fabric 不需要
fabfile.py
文件, 也不需要fab
命令,目前 Fabric 有三个版本: - Fabric1 就是以前的 Fabric,只支持 Python2,已不推荐使用;
- Fabric2 就是现在的 Fabric,同时支持 Python2 和 Python3, 也是官方强烈推荐的版本;
- Fabric3,这是网友从旧版的 Fabric1 克隆过来的非官方版本,但是兼容 Fabric1,也支持 Python2 和 Python3。
pip install fabric
部署脚本说明
# deploy.py
# 1. 创建一个远程连接
# 2. 进入指定目录
# 3. 在指定目录下面执行重启命令
from fabric import Connection
def main():
# ssh验证是不需要connect_kwargs
c=Connection(host='服务器的 IP 地址',user='用于登录服务器的用户名',port='SSH 远程服务器的端口号',connect_kwargs={"password": "用户名对应的密码"})
source_fold='需要部署的项目根目录在服务器上的位置'
git_repo="you git repository"
c.cd(source_fold)
c.run('git init && git pull %s'%git_repo)
with c.cd(source_fold):
c.run('../env/bin/pip install -r requirements.txt')
c.run('../env/bin/python3 manage.py collectstatic')
c.run('../env/bin/python3 manage.py migrate')
c.sudo('systemctl daemon-reload')
c.sudo('systemctl start knows365')
c.sudo('service nginx reload')
if __name__ == "__main__":
main()
python deploy.py
Fabric API
- 以Connection对象,完整构建 Connection 对象的方式如下:
class Connection(Context):
host = None
user = None
port = None
ssh_config = None
connect_timeout = None
connect_kwargs = None
多台服务器
- 在多台服务器运行命令,使用迭代挨个服务器执行命令:
#web1,web2,mac1 都是服务器的名字,你也可以用ip代替
>>> from fabric import Connection
>>> for host in ('web1', 'web2', 'mac1'):
>>> result = Connection(host).run('uname -s')
... print("{}: {}".format(host, result.stdout.strip()))
- 第二种办法:用SerialGroup
# Group(*hosts, **kwargs) 参数说明:
# *hosts: 可以传入多个主机名或IP
# **kwargs 接收的参数可以和Connection一样,可以指定密码
from fabric import SerialGroup as Group
pool = Group('web1', 'web2', 'web3', connect_kwargs={"password": "youpassword"} )
pool.put('myfiles.tgz', '/opt/mydata')
pool.run('tar -C /opt/mydata -xzvf /opt/mydata/myfiles.tgz')
作者:刘志军
链接:https://juejin.im/post/5c2463936fb9a049c965bbf0
来源:掘金
著作权归作者所有。商业转载请联系作者获得授权,非商业转载请注明出处。