Ansible快速入门:轻量级自动化部署工具

云计算 自动化
比起来其他自动化集群管理和运维工具 Puppet、Chef、Slat, Ansible 显得很简单并且轻量级, 但是 Ansible 又不像 Fab 那样功能单一只能做批量命令。

自动化部署系统将集群的所有状态保存在几个文件中,即使将集群完全摧毁,通过这些配置文件,可以很快恢复完全一样的集群出来。

这就像将一座城市保存在一个水晶球里。或者钢铁侠的衣服折叠成一个手提箱。

[[145534]]

比起来其他自动化集群管理和运维工具 Puppet、Chef、Slat, Ansible 显得很简单并且轻量级, 但是 Ansible 又不像 Fab 那样功能单一只能做批量命令。

Ansible 比 Fab 增加了对服务器状态的管理功能,这样就能将运维操作状态记录和保存在版本库中。Ansible 尽量少引入 DSL 这样的学习门槛。配置文件只是常见的 YAML 格式 (playbooks)。

同样这样的简单设计的劣势是没有依赖管理功能。但是 Ansible 对于一般的使用场景已经足够了。

可以用来初始化基础设施的服务器集群,用户管理、部署和更新、卸载应用代码,管理配置文件,维护 Web 服务器等等。并且可以用来同时管理多个不同的云服务提供商。

Ansible 的特点

[[145535]]

轻量级

轻量级的好处是学习门槛低、问题少、安装快、执行快。操作完全依赖 SSH 而不需要安装 agent 。这样的好处是不再需要维护 agent 的状态,不用担心 Agent 挂掉。而 SSH 是每台服务器必备的服务。它非常适合安全补丁更新的场景。比如,100 台服务器打 bash vulnerability 安全补丁只需要 10 分钟。

 


支持多个不同的云服务

这样你可以将服务器混合部署在自建 IDC、AWS、DigitalOcean、Linode 上。而且将调试环境放到本机的 Vagrant 的虚拟机中。

这对于测试和调试非常方便。

灰度更新

Ansible 支持对集群的小部分机器批量操作,然后逐步完成整个集群的操作。这对于需要机器重启的场景就非常实用。

现有自动化系统的补充

Ansible 可以补充现有 Salt 和 puppet 系统的不足。比如重启那些运行在每个服务器上的 Agent 。

Ansible 中的概念

任务 Task——多个 Task 顺序执行,在每个 Task 执行结束可以通知 Hanlder 触发新操作。

变量 Variable——用户定义的变量。

环境 Facts——Facts 从每台服务器上收集得到,可以用作变量。

模块——比如 shell、ping、apt 等等

操作 Hanlder

#p#

Ansible 快速入门

安装

 

  1. sudo pip install ansible 

增加服务器资源

修改 /etc/ansible/hosts 添加

 

  1. [web] 
  2. 192.168.1.2 
  3. 192.168.1.3 
  4. 192.168.1.4 

 

PS: 一般将 hosts 文件放到当前文件夹, 需要在命令中指定 hosts 文件位置

 

  1. ansible -u root web -m ping -i ./hosts 

执行下 Helloworld:

  1. ansible all -m ping -u root 

这样的入门教程已经完成了。

Ansible 的手动执行命令版本:

  1. ansible all -m ping -u root 

看其他几个常用的操作,体会一下,通过看命令你就会知道所做的操作,非常简单:

 

  1. ansible -u root web -m copy -a "src=/etc/hosts dest=/tmp/hosts" 
  2. ansible -u root web -m yum -a "name=abcd state=present" 
  3. ansible -u root web -m yum -a "name=abcd state=absent" 
  4. ansible -u root web -m user -a "name=foo password=" 
  5. ansible -u root web -m user -a "name=foo state=absent 
  6. ansible -u root web -m git -a "repo=git://blog.eood.cn/repo.git dest=/srv/myapp version=HEAD" 
  7. ansible -u root web -m service -a "name=nginx state=started" 
  8. ansible -u root web -m service -a "name=nginx state=restarted" 
  9. ansible -u root web -m service -a "name=nginx state=stopped" 

 

一个最简单的 Playbook:

 

  1. --- 
  2. - hosts: blog.eood.cn 
  3.   tasks: 
  4.     - name: Installs nginx web server 
  5.       apt: pkg=nginx state=installed update_cache=true 
  6.       notify: 
  7.         - start nginx 
  8.  
  9.   handlers: 
  10.     - name: start nginx 
  11.       service: name=nginx state=started 

 

保存成 nginx.yml

执行 Playbook:

 

  1. ansible-playbook nginx.yml 

通过添加命令行变量可以 override nginx 中的变量。

***

Ansible 结合 Docker、Mesos、Puppet、Vagrant、Git 等系统可以构建出非常好的自动化运维平台。Ansible 比起其他自动化运维工具更适合对 Docker 实例进行维护和管理。如果你的机器实例数量超过 1000,也可以选择Ansible 的 Web 控制工具 Ansible Tower 。

博文出处:http://blog.eood.cn/the-ansible
 

责任编辑:Ophira 来源: 博客
相关推荐

2021-02-22 18:50:03

Ansible系统运维

2019-10-30 14:47:05

工具代码开发

2014-09-22 11:24:18

运维

2017-03-22 18:30:44

Linux运维自动化ansible

2017-03-22 16:31:30

Linux运维自动化ansible

2022-07-04 09:00:36

Playwright自动化测试工具

2020-05-25 16:00:24

工具代码开发

2018-08-31 09:55:38

Ansible网络自动化

2015-10-08 10:55:23

云服务自动化运维 ANSIBLE

2015-11-09 14:27:36

Ansiblelinux自动化运维

2014-03-11 11:10:10

PowerShell自动化脚本

2022-07-15 16:39:19

PythonWhoosh工具

2016-10-28 08:39:23

WebHook运维工具

2013-07-02 10:45:38

2021-10-14 09:55:28

AnsibleanacronLinux

2022-07-29 14:39:17

Ansible运维工具

2021-03-02 06:32:03

Ansible系统运维

2013-11-27 11:34:43

自动化部署Python

2023-04-06 07:09:25

自动化部署Actions

2022-11-15 17:07:40

开发自动化前端
点赞
收藏

51CTO技术栈公众号