工作专题

自动化运维工具Ansible使用介绍

2017-03-21  本文已影响2439人  qiuyi943

本文主要内容均收集于网络上的博文资料,仅以此文作为学习总结。BTW,目前Ansible对python3的支持还不是很完备。

一、基础介绍

1、 简介

ansible是新出现的自动化运维工具,基于Python开发,集合了众多运维工具(puppet、cfengine、chef、func、fabric)的优点,实现了批量系统配置、批量程序部署、批量运行命令等功能。ansible是基于模块工作的,本身没有批量部署的能力。真正具有批量部署的是ansible所运行的模块,ansible只是提供一种框架。主要包括:
(1)、连接插件connection plugins:负责和被监控端实现通信;
(2)、host inventory:指定操作的主机,是一个配置文件里面定义监控的主机;
(3)、各种模块核心模块、command模块、自定义模块;
(4)、借助于插件完成记录日志邮件等功能;
(5)、playbook:剧本执行多个任务时,非必需可以让节点一次性运行多个任务。

2、总体架构

总体架构

3、特性

(1)、no agents:不需要在被管控主机上安装任何客户端;
(2)、no server:无服务器端,使用时直接运行命令即可;
(3)、modules in any languages:基于模块工作,可使用任意语言开发模块;
(4)、yaml,not code:使用yaml语言定制剧本playbook;
(5)、ssh by default:基于SSH工作;
(6)、strong multi-tier solution:可实现多级指挥。

4、优点

(1)、轻量级,无需在客户端安装agent,更新时,只需在操作机上进行一次更新即可;
(2)、批量任务执行可以写成脚本,而且不用分发到远程就可以执行;
(3)、使用python编写,维护更简单,ruby语法过于复杂;
(4)、支持sudo。

5、任务执行流程

任务执行流程

二、安装Ansible

$ git clone https://github.com/ansible/ansible.git --recursive
$ cd ./ansible
$ source ./hacking/env-setup
$ sudo easy_install pip

以下的Python模块也需要安装:

$ sudo pip install paramiko PyYAML Jinja2 httplib2 six pycrypto

如果安装paramiko 的时候系统报openssl相关的错误,那么需要再安装以下文件:

$ sudo apt-get install -y libffi-dev libssl-dev python-dev

当更新ansible版本时,不只要更新git的源码树,也要更新git中指向Ansible自身模块的 “submodules” (不是同一种模块):

$ git pull --rebase
$ git submodule update --init --recursive

三、Ansible 配置

1、SSH免密钥登录设置

# ssh-keygen -t rsa -P ''
# cat /root/.ssh/id_rsa.pub >> /root/.ssh/authorized_keys
# chmod 600 /root/.ssh/authorized_keys

如果需要配置公钥的服务器数量比较多的话,也可以通过使用ansible中的authorize_key模块来进行分布式部署。

2、Ansible配置

Ansible使用前通常需要配置/etc/anisble/路径下的hosts和ansible.cfg这个两个文件。要注意的是,编辑这两个文件需要root权限。

# mkdir -p /etc/ansible`
# vim /etc/ansible/ansible.cfg`
……
remote_port = 36000
private_key_file = /root/.ssh/id_rsa
……

Ansible 可同时操作属于一个组的多台主机,组和主机之间的关系通过 inventory 文件(INI 格式)配置,默认的文件路径为 /etc/ansible/hosts。一个系统可以属于不同的组,比如一台服务器可以同时属于 webserver组 和 dbserver组。

# vim /etc/ansible/hosts
[test]
10.139.13.80

/etc/ansible/hosts是配置分组的默认文件,还有一种方式可以通过定义环境变量ANSIBLE_HOSTS来改变配置文件的引用路径:

export ANSIBLE_HOSTS=~/test/qiuyi_ansible/test_hosts

四、Ansible ad-hoc命令

Ansible提供两种方式去完成任务,一种是 ad-hoc 命令,另一种写 Ansible playbook。前者可以解决一些简单的任务,后者解决较复杂的任务。ad-hoc只能做些一些轻量级的指令操作,而配置管理或部署这种事还是要借助 playbook 来完成,即使用 ‘/usr/bin/ansible-playbook’ 这个命令。

ad-hoc的命令格式:

ansible <host-pattern> [options]

ansible有许多模块,默认是 ‘command’,也就是命令模块,我们可以通过 -m 选项来指定不同的模块。

常用模块:

1. setup:用来查看远程主机的一些基本信息

2. ping:用来测试远程主机的运行状态

3. file:设置文件属性

相关选项如下:

示例

