自动运维化工具Ansible使用详解(上)

Posted DevOps技术栈

tags:

篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了自动运维化工具Ansible使用详解(上)相关的知识,希望对你有一定的参考价值。


来源:

http://weiweidefeng.blog.51cto.com/1957995/1895261


Ansible 是什么 ?

自动运维化工具Ansible使用详解(上)

ansible架构图

自动运维化工具Ansible使用详解(上)

ansible特性 

模块化:调用特定的模块,完成特定的任务;

基于Python语言研发,由Paramiko, PyYAML和Jinja2三个核心库实现;

部署简单:agentless;

支持自定义模块,使用任意编程语言;

强大的playbook机制;

幂等性;

安装及程序环境:

程序:

ansible

ansible-playbook

ansible-doc

配置文件:

/etc/ansible/ansible.cfg

主机清单:

/etc/ansible/hosts

插件目录:

/usr/share/ansible_plugins/

安装ansible

自动运维化工具Ansible使用详解(上)

安装依赖包

自动运维化工具Ansible使用详解(上)

ansible命令的使用:

Usage: ansible <host-pattern> [options]

常用选项:

-m MOD_NAME

-a MOD_ARGS

配置Host Inventory:

/etc/ansible/hosts

[group_id]

HOST_PATTERN1

HOST_PATTERN2

示例:

首先对此文件进行备份操作,以防后面需要用到默认配置文件

自动运维化工具Ansible使用详解(上)

进入到/etc/ansible/hosts文件,此处绿色光标以下的内容是没有用的,都是示例,可以删除掉,然后添加我们下面实验操作用到的主机。

自动运维化工具Ansible使用详解(上)

添加一组websrvs服务器,以用于下面的测试

自动运维化工具Ansible使用详解(上)

测试主机连通性

这里报错是因为实验用的主机交换其他两台主机的公钥/私钥的原因导致的

自动运维化工具Ansible使用详解(上)

实验SSH免密码登陆设置

生成私钥和公钥 ssh-keygen -t rsa -P ''

自动运维化工具Ansible使用详解(上)

复制公钥文件问authorized_keys

自动运维化工具Ansible使用详解(上)

把公钥传送到其他主机

自动运维化工具Ansible使用详解(上)

在68的主机上面可以看见公钥已经传送过来了,并且确认文件的权限是否正确

自动运维化工具Ansible使用详解(上)

重复以上操作把公钥发送给69的主机

自动运维化工具Ansible使用详解(上)

然后重新执行ansible的ping模块命令查看该两台主机的连通性

可以发现此时已经成功,那么下面就开始介绍ansilbe的其他模块

自动运维化工具Ansible使用详解(上)

最后记得利用ansible同步一下所有主机的时间,以免某主机的时间有错误,后面看日志起来会造成混乱

自动运维化工具Ansible使用详解(上)

ansible模块:

获取模块列表:ansible-doc -l

获取指定模块的使用帮助:ansible-doc -s MOD_NAME

常用模块:

ping模块:探测目标主机是否存活;

自动运维化工具Ansible使用详解(上)

示例:测试所有的主机的连通性

自动运维化工具Ansible使用详解(上)

command模块:在远程主机执行命令;

自动运维化工具Ansible使用详解(上)

示例1:让所有主机同步时间

此处没有给出指定的-m command命令,是因为ansible的模块默认就是command

自动运维化工具Ansible使用详解(上)

示例2:让每一台主机都执行uname -r命令

自动运维化工具Ansible使用详解(上)示例3:在主机上面都创建一个用户

自动运维化工具Ansible使用详解(上)

查看两台主机是否已经创建该用户

自动运维化工具Ansible使用详解(上)

自动运维化工具Ansible使用详解(上)

自动运维化工具Ansible使用详解(上)查看用户信息:

自动运维化工具Ansible使用详解(上)

帮这两个用户改密码,此处需要注意的是,虽然用下面的命令看似执行成功,但是当我们验证的时候,就会发现密码错误了,这是因为ansible的command模块并不支持管道等输出,所以下面介绍另外一个ansible的模块shell

自动运维化工具Ansible使用详解(上)

自动运维化工具Ansible使用详解(上)

shell模块 :在远程主机上调用shell解释器运行命令,支持shell的各种功能,例如管道等

注意:command和shell模块的核心参数直接为命令本身;而其它模块的参数通常为“key=value”格式;

自动运维化工具Ansible使用详解(上)

示例:批量修改其他主机的特定用户的密码

自动运维化工具Ansible使用详解(上)

此时可以发现已经可以登陆成功

自动运维化工具Ansible使用详解(上)

copy模块:复制文件到远程主机

用法:

(1) 复制文件

-a "src='#'"  "

(2) 给定内容生成文件

-a "content=  dest=  "

其它参数:mode, owner, group, ...

自动运维化工具Ansible使用详解(上)

示例:复制文件到其他主机

此处创建一个测试文件

自动运维化工具Ansible使用详解(上)

复制文件到其他主机

下面红色的报错信息是,如果要传送文件,该主机的指定目录需要存在,如果不存在,就是提示错误

自动运维化工具Ansible使用详解(上)

创建对应的目录

自动运维化工具Ansible使用详解(上)

重新传送文件,已经没有错误提示,但是此处也可以看见,如果文件已经存在,则原文件会被覆盖掉,并且此处也没有任何提示覆盖文件的信息,所以操作的时候就需要注意了,以免覆盖掉重要的文件

