Ansible安装及简单使用

简介:

ansible是新出现的自动化运维工具,基于Python开发,集合了众多运维工具(puppet、cfengine、chef、func、fabric)的优点,实现了批量系统配置、批量程序部署、批量运行命令等功能。ansible是基于模块工作的,本身没有批量部署的能力。真正具有批量部署的是ansible所运行的模块,ansible只是提供一种框架。主要包括:

(1)、连接插件connection plugins:负责和被监控端实现通信;

(2)、host inventory:指定操作的主机,是一个配置文件里面定义监控的主机;

(3)、各种模块核心模块、command模块、自定义模块;

(4)、借助于插件完成记录日志邮件等功能;

(5)、playbook:剧本执行多个任务时,非必需可以让节点一次性运行多个任务。

架构:

blob.png

连接其他主机默认使用ssh协议

host inventory:主机组名称

安装ansible:

[root@stu ~]# yum install ansible-1.5.4-1.el6.noarch.rpm

查看生成的文件:

/etc/ansible
/etc/ansible/ansible.cfg   #配置文件
/etc/ansible/hosts   #主机库(host inventory)
/usr/bin/ansible   #主程序
/usr/bin/ansible-doc   #文档
/usr/bin/ansible-playbook   #剧本

命令:

ansible <host-pattern> [-f forks] [-m module_name] [-a args]

    host-pattern:host inventory文件的一个组名,可以为all

    -f forks:并行处理的个数,默认为5

    -m module_name:模块名,默认为command

    -a args:参数

ansible-doc:

    -l:查看模块列表

    -s:查看相关模块参数

实验:

一台控制节点(安装ansible),三台被控制节点

控制节点:

