目录
1、ansible概述
■ Ansible可以同时管理Redhat系的Linux,Debian 系的Linux,以及Windows主机。管理节点只在执行脚本时与远程主机连接,没有特别的同步机制,所以断电等异常一般不会影响ansbile
■ ansible是新出现的自动化运维工具,基于Python开发,集合了众多运维工具( puppet、cfengine、chef、func、 fabric) 的优点,实现了批量系统配置、批量程序部署、批量运行命令等功能。ansible 是基于模块工作的,本身没有批量部署的能力。真正具有批量部署的是ansible所运行的模块,ansible. 只是提供一种框架
● 连接插件connection plugins:负责和被监控端实现通信
● host inventory:指定操作的主机,是一个配置文件里面定义监控的主机
● 各种模块核心模块、command 模块、自定义模块
● 借助于插件完成记录日志邮件等功能
● playbook: 剧本执行多个任务时,非必需可以让节点一次性运行多个任务
■ ansible的架构:连接其他主机默认使用ssh协议 (端口号22)
2、ansible环境安装部署
管理端ansible:192.168.140.10
被管理端mysql: 192.168.140.20
被管理端webserver: 192.168.140.30
安装步骤
2.1、修改主机名,安装epel源
[root@server1 ~]# hostnamectl set-hostname ansible
[root@server1 ~]# su
[root@server2 ~]# hostnamectl set-hostname mysql
[root@server2 ~]# su
[root@server3 ~]# hostnamectl set-hostname webserver
[root@server3 ~]# su
[root@ansible ~]# wget -O /etc/yum.repos.d/CentOS-Base.repo https://mirrors.aliyun.com/repo/Centos-7.repo #阿里镜像站下载镜像
[root@ansible ~]# yum makecache
[root@ansible ~]# yum install -y epel-release #安装epel源
[root@ansible ~]# yum install -y ansible
[root@ansible ~]# ansible --version #查看ansible版本
[root@ansible ~]# yum -y install tree #安装树状结构展示安装包
[root@ansible ~]# tree /etc/ansible #树状结构展示文件夹
注:
ansible.cfg: ansible的配置文件
hosts:ansible的主仓库,用于存储需要管理的远程主机的相关信息
roles:角色
[root@ansible ~]# cd /etc/ansible/
[root@ansible ~]# vim /etc/ansible/hosts #配置主机清单
[root@ansible ansible]# ssh-keygen -t rsa #生成密钥
[root@ansible ansible]# ssh-copy-id root@192.168.140.20 #配置密钥对验证,免密登录
[root@ansible ansible]# ssh-copy-id root@192.168.140.30 #配置密钥对验证,免密登录
[root@ansible ansible]# ssh-agent bash #免交互代理
[root@ansible ansible]# ssh-add
2.1.1、切换到被管理点查看效果
[root@mysql ~]# ls -a
[root@mysql ~]# cd .ssh/
[root@mysql .ssh]# ls -lh
[root@mysql .ssh]# cat authorized_keys
2.2、ansible命令行常用模块
2.2.1、主机连通性测试
[root@ansible ~]# ansible all -m ping
2.2.2、command模块
2.2.2.1、查看时间和根目录下的信息
[root@ansible ansible]# ansible mysql -a 'date' #查看mysql节点的时间
[root@ansible ansible]# ansible all -a 'date' #查看所有节点的时间