# ansible test -m file -a "src=/etc/resolv.conf dest=/tmp/resolv.conf state=link"
# ansible test -m command -a "ls –al /tmp/resolv.conf"
# ansible test -m file -a "path=/tmp/resolv.conf state=absent"
# ansible test -m command -a "ls -al /tmp/resolv.conf"

4. copy:复制文件到远程主机

相关选项如下:

示例:

# ansible test -m copy -a "src=/etc/ansible/ansible.cfg dest=/tmp/ansible.cfg owner=root group=root mode=0644"
# ansible test -m command -a "ls -al /tmp/ansible.cfg"

5. command:在远程主机上执行命令

相关选项如下:

示例:

$ ansible test -m command  -a "chdir=~/qiuyi_test creates=~/qiuyi_test/1.txt ls"
10.139.13.80 | skipped
$ ansible test -m command  -a "chdir=~/qiuyi_test creates=~/qiuyi_test/2.txt ls"
10.139.13.80 | success | rc=0 >>
1.txt
qiuyi.sh
ssh

注意,creates选项并不会创建文件。

6. shell:切换到某个shell执行指定的指令,参数与command相同

与command不同的是,此模块可以支持命令管道,同时还有另一个模块也具备此功能:raw

示例:

# ansible raleigh -m shell -a "echo $TERM"

使用 Ansible ad-hoc 命令行接口时(与使用 Playbooks 的情况相反),尤其注意 shell 引号的规则. 比如在上面的例子中,如果使用双引号”echo $TERM”,会求出TERM变量在当前系统的值,而我们实际希望的是把这个命令传递 到其它机器执行.

示例:

$ vim /home/user_00/test/qiuyi_ansible/qiuyi_test.sh
#!/bin/sh
date +%F_%H:%M:%S
$ chmod +x /home/user_00/test/qiuyi_ansible/qiuyi_test.sh
$ ansible test -m copy -a "src= /home/user_00/test/qiuyi_ansible/qiuyi_test.sh dest=/home/user_00/qiuyi_test owner=user_00  mode=0755"
$ ansible test -m shell -a "~/qiuyi_test/qiuyi.sh"
10.139.13.80 | success | rc=0 >>
2017-03-22_12:27:18

7. 更多模块

其他常用模块,比如:service、cron、yum、synchronize就不一一例举,可以结合自身的系统环境进行测试。在使用中,如果想查看某个模块的信息,可以使ansible-doc命令。

# ansible-doc –l
add_host             add a host (and alternatively a group) to the ansible-playbo
apt                  Manages apt-packages                                        
apt_repository       Manages apt repositores                                     
assemble             Assembles a configuration file from fragments               
async_status         Obtain status of asynchronous task                          
authorized_key       Adds or removes an SSH authorized key                       
command              Executes a command on a remote node                         
copy                 Copies files to remote locations.                           
cron                 Manage crontab entries.                                     
debug                Print statements during execution                           
easy_install         Installs Python libraries                                   
ec2                  create an instance in ec2, return instanceid                
facter               Runs the discovery program `facter' on the remote system... 
fail                 Fail with custom message                                    
fetch                Fetches a file from remote nodes                            
file                 Sets attributes of files                                    
get_url              Downloads files from HTTP, HTTPS, or FTP to node            
git                  Deploy software (or files) from git checkouts               
group                Add or remove groups                                        
group_by             Create Ansible groups based on facts                        
ini_file             Tweak settings in INI files                                 
lineinfile           Ensure a particular line is in a file                       
mail                 Send an email                                               
mount                Control active and configured mount points                  
mysql_db             Add or remove MySQL databases from a remote host.           
mysql_user           Adds or removes a user from a MySQL database.               
nagios               Perform common tasks in Nagios related to downtime and notif
ohai                 Returns inventory data from `Ohai'                          
pause                Pause playbook execution                                    
ping                 Try to connect to host and return `pong' on success.        
pip                  Manages Python library dependencies.                        
postgresql_db        Add or remove PostgreSQL databases from a remote host.      
postgresql_user      Adds or removes a users (roles) from a PostgreSQL database..
raw                  Executes a low-down and dirty SSH command                   
script               Runs a local script on a remote node                        
seboolean            Toggles SELinux booleans.                                   
selinux              Change policy and state of SELinux                          
service              Manage services.                                            
setup                Gathers facts about remote hosts                            
shell                Execute commands in nodes.                                  
slurp                Slurps a file from remote nodes                             
subversion           Deploys a subversion repository.                            
supervisorctl        Manage the state of a program or group of programs running v
svr4pkg              Manage Solaris SVR4 packages                                
template             Templates a file out to a remote server.                    
user                 Manage user accounts                                        
virt                 Manages virtual machines supported by libvirt               
wait_for             Waits for a given port to become accessible on a server.... 
yum                  Manages packages with the `yum' package manager

五、 Palybooks

