批量管理工具:pssh/ansible
ssh 免密码 批量管理
1.创建用户
useradd user1
echo “123456”| passwd --stdin user1
2.创建秘钥
ssh-keygen -t dsa
然后一直回车
非交互式(批量)创建秘钥

3.上传公钥(其他服务器也需要有同样用户)
ssh-cppy-id -i ~/.ssh/id_dsa.pub user1@IP
如果端口改变的话

4.可以直接写脚本执行(非交互式)
例:直接在后面加命令

5.ssh 常用选项用法
-l 指定登入用户
-p 设置端口号(scp时需要大写P)
-f 后台运行,并推荐加上 -n 参数
-n 将标准输入重定向到 /dev/null,防止读取标准输入
-t 在终端执行
5.sudu用法:在sudo组中或在/etc/sudoers 下修改 给用户授权
远程sudo需要 ssh 加 -t


expect实现非交互式批量管理
例:批量分发公钥
vim scrip.exp

如果还需要执行后续命令
则加上


然后循环调用此脚本进行批量

ansible
CI(持续集成):为了每个项目组程序员开发的功能或模块能够兼容需要不断的把已经开发好的功能集成到系统中进行测试
CD(持续交付):测试没问题不断快速发到预发布系统中能让客户获取新版本
CD(持续部署):把交付的结果放到线上,这个过程能够脚本自动执行和快速敏捷实现
DevOps:以上三个过程能够全部自动进行
AIOps:人工智能运维(智能化运维)
2.以上可以分为三步:系统安装、系统配置、系统部署。ansible可以完成配置和部署
3.ansible命令行:
-a:传输模块参数
-m:调用得模块
-C:模拟测试
-f:并发量
-i:指定主机清单文件(默认/etc/ansible/hosts)
–list-hosts:列出可匹配的主机列表
-t:指定日志
-c:指定链接方式
-u:指定链接的用户
-s:sudo
4.免秘钥登录
ssh-keygen -t rsa -P " "
ssh-copy-id -i ~/.ssh/id_rsa.pub root@172.16.0.67
5.定义目标主机在/etc/ansible/hosts中
[] 可以设置每个主机组

例
fales 表示没改变目标主机配置
6.查看可用模块

-a 获取文档
-l 列出可用模块
-s 查看模块中可用的参数