自动运维化工具Ansible使用详解(上)

验证文件

自动运维化工具Ansible使用详解(上)

file模块:设置文件的属性

用法:

(1) 创建目录:

-a "path=  state=directory"

(2) 创建链接文件:

-a "path=  src='#'" /p>

(3) 删除文件:

-a "path=  state=absent“

自动运维化工具Ansible使用详解(上)

示例:修改文件的权限和属主

自动运维化工具Ansible使用详解(上)

验证文件

自动运维化工具Ansible使用详解(上)

示例:创建文件的软连接

自动运维化工具Ansible使用详解(上)

验证文件

自动运维化工具Ansible使用详解(上)

设置文件的状态为absent(即删除文件)

自动运维化工具Ansible使用详解(上)

验证

自动运维化工具Ansible使用详解(上)

fetch模块:从远程主机拿文件

自动运维化工具Ansible使用详解(上)

示例:从10.1.156.69主机拿一个文件

自动运维化工具Ansible使用详解(上)

自动运维化工具Ansible使用详解(上)

cron模块 :管理计划任务条目

用法:

-a ""

minute=

hour=

day=

month=

weekday=

job=

name=

user=

state={present|absent}

自动运维化工具Ansible使用详解(上)

示例:创建一个同步时间的计划任务,每5分钟同步一下服务器的时间

自动运维化工具Ansible使用详解(上)

验证任务

自动运维化工具Ansible使用详解(上)

示例:删除计划任务

自动运维化工具Ansible使用详解(上)

验证

自动运维化工具Ansible使用详解(上)

hostname模块:管理主机名

用法:

name=

自动运维化工具Ansible使用详解(上)

示例:修改主机名

自动运维化工具Ansible使用详解(上)

自动运维化工具Ansible使用详解(上)

yum模块:使用yum命令完成程序包管理

用法:

-a ""

(1) name=  state={present|latest}

(2) name=  state=absent

自动运维化工具Ansible使用详解(上)

示例:安装指定包

此实验,首先,确定主机的yum源是可用的,否则实验会失败

自动运维化工具Ansible使用详解(上)

安装samba包

自动运维化工具Ansible使用详解(上)

验证

自动运维化工具Ansible使用详解(上)

删除samba安装包

自动运维化工具Ansible使用详解(上)

已经没有安装的字眼了

自动运维化工具Ansible使用详解(上)

service模块:服务管理

用法:

-a ""

name=

state=

started

stopped

restarted

enabled=

runlevel=

自动运维化工具Ansible使用详解(上)

示例:开启主机的httpd服务

首先我们确认httpd服务是关闭的

自动运维化工具Ansible使用详解(上)

开启httpd服务,并且设置为开机启动

自动运维化工具Ansible使用详解(上)

验证,80端口已经开启

自动运维化工具Ansible使用详解(上)

group模块:增加或删除组

用法:

-a ""

name=

state=

system=

gid=

自动运维化工具Ansible使用详解(上)

示例:添加一个组

自动运维化工具Ansible使用详解(上)

验证

自动运维化工具Ansible使用详解(上)

删除组

自动运维化工具Ansible使用详解(上)

自动运维化工具Ansible使用详解(上)

验证

自动运维化工具Ansible使用详解(上)

user模块:用户管理

使用格式:

name= : 创建的用户名

state= : present新增,absent删除

force= : 删除用户的时候删除家目录

system= : 创建系统用户

uid= : 指定UID

shell= : 指定shell

home= : 指定用户家目录

自动运维化工具Ansible使用详解(上)

示例:增加一个系统用户

自动运维化工具Ansible使用详解(上)

验证

自动运维化工具Ansible使用详解(上)

删除用户

自动运维化工具Ansible使用详解(上)

setup模块:收集主机里面的各种信息

自动运维化工具Ansible使用详解(上)

示例:收集所有主机的信息

自动运维化工具Ansible使用详解(上)

下一章ansible-playbook使用详解。

自动运维化工具Ansible使用详解(上)

如果您觉得不错,请别忘了转发、分享、点赞让更多的人去学习, 您的举手之劳,就是对小编最好的支持,非常感谢!


自动运维化工具Ansible使用详解(上) 小编有话说


世上没有绝望的处境,只有对处境绝望的人。


自动运维化工具Ansible使用详解(上) 自动运维化工具Ansible使用详解(上) 自动运维化工具Ansible使用详解(上) 自动运维化工具Ansible使用详解(上) 自动运维化工具Ansible使用详解(上) 自动运维化工具Ansible使用详解(上) 自动运维化工具Ansible使用详解(上) 自动运维化工具Ansible使用详解(上)

自动运维化工具Ansible使用详解(上) 自动运维化工具Ansible使用详解(上) 自动运维化工具Ansible使用详解(上) 自动运维化工具Ansible使用详解(上) 自动运维化工具Ansible使用详解(上) 自动运维化工具Ansible使用详解(上) 自动运维化工具Ansible使用详解(上) 



以上是关于自动运维化工具Ansible使用详解(上)的主要内容,如果未能解决你的问题,请参考以下文章

Linux轻量级自动运维化工具Ansible解析

243张图片为你解析Linux轻量级自动运维化工具Ansible

ansible自动化运维工具使用详解

自动化运维工具——ansible详解案例分享

Ansible自动化运维工具Ansible的基本配置详解

自动化运维工具——ansible详解