1、基础介绍

Playbooks与ad-hoc相比,是一种完全不同的运用 ansible 的方式。
简单来说,playbooks是一种简单的配置管理系统与多机器部署系统的基础。与现有的其他系统有不同之处,且非常适合于复杂应用的部署。Playbooks可用于声明配置,更强大的地方在于,在 playbooks中可以编排有序的执行过程,甚至于做到在多组机器间,来回有序的执行特别指定的步骤。并且可以同步或异步的发起任务。

Playbooks 采用的格式是YAML

---
- hosts: webservers
  vars:
    http_port: 80
    max_clients: 200
  remote_user: root
  tasks:
  - name: ensure apache is at the latest version
    yum: pkg=httpd state=latest
  - name: write the apache config file
    template: src=/srv/httpd.j2 dest=/etc/httpd.conf
    notify:
    - restart apache
  - name: ensure apache is running
    service: name=httpd state=started
  handlers:
    - name: restart apache
      service: name=httpd state=restarted
tasks:
  - name: create a virtual host file for {{ vhost }}
    template: src=somefile.j2 dest=/etc/httpd/conf.d/{{ vhost }}
tasks:
  - name: make sure apache is running
    service: name=httpd state=running
- name: template configuration file
  template: src=template.j2 dest=/etc/foo.conf
  notify:
     - restart memcached
     - restart apache

Handlers 也是一些task的列表,通过名字来引用,它们和一般的 task 并没有什么区别。Handlers是由通知者进行 notify, 如果没有被 notify,handlers 不会执行。不管有多少个通知者进行了 notify,等到 play 中的所有 task 执行完成之后,handlers也只会被执行一次。handlers 会按照声明的顺序执行。

这里是一个 handlers 的示例:

handlers:
    - name: restart memcached
      service:  name=memcached state=restarted
    - name: restart apache
      service: name=apache state=restarted

Handlers 最佳的应用场景是用来重启服务,或者触发系统重启操作。除此以外很少用到了。

以下示例是并行的运行playbook,并行的级别是10:

ansible-playbook playbook.yml -f 10

在执行一个 playbook 之前,想看看这个 playbook 的执行会影响到哪些 hosts,你可以这样做:

ansible-playbook playbook.yml --list-hosts

playbook是由一个或多个“play”组成的列表,可以让它们联同起来按事先编排的机制执行;所谓task无非是调用ansible的一个module,而在模块参数中可以使用变量;模块执行是幂等的,这意味着多次执行是安全的,因为其结果均一致。

幂等(idempotent、idempotence)是一个数学与计算机学概念,常见于抽象代数中。
在编程中,一个幂等操作的特点是其任意多次执行所产生的影响均与一次执行的影响相同。幂等函数,或幂等方法,是指可以使用相同参数重复执行,并能获得相同结果的函数。这些函数不会影响系统状态,也不用担心重复执行会对系统造成改变。

2、Roles和include语句

假如你希望在多个play或者多个playbook中重用同一个task列表,你可以使用include 做到这一点。 当我们希望为系统定义一个角色时,使用include去包含task列表是一种很好用的方法。需要记住的是,一个play所要达成的目标是将一组系统映射为多个角色。

一个 task include file 由一个普通的 task 列表所组成,像这样:

---
# possibly saved as tasks/foo.yml

- name: placeholder foo
  command: /bin/foo

- name: placeholder bar
  command: /bin/bar

Include 指令看起来像下面这样,在一个 playbook 中,Include 指令可以跟普通的 task 混合在一起使用:

tasks:

  - include: tasks/foo.yml

Roles 基于一个已知的文件结构,去自动的加载某些 vars_files,tasks 以及 handlers。基于 roles 对内容进行分组,使得我们可以容易地与其他用户分享 roles 。

一个项目的结构如下:

site.yml
webservers.yml
fooservers.yml
roles/
   common/
     files/
     templates/
     tasks/
     handlers/
     vars/
     defaults/
     meta/
   webservers/
     files/
     templates/
     tasks/
     handlers/
     vars/
     defaults/
     meta/

一个 playbook 如下:

---
- hosts: webservers
  roles:
     - common
     - webservers

这个 playbook 为一个角色 ‘x’ 指定了如下的行为:

3、小结

本节只对Playbooks的基础内容进行了简单的介绍;而余下的如Roles依赖、条件控制、循环操作、异步处理等相关内容可以参考Ansible中文权威指南进行学习,本文将不再深入介绍。

六、参考文献

Reference:
[1] http://www.ansible.com.cn/docs/
[2] http://sofar.blog.51cto.com/353572/1579894
[3] http://baike.baidu.com/item/ansible
上一篇下一篇

猜你喜欢

热点阅读