导读:fabric支持pip、easy_install和源码安装的方式,是基于python(25及以上版本)的一种自动化运维工具。工具/原料fabriclinuxpip安装1pip install fabricENDeasy_install安装1
fabric支持pip、easy_install和源码安装的方式,是基于python(25及以上版本)的一种自动化运维工具。
工具/原料
fabric
linux
pip安装
1
pip install fabric
END
easy_install安装
1
easy_install fabric
END
源码安装
1
首先安装依赖包
yum -y install python-setuptools python-devel
2
下载fabric源码包并解压安装
tar zxvf Fabric-182targz
cd Fabric-182
python setuppy install
END
注意事项
python一定要是25及以上版本
个人推荐使用源码安装
最近对公司的通道机账号进行改造管理,全面的更加深入的理解了公司账号管理的架构。(注:基本上所有的机器上的ssh不能使用,只有部分机器能够使用。为了安全的角度考虑,安装的不是公版的ssh,而都是定制版的ssh,(限制了机器上的源IP地址即可))。
自动化管理服务器,有两种 *** :
之一种 *** ,是我们公司自己开发的(服务器大概是3W台),基本上服务器之间不能够通过ssh互相连通,只能是一台服务器能够连到所有的服务器上,这台服务器我们称之为通道机(也叫堡垒机),当我们想登某台服务器的时候,需要先登上这台通道机,然后经过一系列的验证之后,就能自动的登上你要登到的服务器上。
并且我们自己开发了一套叫做通道机API的方式,来管理3W台服务器,比如收集各台服务器的信息等。其这个API的本质就是使用的是POST的方式将命令post到目标机上,然后返回结果进行处理即可。这是一个大概的思想。
第二种 *** ,就是使用ssh的协议进行管理,使用python的paramiko来进行管理,下面会进行介绍:
有一些想法,可以使用python的paramiko模块来进行管理名下服务器,前提是能够ssh到各个服务器上。
下面对这个paramiko的模块做个简单的介绍和分享:
1简介:
paramiko是用python语言写的一个模块,遵循SSH2协议,支持以加密和认证的方式,进行远程服务器的连接。
由于使用的是python这样的能够跨平台运行的语言,所以所有python支持的平台,如Linux, Solaris, BSD, MacOS X, Windows等,paramiko都可以支持,因此,如果
需要使用SSH从一个平台连接到另外一个平台,进行一系列的操作时,paramiko是更佳工具之一。
举个常见的例子,现有这样的需求:需要使用windows客户端,远程连接到Linux服务器,查看上面的日志状态,大家通常使用的 *** 会是:
1:用telnet
2:用PUTTY
3:用WinSCP
4:用XManager等…
那现在如果需求又增加一条,要从服务器上下载文件,该怎么办?那常用的办法可能会是:
1:Linux上安装FTP并配置
2:Linux上安装Sambe并配置…
大家会发现,常见的解决 *** 都会需要对远程服务器必要的配置,如果远程服务器只有一两台还好说,如果有N台,还需要逐台进行配置,或者需要使用代码进行以上操作
时,上面的办法就不太方便了。
使用paramiko可以很好的解决以上问题,比起前面的 *** ,它仅需要在本地上安装相应的软件(python以及PyCrypto),对远程服务器没有配置要求,对于连接多台服
务器,进行复杂的连接操作特别有帮助。
2使用的几个简单的案例:
下面是两种使用paramiko连接到linux服务器的代码:
方式一:
1 ssh = paramikoSSHClient()2 sshset_missing_host_key_policy(paramikoAutoAddPolicy())3 sshconnect("IP地址",22,"用户名","密码")
上面的第二行代码的作用是允许连接不在know_hosts文件中的主机。
方式二:
1 t = paramikoTransport(("IP地址","端口"))2 tconnect(username = “用户名”, password = “口令”)3 如果连接远程主机需要提供密钥,上面第二行代码可改成:4 tconnect(username = “用户名”, password = “口令”, hostkey=”密钥”)
3一些简单的例子:
如果linux服务器开放了22端口,在windows端,我们可以使用paramiko远程连接到该服务器,并执行任意命令,然后通过 print或其它方式得到该结果。
1 #!/usr/bin/python 2 import paramiko3 4 ssh = paramikoSSHClient()5 sshset_missing_host_key_policy(paramikoAutoAddPolicy())6 sshconnect("某IP地址",22,"用户名", "口令")7 stdin, stdout, stderr = sshexec_command("你的命令")8 print stdoutreadlines()9 sshclose()
其中的”你的命令”可以任意linux支持的命令,如一些常用的命令:
1 df:查看磁盘使用情况2 uptime:显示系统运行时间信息3 cat:显示某文件内容4 mv/cp/mkdir/rmdir:对文件或目录进行操作5 / *** in/service/ xxxservice start/stop/restart:启动、停止、重启某服务6 netstat -ntl |grep 8080:查看8080端口的使用情况
7 或者 nc -zv localhost :查看所有端口的使用情况
8 find / -name XXX:查找某文件9
这样一来,对于linux的任何操作几乎都可以通过windows端完成,如果对该功能进行引申,还可以同时管理多台服务器。
4 从widnows端下载linux服务器上的文件
1 #!/usr/bin/python 2 import paramiko 3 4 t = paramikoTransport((“主机”,”端口”)) 5 tconnect(username = “用户名”, password = “口令”) 6 sftp = paramikoSFTPClientfrom_transport(t) 7 remotepath=’/var/log/systemlog’ 8 localpath=’/tmp/systemlog’ 9 sftpget(remotepath, localpath)10 tclose()
5从widnows端上传文件到linux服务器
1 #!/usr/bin/python 2 import paramiko 3 4 t = paramikoTransport((“主机”,”端口”)) 5 tconnect(username = “用户名”, password = “口令”) 6 sftp = paramikoSFTPClientfrom_transport(t) 7 remotepath=’/var/log/systemlog’ 8 localpath=’/tmp/systemlog’ 9 sftpput(localpath,remotepath)10 tclose()
你可以用pip进行安装,命令是
pip install Crypto
python版本升级和pip安装 *** :
11 Python版本升级
CentOS 63自带的Python版本为26,首先需要升级到27版本。由于旧版本的Python已被深度依赖,所以不能卸载原有的Python,只能全新安装。
1 下载Pyhon,选择下载Gzipped source tar ball (276) (sig),网址:https://wwwpythonorg/download/releases/276
2 解压安装,命令如下
tar -xvf Python-276tgz
cd Python-276
/configure --prefix=/usr/local/python27
make
make install
3 创建链接来使系统默认python变为python27
ln -fs /usr/local/python27/bin/python27 /usr/bin/python
4 查看Python版本
python –V
5 修改yum配置(否则yum无法正常运行)
vi /usr/bin/yum
将之一行的#!/usr/bin/python修改为系统原有的python版本地址#!/usr/bin/python26
至此CentOS63系统Python已成功升级至276版本。
12 安装pip
Pip是一个安装和管理python包的工具。
安装 *** 如下:
1 下载pip,地址https://rawgithubcom/pypa/pip/master/contrib/get-pippy
2 执行安装命令
python get-pippy
3 创建连接(否则会报错提示“命令不存在”)
ln -s /usr/local/python27/bin/pip /usr/bin/pip
pycrypto模块好像是用命令python setuppy install安装 打开命令提示符,切换到解压后的crypto模块文件夹,输入命令 C:\python33\python setuppy install 回车 安装模块
11 从清华大学镜像库下载
我选择的Anaconda版本是202104的,最新版好像后面是安装gdal库还是配置GEE的时候会出问题,唉,记不清了。就往前选了一个版本。
12 根据前面安装文件夹路径(根目录D盘下)配置环境这里改一下:
D:\Anaconda3
D:\Anaconda3\Scripts
D:\Anaconda3\Library\bin
13 检查这里输入python验证安装成功之后,要输入exit()退出python环境
14 国内镜像这步可以不用吧
3 配置GEE
31配置 ***
根据自己电脑的 *** 端口修改(在设置— *** 和Internet— *** 里查看)
set http_proxy=http://127001:8580
set https_proxy=http://127001:8580
32 配置GEE
参考了另一篇文章,直接从3开始
3在Anaconda Prompt中输入命令
4安装鉴权验证依赖库
python36以上的:根据 python36安装pycryto库失败
需要把输入命令改为pip install pycryptodome
如果已经输入过pip install pyCrypto,需要先uninstall一下
pip install pycryptodome
安装这个库就可以了。
然后进入这个库的目录:Lib\site-packages
找到 crypto 这个库,更改为首字母大写 Crypto 即可
也是被坑了一大把一大把
首先说明:pycryptodome pycrypto 这两个库是同一个库,但是 pycrypto 已经不维护了
pycrypto 这个库其实也能用,也是需要更改库名为大写,不知道为什么作者这么搞,非要更改一下库名,不更改的话,你会发现库里面的引用都是问题