Linux-Ansible学习手杂
Ansible 介绍
Ansible是一个配置管理和配置工具,使用SSH连接到服务器并运行配置好的任务,服务器上不需要安装任何其他软件,只需要开启SSH,客户端的ansible会完成所有其他的工作。
上图为ansible的基本架构,从上图可以了解到其由以下部分组成:
- 核心:ansible
- 核心模块(Core Modules):这些都是ansible自带的模块
- 扩展模块(Custom Modules):如果核心模块不足以完成某种功能,可以添加扩展模块
- 插件(Plugins):完成模块功能的补充
- 剧本(Playbooks):ansible的任务配置文件,将多个任务定义在剧本中,由ansible自动执行
- 连接插件(Connectior Plugins):ansible基于连接插件连接到各个主机上,虽然ansible是使用ssh连接到各个主机的,但是它还支持其他的连接方法,所以需要有连接插件
- 主机群(Host Inventory):定义ansible管理的主机
Ansible 部署
YUM方式安装
Centos-安装信息:
源码方式安装
安装好 Ansible 后,我们可以在 /etc/ansible/
的目录底下找到 Ansible 的一些配置文件.
公司通常把 ansible.cfg
和 hosts
这两个配置文件与其它的 Playbooks
放在同个目录下,然后通过git
把它们一起管理起来防止出现不必要的问题.
Ansible 配置文件介绍
目录结构介绍
通过如下命令我们可以获取Ansible所有文件存放目录:
该命令输出内容较多, 大致分为如下几类:
描述 | 路径 |
---|---|
配置文件目录 | /etc/ansible/ |
执行文件目录 | /usr/bin/ |
Lib库依赖目录 | /usr/lib/pythonX.X/site-packages/ansible/ |
Help 文档目录 | /usr/share/doc/ansible-X.X.X/ |
Man文档目录 | /usr/share/man/manl/ |
Ansible配置文件解析(ansible.cfg)
Inventory
用于定义 Ansible 的主机列表配置, Ansible 的自身配置文件只有一个, 即ansible.cfg
, Ansible 安装好后它默认存放于/etc/ansible/ 目录下。
ansible.cfg
配置文件可以存在于多个地方, Ansible 读取配置文件的顺序依次是当前命令执行目录→用户家目录下的。ansible.cfg→ /etc/ansible.cfg, 先找到哪个就使用哪个的配置。其 ansible.cfg 配置的所有内容均可在命令行通过参数的形式传递或定义在 Playbooks 中。目前ansible 配置文件有四种,如下显示:
- 使用/etc/ansible/ansible.cfg
ansible 软件包提供一个基本的配置文件,它位于/etc/ansible/ansible.cfg
如果找不到其他配置文件,则使用此文件。
- 使用~/ansible.cfg
Ansible 在用户的主目录中查找 .ansible.cfg
文件。如果存在此配萱并且当前工作目录中也没有ansible.cfg
文件,则使用此配置取代/etc/ansible/ansible.cfg
。
- 使用./ansible.cfg
如果执行ansible 命令的目录中存在ansible.cfg 文件,则使用它,而不使用全局文件或用户的个入文件。这样,管理员可以创建一种目录结构,将不同的环境或项目存储在单独的目录中,并且每一目录包含为独特的一组设置而定制的配置文件。
- 使用ANSIBLE_CONFIG 环境变量
通过ANSIBLE_CONFIG 环境变量定义配萱文件的位置。定义了此变量时,Ansible 将使用变 量所指定的配置文件,而不用上文中提及的任何配置文件。
- 这四种文件的优先级为
配置文件 ansible.cfg 约有 500 行语句, 大多数为注释行默认配置项。 该文件遵循 INI 格 式, 主要常修改配置如下:
Ansible 管理主机配置文件解析(Inventory)
Inventory 是 Ansible 管理主机信息的配置文件,相当于系统 HOSTS 文件的功能,默认存放在/etc/ansible/hosts。为方便批量管理主机,便捷使用其中的主机分组.
内置变量清单
主机连接配置
ansible_connection
:与主机的连接类型。可以是ansible的连接插件的名称。SSH协议类型为smart、ssh或paramiko。默认值是smart。
所有连接配置
ansible_host
:要连接到远程主机的名称。
ansible_port
:要连接到远程主机的端口,默认为22。
ansible_user
:连接到远程主机的用户名。
ansible_password
:连接到远程主机的用户名密码。
SSH连接配置
ansible_ssh_private_key_file
:ssh使用的私有文件,适用于有多个秘钥,但不想使用ssh agent情况。
ansible_ssh_common_args
:该设置附加到默认的sftp、scp和ssh命令行上。
ansible_sftp_extra_args
:该设置总是附加到默认的sftp命令行上。
ansible_scp_extra_args
:该设置总是附加到默认的scp命令行上。
ansible_ssh_extra_args
:该设置总是附加到默认的ssh命令行上。
ansible_ssh_pipelining
:确定是否使用SSH pipelining,该参数会覆盖ansible.cfg中的pipelining设置。
ansible_ssh_executable
:此设置会覆盖使用系统ssh的默认行为,会覆盖ansible.cfg中的ssh_executable参数。
如果只有一个 Inventory 时可不用指定路径,默认读取/etc/ansible/hosts
,Inventory 可以同时存在多个.
参考示例:
Ansible 通过Inventory 来定义其主机和组,在使用时通过-i 或 –inventory-file 指定读取,与 Ansible 命令结合使用时组合如下:
Ansible 常用命令
Ansible 命令集
其中,我们比较常用的是/usr/bin/ansible
和/usr/bin/ansible-playbook
Ansible 命令详解
命令的具体格式如下:
也可以通过ansible -h
来查看帮助,下面我们列出一些比较常用的选项,并解释其含义:
-a MODULE_ARGS
#模块的参数,如果执行默认COMMAND的模块,即是命令参数,如: “date”,“pwd”等等
-k
,--ask-pass
#ask for SSH password。登录密码,提示输入SSH密码而不是假设基于密钥的验证
--ask-su-pass
#ask for su password。su切换密码
-K
,--ask-sudo-pass
#ask for sudo password。提示密码使用sudo,sudo表示提权操作
--ask-vault-pass
#ask for vault password。假设我们设定了加密的密码,则用该选项进行访问
-B SECONDS
#后台运行超时时间
-C
#模拟运行环境并进行预运行,可以进行查错测试
-c CONNECTION
#连接类型使用
-f FORKS
#并行任务数,默认为5
-i INVENTORY
#指定主机清单的路径,默认为/etc/ansible/hosts
--list-hosts
#查看有哪些主机组
-m MODULE_NAME
#执行模块的名字,默认使用 command 模块,所以如果是只执行单一命令可以不用 -m参数
-o
#压缩输出,尝试将所有结果在一行输出,一般针对收集工具使用
-S
#用 su 命令
-R SU_USER
#指定 su 的用户,默认为 root 用户
-s
#用 sudo 命令
-U SUDO_USER
#指定 sudo 到哪个用户,默认为 root 用户
-T TIMEOUT
#指定 ssh 默认超时时间,默认为10s,也可在配置文件中修改
-u REMOTE_USER
#远程用户,默认为 root 用户
-v
#查看详细信息,同时支持-vvv
,-vvvv
可查看更详细信息
Ansible 配置公私钥
上面我们已经提到过 ansible 是基于 ssh 协议实现的,所以其配置公私钥的方式与 ssh 协议的方式相同,具体操作步骤如下:
Ansible 常用模块
1. 主机连通性测试(ping模块)
我们使用ansible docker -m ping
命令来进行主机连通性测试,效果如下:
这样就说明我们的主机是连通状态的
2. command 模块
这个模块可以直接在远程主机上执行命令,并将结果返回本主机。如:ansible docker -m command -a 'df -h'
命令模块接受命令名称,后面是空格分隔的列表参数。给定的命令将在所有选定的节点上执行。它不会通过shell进行处理,比如$HOME和操作如”<“,”>”,”|”,”;”,”&” 工作(需要使用(shell)模块实现这些功能)。
注意,该命令不支持
| 管道命令
。
3. shell 模块
shell模块可以在远程主机上调用shell解释器运行命令,支持shell的各种功能,例如管道等。如:ansible docker -m shell -a 'cat /etc/passwd | grep root'
只要是我们的shell命令,都可以通过这个模块在远程主机上运行.
4. copy 模块
这个模块用于将文件复制到远程主机,同时支持给定内容生成文件和修改权限等。其相关选项如下:
4.1 复制文件:
4.2.给定内容生成文件,并赋予权限:
4.3. 文件存在,覆盖备份
5. file 模块
该模块主要用于设置文件的属性,比如创建文件、创建链接文件、删除文件等。下面是一些常见的命令:
5.1. 创建一个文件并且赋值
5.2. 创建目录
5.3. 创建软链
5.4.删除目录和文件:
6. fetch 模块
该模块用于从远程某主机获取(复制)文件到本地。
6.1. 远程复制文件
把被控主机/data/test.txt
复制到ansible主机/tmp
目录下
6.2. 拷贝远程主机的目录到本机
7. cron 模块
功能:管理被控端计划任务;
主要参数如下:
7.1 创建时间同步定时任务
7.2 取消时间同步定时任务
7.3 删除时间同步定时任务
8.yum 模块
管理软件包,需要确认被管理端为红帽系列的,并且需要被管理端配置好yum源。主要的参数如下:
安装一个httpd
包
卸载apache
软件包
9. systemd 模块 or systemd模块
该模块用于服务程序的管理。
启动nginx
服务,并设置为开机自启:
10. ansible user 模块 和 group 模块
group模块
管理被控端用户组
创建组tester
,gid
为8888
:
删除组tester
:
user模块
管理被控端用户
添加一个系统用户,用户名为test1
,uid=2222
,创建家目录,主组为root
,附加组为bin
,默认shell
为nologin
删除test1
用户:
11.script 模块
在远程主机运行本地的脚本,实例:
12.get_url 模块
通过互联网下载软件至被控端本地
下载互联网的软件至本地
13.hostname 模块
管理远程主机的主机名
更改192.168.1.88
的主机名为test88
14.archive 模块 和 unarchive 模块
archive模块
在远端主机打包与压缩
将 /var/log/nbdc
目录压缩为 tar.gz
格式,并存储至 /tmp
目录下
unarchive模块
在远端主机解包与解压缩
远程解压192.168.1.88下的/tmp/nbdc.tar.gz
文件
15.selinux 模块
管理远端主机的 SELINUX
防火墙
设置 selinux 为 enforcing
设置 selinux 为 disabled
playbook–有空再深入学习….
Playbook语法简介
Ansible使用YAML语法描述配置文件,YAML语法以简洁明了、结构清晰著称。Ansible的任务配置文件被称为Playbook,我们可以称之为"剧本”。
每一个剧本(Playbook)中都包含一系列的任务,这每个任务在Ansible中又被称为"戏剧”(play)。一个剧本(Playbook)中包含多出戏剧(play),这很容易理解。
具体可到:https://www.junmajinlong.com/ansible/4_ansible_soul_playbook/ 学习,文章系列也非常不错
以下是一个例子:
命令行执行:ansible-playbook demo.yml
下面收Ansible-Linux巡检的一个例子:
1.编写自己的主机清单:/etc/ansible/hosts
2.编写check_server.yml
的playbook的文件
3.编写巡检脚本check_resources.sh
linux巡检:CPU、内存、磁盘。
4.运行ansible-playbook check_server.yml
结果: