ansible源码安装、普通用户实现批量控制
一、ansible简介
ansible是一款自动化运维工具,基于Python开发,集合了众多运维工具(puppet、chef、func、fabric)的优点,实现了批量系统配置、批量程序部署、批量运行命令等功能。 ansible不需要在远程主机上安装client/agents,因为它们是基于ssh来和远
程主机通讯的。
二、ansible 特点
1 部署简单,只需在主控端部署Ansible环境,被控端无需做任何操作;
2 默认使用SSH协议对设备进行管理;
3有大量常规运维操作模块,可实现日常绝大部分操作;
4配置简单、功能强大、扩展性强;
5轻量级,无需在客户端安装agent,更新时,只需在操作机上进行一次更新即可;
三、架构图
环境:
2台centos7
192.168.0.4主
192.168.0.5被控制
在192.168.0.4上
1、配置本地yumyuan
mkdir /etc/yum.repo/1
mv /etc/yum.repo/C* 1
vi /etc/yum.repos.d/yum.repo
[yum.repo]
name=yum.repo
baseurl=file:///mnt/cdrom
gpgcheck=0
enable=1
yum clear all
yum install gcc -y
yum install python-devel -y
yum install unzip -y
查看python版本
python --version
2.7.*
下载包:
下载ansibel的tar包 https://releases.ansible.com/ansible/ansible-2.7.2.tar.gz
下载关联包 https://pypi.org/project/ 加上下面包名
1、setuptools-40.6.2.zip
unzip setuptools-40.6.2.zip
cd setsetuptools-40
python setup.py install
2、pip-18.1.tar.gz
tar xvfz pip-18.1.tar.gz
cd pip-18.1
python setup.py install
3、pycrypto-2.6.1.tar.gz
4、PyYAML-3.11.tar.gz
5、MarkupSafe-0.9.3.tar.gz
6、Jinja2-2.7.3.tar.gz
7、ecdsa-0.11.tar.gz
8、 paramiko-1.15.1.tar.gz
9、simplejson-3.6.5.tar.gz
10、pip install six-1.11.0-py2.py3-none-any.whl
11 pip install ipaddress-1.0.22-py2.py3-none-any.whl
12、pip install asn1crypto-0.24.0-py2.py3-none-any.whl
13、 pip install idna-2.7-py2.py3-none-any.whl
14、pip install enum34-1.1.6-py2-none-any.whl
15、tar xvfz cffi-1.11.5.tar.gz
16、tar xvfz pycparser-2.19.tar.gz
17、pip install cffi-1.11.5-cp27-cp27mu-manylinux1_x86_64.whl
18、pip install cryptography-2.4.2-cp27-cp27mu-manylinux1_x86_64.whl
19、tar xvfz ansible-2.7.2.tar.gz
注意:: 所有的tar包如 第2个一样 所以有的 *.whl 的进行 pip install 包名 进行安装
检查结果: ansible --version
可以看到 ansible的版本2.7
安装完毕。
安装参谋连接 :https://www.jianshu.com/p/8ed33efa0139
实验搭建:
两台centos7
192.168.0.4 主(安装ansible)
192.168.0.5 被监控
1、在所有机器上进行操作
useradd ansible
passwd ansible (密码123456)
sed -i '$a\ansible ALL=(ALL) NOPASSWD: ALL' /etc/sudoers
2、在192.168.0.4上进行操作:
修改ansible管理机/etc/ansible/ansible.cfg文件
deprecation_warnings = Flase
command_warnings = False
将客户端ip加入hosts文件 可进行分组
vim /etc/ansible/hosts
[组名] 自定义分组
IP
3、su - ansible
ssh-keygen -t rsa
ssh-copy-id -i 192.168.0.4
ssh-copy-id -i 192.168.0.5
部署完毕
命令操作:
1、基础命令
ansible ip或组 -m command -a '执行脚本路径下命令'
2、shell 模块
ansible ip -m shell -a "脚本的绝对路径"
*** ansible ip -m shell -a "支持管道命令"
3、copy 模块
ansible ip -m copy -a "src=来源目录/文件 dest=目标路径 owner=属主 group=属组 mode=0755 权限"
默认权限644 如果目标路径不存在 自动创建
4、cron 模块
ansible ip -m cron -a "name=任务名字随意 job='任务' 时间例如 weekday=5"
***** "name=名字 state=absent" 取消任务
minute分钟 可以写成 mintue='1-10' '1,5,6'
hour 小时 每隔2小时 hour=*/2
day 日期
month 月份
5、service 模块 yum 模块
ansible ip -m yum -a "name=包名(必须精准包名)" 安装包
ansible ip -m service -a "name=服务 state=started/stopped enabled=yes/no"
******** 所有命令后面加上 --sudo 执行的root权限
例如: ansible all -m shell -a "/home/ansible/ip.sh" --sudo
ansible源码安装、普通用户实现批量控制的更多相关文章
- ansible源码安装
一.升级python 笔者系统为centos6.5,系统默认安装python2.6,虽然ansible官方文档要求python版本为2.6或2.7,然而许多人都说使用2.6可能出现一系列问题,所以作者 ...
- 源码安装Ansible
一.Ansible介绍 ansible是一款的自动化运维工具,基于Python开发,集合了众多运维工具(puppet.cfengine.chef.func.fabric)的优点,实现了批量系统配置.批 ...
- Linux 源码安装Ansible 参考篇
Ansible 源码搭建配置 近期在学习自动化运维相关技术,文章主要模拟内网情况下对Ansible的安装演示,源码安装较为繁琐.枯燥,尤其是在实际安装过程中可能出现各式各样的问题,所有在安装过程中尽量 ...
- CentOS下源码安装vsftpd-3.0.0,并设置指定用户访问指定目录(附带完整配置文件)
1.卸载系统已经存在的ftp服务器 因为是源码安装,所以不能通过rpm -qa的方式查看是否已经安装ftp服务器,可以通过find / | grep vsftp*方式查看系统中存在哪些与vsftpd相 ...
- ansible源码解读
Ansible源码获取 Ansible Github:https://github.com/ansible Ansible目录结构 $ tree -L 2 ansible-2.0.0.0 ansibl ...
- 搭建LNAMP环境(七)- PHP7源码安装Memcached和Memcache拓展
上一篇:搭建LNAMP环境(六)- PHP7源码安装MongoDB和MongoDB拓展 一.安装Memcached 1.yum安装libevent事件触发管理器 yum -y install libe ...
- 搭建LNAMP环境(二)- 源码安装Nginx1.10
上一篇:搭建LNAMP环境(一)- 源码安装MySQL5.6 1.yum安装编译nginx需要的包 yum -y install pcre pcre-devel zlib zlib-devel ope ...
- 搭建LNAMP环境(一)- 源码安装MySQL5.6
1.yum安装编译mysql需要的包 yum -y install gcc-c++ make cmake bison-devel ncurses-devel perl 2.为mysql创建一个新的用户 ...
- Greenplum 源码安装教程 —— 以 CentOS 平台为例
Greenplum 源码安装教程 作者:Arthur_Qin 禾众 Greenplum 主体以及orca ( 新一代优化器 ) 的代码以可以从 Github 上下载.如果不打算查看代码,想下载编译好的 ...
随机推荐
- 利用AXI VDMA实现OV5640摄像头采集笔记(二)
导读:摄像头采样图像数据后经过VDMA进入DDR,通过PS部分控制,经过三级缓存,将DDR中保持的图形数据通过VDMA发送出去.在FPGA的接收端口产生VID OUT时序驱动HDMI显示器显示图形. ...
- iOS:探究视图控制器的转场动画
一.介绍 在iOS开发中,转场动画的使用无处不见,不只是我们自己更多的使用UIViewblock动画实现一个转场动画,其实,在我们实现VC控制器跳转的时候都是转场动画的实现,例如标签栏控制器的切换.模 ...
- elasticsearch操作命令
总结几个es的curl操作命令: 查询某条数据:curl -XGET http://elasticsearch:9200/company/company/123?pretty 查询索引下数据总量:cu ...
- 大数据之路week01--自学之集合_2(列表迭代器 ListIterator)
列表迭代器: ListIterator listerator():List集合特有的迭代器 该迭代器继承了Iterator迭代器,所以,就可以直接使用hasNext()和next()方法 特有功能: ...
- jdbc 加载数据库驱动如何破坏双亲委托模式
导读 通过jdbc链接数据库,是每个学习Java web 方向的人必然一开始会写的代码,虽然现在各路框架都帮大家封装好了jdbc,但是研究一下jdbc链接的套路还是很意义 术语以及相 ...
- css3关于body的默认滑动机制
css关于body的默认滑动机制 大家都知道 body里面只要高度超出了原来的高度就可以滚动要取消这个机制 只能设置height:100% overflow:hidden就能取消了
- 小程序的基本概念-生命周期(组件 wxml)
一.组件生命周期:一个组件从创建开始到使用中最后被销毁的过程 ---onLoad事件:组件(创建成功并且加载完成)触发一次 (1)当此事件触发发送请求获取数据 (2)获取其他组件传递数据(option ...
- ARP协议字段解读
Hardware type : 硬件类型,识别链路层协议 Protocol type : 协议类型,标识网络层协议 Hardware size : 硬件地址大小,标识MAC地址长度,这里是6个字节(4 ...
- Linux中文件的SUID、SGID、Sticky权限说明
1.SUID 首先我们要了解,在Linux中启动一个程序或者启动一个进程是需要有用户的,一个文件的存在是要有用户和组的,一个进程启动后,它的属主取决于进程的发起者,比如 我用root用户启动了一个 c ...
- 2019CSP游记
\(CSP2019\)游记 写在前面 考完,终于深刻地认识到省一似乎和我想象的真不是一个难度.也罢,不然为什么\(NOIP\)改了名还是这么有含金量. 考前一天和一群同学们嚷嚷着要去吃散伙饭,说没拿到 ...