TranslateProject/translated/tech/20150930 Install and use Ansible (Automation Tool) in CentOS 7.md
2015-10-01 11:16:55 +08:00

3.6 KiB
Raw Blame History

在CentOS 7中安装并使用Ansible(自动化工具)

Ansible是一款为类Unix系统开发的免费开源配置和自动化工具。它用Python写成并且和Chef和Puppet相似但是有一个不同和好处是我们不需要在节点中安装任何客户端。它使用SSH来和节点进行通信。

本篇中我们将在CentOS 7上安装并配置Ansible并且尝试管理两个节点。

Ansible 服务端 ansible.linuxtechi.com ( 192.168.1.15 )

Nodes 192.168.1.9 , 192.168.1.10

第一步: 设置EPEL仓库

Ansible仓库默认不在yum仓库中因此我们需要使用下面的命令启用epel仓库。

[root@ansible ~]# rpm -iUvh http://dl.fedoraproject.org/pub/epel/7/x86_64/e/epel-release-7-5.noarch.rpm

第二步: 使用yum安装Ansible

[root@ansible ~]# yum install ansible

安装完成后检查ansible版本

[root@ansible ~]# ansible --version

ansible-version

第三步: 设置用于节点鉴权的SSH密钥

在Ansible服务端生成密钥并且复制公钥到节点中。

root@ansible ~]# ssh-keygen

ssh-keygen

使用ssh-copy-id命令来复制Ansible公钥到节点中。

ssh-copy-id-command

第四步为Ansible定义节点的清单

文件 /etc/ansible/hosts 维护了Ansible中服务器的清单。

[root@ansible ~]# vi /etc/ansible/hosts
[test-servers]
192.168.1.9
192.168.1.10

Save and exit the file. 保存并退出文件

主机文件示例。

ansible-host

第五步尝试在Ansible服务端运行命令

使用ping检查test-servers或者ansible节点的连通性。

[root@ansible ~]# ansible -m ping 'test-servers'

ansible-ping

执行shell命令

**例子1检查Ansible节点的运行时间 **

[root@ansible ~]# ansible -m command -a "uptime" 'test-servers'

ansible-uptime

**例子2检查节点的内核版本 **

[root@ansible ~]# ansible -m command -a "uname -r" 'test-servers'

kernel-version-ansible

**例子3给节点增加用户 **

[root@ansible ~]# ansible -m command -a "useradd mark" 'test-servers'
[root@ansible ~]# ansible -m command -a "grep mark /etc/passwd" 'test-servers'

useradd-ansible

例子4重定向输出到文件中

[root@ansible ~]# ansible -m command -a "df -Th" 'test-servers' > /tmp/command-output.txt

redirecting-output-ansible


via: http://www.linuxtechi.com/install-and-use-ansible-in-centos-7/

作者:Pradeep Kumar 译者:geekpi 校对:校对者ID

本文由 LCTT 原创编译,Linux中国 荣誉推出