1、ssh-keygen -t rsa 生成公钥和私钥 -t 指定类型,此时会在/root/.ssh/下生成公钥和私钥的文件
2、ssh-copy-id -i /root/,ssh/id_rsa.pub root@192.168.111.138 将公钥文件拷贝到另一台服务器,-i 指定组文件
3、此时会在另外一台服务器上生成auth文件。完成!
最小化安装没有ssh-copy-id解决办法,yum install -y openssl-clients
pssh实例
pssh是一个可以在多台服务器上执行命令的工具,同时支持拷贝文件,是同类工具中很出色的。使用时必须在各个服务器上配置好秘钥认证访问
安装方法
1、wget http://www.theether.org/pssh/pssh-1.4.3.tar.gz
2、解压,进入目录。python setup.py install
如果提示没有setiptools模块,解决办法:
pssh -i -h list.txt ‘df -h’
ansible详解、
ansible和saltstack都是管理工具,ansible只需要在一台普通服务器上运行即可,不需要在被管控的服务器上安装客户端,因为它是基于SSH的,所以ansible不需要配置额外的支持,运行ansible的服务器称为‘管理节点’,通过ansible进行管理的服务器成为“受控节点”
优点:
1、轻量级,更新时,只需要在一台服务器上进行一次更新即可
2、采用SSH协议
3、不需要去客户端执行agent
4、批量执行可以写成脚本,不用分发到远程就就可以执行
5:、使用python编写,维护更简单
6、支持sudo普通用户命令
安装方法
ansible能够安装到linux、bsd、mac等平台,python的最低版本要求为2.6
centos使用yum安装,安装之前先安装perl源码 rpm -Uvh http://mirrors.ustc.edu.cn/fedora/epel/6/x86_64/epel-release-6-8.noarch.rpm
yum install ansible -y
使用方法
cd /'etcansible; hosts文件为配置。可以添加分组
-u username 指定ssh链接的用户名,即执行后面命令的用户
-i inventory_fie 指定使用的配置文件,默认为hosts
-m module 指定使用的模块,默认为command
-f 指定并发数
-a 指定模块的参数
--sudo [-k] 当需要root权限执行的话,-k参数用来输入root密码
常见的模块有comman、shell、script、yum、copy、file、async、docker、cron、mysql_user、ping、sysctl、user等
1、ansible 192.168.111.* -m command -a 'df -h'
2、 ansible all -m cpoy -a 'src=/etc/passwd dest=/tmp mode=755 owner=root'
3、ansible all -m yum -a "name=screen state=installed"
4、ansible all -m file -a "path=/tmp/`date +5F` state=directory mode=755"
5、ansible all -m file -a "path=/tmp/123.txt state=touch mode=644"
6、ansibkle all -m user -a "name=user1 home=/home/user1"
7、ansible all -m cron -a "minute=0 hour=0 day=* month=* weekday=* name='工作内容' job='/usr/sbin/ntpdate pool.ntp.org'"
批量管理工具:pssh/ansible的更多相关文章
- Linux下批量管理工具pssh安装和使用
Linux下批量管理工具pssh安装和使用 pssh工具包 安装:yum -y install pssh pssh:在多个主机上并行地运行命令 pscp:把文件并行地复制到多个主机上 prsync:通 ...
- 轻量级批量管理工具pssh
pssh工具 pssh工具是个轻量级的批量管理工具,相比同类型的开源工具 Ansible,Saltstack,他比较轻量级,需要对管理的主机做秘钥认证 Ansible是可以做秘钥认证,也可以通过配置文 ...
- 自动化批量管理工具pssh - 运维小结
pssh提供OpenSSH和相关工具的并行版本.包括pssh,pscp,prsync,pnuke和pslurp.该项目包括psshlib,可以在自定义应用程序中使用.pssh是python写的可以并发 ...
- Linux下批量管理工具pssh使用记录
pssh是一款开源的软件,使用python实现,用于批量ssh操作大批量机器:pssh是一个可以在多台服务器上执行命令的工具,同时支持拷贝文件,是同类工具中很出色的:比起for循环的做法,我更推荐使用 ...
- Linux下批量管理工具PSSH
pssh命令 pssh命令是一个python编写可以在多台服务器上执行命令的工具,同时支持拷贝文件,是同类工具中很出色的,类似pdsh,个人认为相对pdsh更为简便,使用必须在各个服务器上配置好密钥认 ...
- Linux系统——Ansible批量管理工具
批量管理工具: (1)ansible 操作简单(适用于500台以下服务器) (2)saltstack 比较复杂(一般适用于1000-4w台服务器) (3)puppet超级复杂 systemctl(统一 ...
- windows下运行的linux服务器批量管理工具(带UI界面)
产生背景: 由于做服务器运维方面的工作,需要一人对近千台LINUX服务器进行统一集中的管理,如同时批量对LINUX服务器执行相关的指令.同时批量对LINUX服务器upload程序包.同时批量对LINU ...
- Python开发程序:简单主机批量管理工具
题目:简单主机批量管理工具 需求: 主机分组 登录后显示主机分组,选择分组后查看主机列表 可批量执行命令.发送文件,结果实时返回 主机用户名密码可以不同 流程图: 说明: ### 作者介绍: * au ...
- 【Python之旅】第六篇(七):开发简易主机批量管理工具
[Python之旅]第六篇(七):开发简易主机批量管理工具 python 软件开发 Paramiko模块 批量主机管理 摘要: 通过前面对Paramiko模块的学习与使用,以及Python中多线程与多 ...
随机推荐
- centos7 安装 git服务器
服务器端配置 yum install -y git groupadd git useradd git -g git 2.创建authorized_keys cd /home/git mkdir .ss ...
- NFS启动文件系统
NFS启动文件系统 一.软硬件平台 1.开发板:创龙AM3359核心板,网口采用RMII形式. 2.UBOOT版本:U-Boot-2016.05,采用FDT和DM. 3.交换芯片MARVELL的88E ...
- mysql学习之基础篇08 UTF8编码
这次我们来说一下在Mysql中的编码问题: 我们知道应用于计算机的最早的字符集是ASCII,它所组成的编码是ASCII编码:由于对于其他国家来说它所容纳的字符个数比较少,后来就出现了ANSI字符集,它 ...
- unity 之 背包系统
此方法只是用于学习和实验所以细节不必要求 一.Ui设置. 画布配置如下: 布局: 说明: 画布里面首先建立一个panel命名为weapon1,在其内部再建立4个panel用于装备的卡槽,装备以imag ...
- 【转】Rxjs知识整理
原文:https://www.jianshu.com/p/16be96d69143 ---------------------------------------------------------- ...
- 《The One!团队》第八次作业:ALPHA冲刺(五)
项目 内容 作业所属课程 所属课程 作业要求 作业要求 团队名称 < The One !> 作业学习目标 (1)掌握软件测试基础技术.(2)学习迭代式增量软件开发过程(Scrum) 第五天 ...
- 项链与手镯Uva 10294——Polya定理
题意 项链和手镯都是由若干珠子串成的环形首饰,区别在于手环可以翻转,但项链不可以. 输入整数 $n$ 和 $t$,输出用 $t$ 中颜色 $n$ 颗珠子能制作成的项链和手镯的个数.($1\leq n ...
- CodeForces - 55D - Beautiful numbers(数位DP,离散化)
链接: https://vjudge.net/problem/CodeForces-55D 题意: Volodya is an odd boy and his taste is strange as ...
- 计算 byte[] 转 int modebus 指定位数 获取值 使用
计算 byte[] 转 int modebus 指定位数 获取值 使用 if (bytetores.Length > 6) { int total = 0; for (int i = 0; i ...
- windbg调试托管代码 .Net clr
现在很多的程序都是多语言混合编程的,比如我司的产品,就是用C++/.net clr混合编制的.那么当我们调试这样的程序时,一定要注意,比如有时我们只看到c++的栈和名称,而.net clr的代码确看不 ...