如何fabric安装

系统知识05

如何fabric安装,第1张

如何fabric安装
导读: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 这个库其实也能用,也是需要更改库名为大写,不知道为什么作者这么搞,非要更改一下库名,不更改的话,你会发现库里面的引用都是问题