1、名称解析
[root@stu ~]# vim /etc/hosts
127.0.0.1   localhost localhost.localdomain localhost4 localhost4.localdomain4
::1         localhost localhost.localdomain localhost6 localhost6.localdomain6
192.168.0.20 stu
192.168.0.21 node1
192.168.0.22 node2
192.168.0.23 node3
2、建立互信
[root@stu ~]# ssh-keygen -t rsa  -P ''
Generating public/private rsa key pair.
Enter file in which to save the key (/root/.ssh/id_rsa): 
Created directory '/root/.ssh'.
Your identification has been saved in /root/.ssh/id_rsa.
Your public key has been saved in /root/.ssh/id_rsa.pub.
The key fingerprint is:
5e:b9:38:77:4f:d9:e9:ae:94:cd:29:4b:c5:0f:1a:2b root@stu
The key's randomart image is:
+--[ RSA 2048]----+
|                 |
|                 |
|                 |
|           .  .  |
|        S o . .o |
|       . o . +=++|
|        + E +=o=o|
|         o ooo+  |
|             o+o |
+-----------------+
[root@stu ~]# ssh-copy-id -i .ssh/id_rsa.pub root@node1
[root@stu ~]# ssh-copy-id -i .ssh/id_rsa.pub root@node2
[root@stu ~]# ssh-copy-id -i .ssh/id_rsa.pub root@node3
3、定义主机组
[root@stu ~]# vim /etc/ansible/hosts
:.,$s/^\([^[:space:]#]\)/#\1/g   #所有以非空白字符或#开头的行都加上注释
[webservers]
node1
node2
[dbservers]
node2
node3

ping测试:

blob.png

date测试:

blob.png

copy测试:(可以使用ansible-doc -s copy查看)

[root@stu ~]# ls
anaconda-ks.cfg  ansible-1.5.4-1.el6.noarch.rpm  install.log  install.log.syslog
[root@stu ~]# ansible dbservers -m copy -a "src=/root/ansible-1.5.4-1.el6.noarch.rpm dest=/tmp/"

blob.png

检查:

blob.png

cron测试:

[root@stu ~]# ansible all -m cron -a 'name="custom job" minute=*/3 hour=* day=* month=* weekday=* job="/usr/sbin/ntpdate 192.168.0.20"'

blob.png

检查:

blob.png

group测试:

blob.png

检查:

blob.png

yum测试:

[root@stu ~]# ansible all -m yum -a "state=present name=corosync"

检查:

blob.png

service测试:

blob.png

blob.png

blob.png

blob.png

剧本:

剧本需要依赖yaml语言来工作,后缀一般为.yaml。

其结构(Structure)通过空格来展示,序列(Sequence)里的项用"-"来代表,Map里的键值对用":"分隔。下面是一个示例。

实验1:

[root@stu ~]# vim test.yaml
- hosts: all
  remote_user: root
  tasks:
   - name: add a group
     group: gid=1000 name=testgroup system=no
   - name: excute a command
     command: /bin/date

blob.png

是把一个任务在所有主机都执行一遍,再执行第二个任务

handler:适用于更改配置文件后,让其生效

实验2:

[root@stu ~]# cp /etc/httpd/conf/httpd.conf ./
[root@stu ~]# vim httpd.conf
Listen 8080
[root@stu ~]# vim web.yaml
- hosts: all
  remote_user: root
  tasks:
   - name: ensure apache is the latest version
     yum: state=latest name=httpd
   - name: apache configure file
     copy: src=/root/httpd.conf dest=/etc/httpd/conf/httpd.conf force=yes
     notify:
      - restart httpd   #此处和下面的要一样
  handlers:
   - name: restart httpd
     service: name=httpd state=restarted

blob.png

验证8080:(不支持管道)

blob.png

blob.png

其他知识:

找rpm可以在以下两个位置:

http://rpmfind.net/

https://pkgs.org/



原创文章,作者:黑白子,如若转载,请注明出处:http://www.178linux.com/30693

(0)
黑白子黑白子
上一篇 2016-08-07 22:15
下一篇 2016-08-08 09:22

相关推荐

  • Week 1–Linux基础1

    一. 计算机是由什么组成的? 计算机有什么作用呢?  1.计算机是由硬件系统与软件系统两大部分组成的. 那么是什么呢?  硬件系统: 1.1 输入组件(如鼠标,键盘等); 输出组件(显示器,打印机等); 1.2 核心大脑–CPU(里面包含有 算术逻辑、控制、记忆等单元); 1.3 为了与以上2大重要部件连接的,肯定需要一个可以…

    Linux干货 2016-12-05
  • Shell脚本、特殊变量、declare、算术运算、退出状态、条件测试、括号区别

    Shell脚本、特殊变量、declare、算术运算、退出状态、条件测试、括号区别 Shell脚本基础(一) 练习

    Linux干货 2016-08-15
  • Linux系统shell脚本

                                          &n…

    系统运维 2016-09-01
  • 周期性计划任务crond讲解

    crond是Linux或者unix系统的作业调度程序。运用它,在设定的时间段周期性执行某个命令或脚本。下文的例子均在centos 7.3上测试。一、crond组件 如果centos7.3最小化安装,不一定存在crond服务,需要手动安装,安装之后手动启动并设置以后自行开机启动。 主要有cronie、cronie-anacron、crontabs三个程序包。 …

    Linux干货 2017-03-27
  • 详解“FTP文件传输服务”配置实例

            详解“FTP文件传输服务”配置实例 目录 简介 ftp工作原理 常见的FTP服务 Vsftpd服务器的安装 Vsftpd.conf配置文件详解 配置FTP服务器实例 实例:配置匿名 实例:配置本地用户登录 实例:配置虚拟用户登录(MySQL认证) 实例:控制用户登…

    Linux干货 2016-10-18
  • Mysql备份III

    Mysql备份III Mysqldump和mysqldumper A备份和恢复所有库 $ time mysqldumo –all-databases > /mysql/backup/date.time.database.dump.sql $ echo $? $ ls&nbs…

    Linux干货 2016-06-09