官方帮助文档:

https://docs.ansible.com/ansible-core/2.11/installation_guide/intro_installation.html

1.Ansible配置文件

More Actions配置文件或指令

描述

/etc/ansible/ansible.cfg

主配置文件

/etc/ansible/hosts

主机清单

/usr/bin/ansible

主程序,临时命令执行工具

/usr/bin/ansible-doc

查看配置文档,模块功能查看工具

/usr/bin/ansible-galaxy

下载/上传代码或roles模块官网

/usr/bin/ansible-playbook

定制自动化任务,编排剧本工具

/usr/bin/ansible-pull

远程执行命令工具

/usr/bin/ansible-vault

文件加密工具

/usr/bin/ansible-console

console界面与用户执行的工具

默认配置文件信息

cat /etc/ansible/ansible.cfg
[defaults]                   #默认值
#inventory      = /etc/ansible/hosts      #主机列表配置文件
#library        = /usr/share/my_modules/  #库文件存放目录
#module_utils   = /usr/share/my_module_utils/ #模块应用程序路径
#remote_tmp     = ~/.ansible/tmp   #临时py命令文件存放在远程主机目录
#local_tmp      = ~/.ansible/tmp   #本机的临时命令执行目录
#plugin_filters_cfg = /etc/ansible/plugin_filters.yml #插件过滤器
#forks          = 5			#默认并发数	
#poll_interval  = 15		#查询间隔数
#sudo_user      = root       #默认sudo用户
#ask_sudo_pass = True		#每次执行是否询问密码
#ask_pass      = True		#连接时提升输入ssh密码
#transport      = smart		
#remote_port    = 22		#远程默认端口 生产中可能会不同
#module_lang    = C			
#module_set_locale = False   #模块设置区域默认为关闭

自定义的配置文件以及清单文件

cat ansible.cfg 
[defaults]
inventory = ./inventory      #设置当前目录下的清单等
remote_user = someuser   #远程连接到某个用户
ask_pass = false					#不需要密码
[privilege_escalation]  
become=True      #连接后是否自动在受管主机上切换用户(通常切换为root)这也可以通过play来指定。
become_method=sudo #如何切换用户(通常为sudo,这也是默认设置,但可选择su)
become_user=root #要在受管主机上切换到的用户(通常是root,这也是默认值)
become_ask_pass=False  #是否需要为become_method提示输入密码。默认为false。 


[root@master ]# cat inventory 
1.1.1.1     #组外ip地址
[web]                   #主机组,不以中括号扩起的均是主机
192.168.136.145  192.168.136.219   #组内ip地址
www[001:006].example.com       #组内域名地址
2.Ansible优先级
1.在没有定义Ansible.cfg配置文件情况下,默认选项为
/etc/ansible/ansible.cfg与/etc/ansible/hosts (优先级最低)

2.在用户的家目录下查看ansible.cfg文件,有配置文件且没有工作ansible
命令目录的情况下则代替默认配置文件(.ansible.cfg优先级其次)

3.在某个目录下存在ansible.cfg文件,则使用它,不使用其它位置配置文件
(优先级一般)

4.环境变量ANSIBLE_CONFIG:自定义式的方式选择某个位置的ansible.cfg
配置文件,一旦选择,全局生效,不会用到其它任何地方的ansible.cfg配置文件。

优先级顺序:ANSIBLE_CONFIG(环境变量) > 自定义目录下的ansible配置  >家目录下的ansible配置 > /etc/ansible/ansible.cfg
3.Ansible权限

练习环境下:

用root用户权限连接即可
偏要普通用户的话:
[root@master ~]# vim /etc/ansible/hosts
[web]
192.168.136.145  ansible_user=redhat ansible_password=redhat 
ansible_sudo_pass=redhat

生产环境下:

#用免密进行登录,详细地址:
#配置主文件,进行升级提权
[root@master ~]# vim /etc/ansible/ansible.cfg 
remote_user = redhat     #107行 设置对端连接的普通用户
[privilege_escalation]  #340行
become=True      #连接后是否自动在受管主机上切换用户(通常切换为root)这也可以通过play来指定。
become_method=sudo #如何切换用户(通常为sudo,这也是默认设置,但可选择su)
become_user=root #要在受管主机上切换到的用户(通常是root,这也是默认值)
become_ask_pass=False  #是否需要为become_method提示输入密码。默认为false。      
									
[root@master ~]#vim /etc/ansible/hosts
[web]
192.168.136.129 

#受管主机
[root@slave1 ~]# visudo
## Allow root to run any commands anywhere
root    ALL=(ALL)       ALL
redhat    ALL=(ALL)       NOPASSWD: ALL
4.Ansible帮助文档

命令行查看帮助文档:
1.先用ansible-doc -l |grep xxx :过滤一下查到模块的名称
如:
ansible-doc -l |grep command
ansible-doc -l |grep user
2. 使用命令输入模块的名称:ansible-doc user
3.上下翻,看到用户的创建与删除的方式为如下:
state
Whether the account should exist or not, taking action if the state is different from what is
stated.
(Choices: absent, present)[Default: present]
type: str

官方帮助文档:https://docs.ansible.com/ansible-core/2.11/collections/index_module.html
英语不好的开翻译,网络挂的拜拜!

5.几个基本的模块

ping模块

[root@centos82 ~]# ansible web -m ping 
192.168.136.145 | SUCCESS => {
    "ansible_facts": {
        "discovered_interpreter_python": "/usr/libexec/platform-python"
    },
    "changed": false,
    "ping": "pong"
}

service模块
enabled:yes|no 开机是否自启
name:必选项,服务名称
state:(started,stopped,restarted,reloaded)启动,停止,启动,重新加载
sleep:停止和启动之间休眠几秒,有助于处理恶劣的init脚本

#查看受管主机httpd状态
[root@centos82 ~]# ansible web -a'systemctl status httpd'
192.168.136.145 | FAILED | rc=3 >>
● httpd.service - The Apache HTTP Server
   Loaded: loaded (/usr/lib/systemd/system/httpd.service; disabled; vendor preset: disabled)
   Active: inactive (dead)
     Docs: man:httpd.service(8)non-zero return code
#开启受管主机的httpd服务
[root@centos82 ~]# ansible web -a'systemctl start httpd'
192.168.136.145 | CHANGED | rc=0 >>
#关闭受管主机的httpd服务
[root@centos82 ~]# ansible web -a'systemctl stop httpd'
192.168.136.145 | CHANGED | rc=0 >>

user模块以及group模块
管理用户账号
-m:user 模块
-a:命令参数
name=xxx :用户名字
shell=/bin/bash|/sbin/nologin :登录的shell(类似-s)
system=yes|no :设置为系统用户,不能在现有用户上更改 (类型-r)
comment=‘描述’ :描述信息(类似-C)
state=absent|present : 修改于不修改内容(创建于删除)
remove=yes|no: 于state=absent搭配使用,会删除用户的家目录(类似userdel -r)
create_home=yes|no : 创建于没有家目录(类型-M)
gid
uid

#给受管主机创建一个没有家目录并且不能登录的系统用户mysql,描述为“这是mysql”
[root@master ~]# ansible web -m user -a "name=mysql system=yes create_home=on shell=/sbin/nologin comment='这是mysql用户'"
192.168.136.129 | CHANGED => {
    "ansible_facts": {
        "discovered_interpreter_python": "/usr/libexec/platform-python"
    },
    "append": false,
    "changed": true,
    "comment": "这是mysql用户",
    "group": 973,
    "home": "/home/mysql",
    "move_home": false,
    "name": "mysql",
    "shell": "/sbin/nologin",
    "state": "present",
    "uid": 974
}

[root@slave01 ~]# cat /etc/passwd|grep mysql
mysql:x:974:973:这是mysql用户:/home/mysql:/sbin/nologin


#删除该用户
root@master ~]# ansible web -m user -a "name=mysql state=absent remove=yes"
192.168.136.129 | CHANGED => {
    "ansible_facts": {
        "discovered_interpreter_python": "/usr/libexec/platform-python"
    },
    "changed": true,
    "force": false,
    "name": "mysql",
    "remove": true,
    "state": "absent",
    "stderr": "userdel: mysql 邮件池 (/var/spool/mail/mysql) 未找到\n",
    "stderr_lines": [
        "userdel: mysql 邮件池 (/var/spool/mail/mysql) 未找到"
    ]
}

    
#创建组
[root@master ~]# ansible web -m group -a "name=vvv state=present gid=9999"
192.168.136.129 | CHANGED => {
    "ansible_facts": {
        "discovered_interpreter_python": "/usr/libexec/platform-python"
    },
    "changed": true,
    "gid": 9999,
    "name": "vvv",
    "state": "present",
    "system": false
}
[root@slave01 ~]# cat /etc/group|grep vvv
vvv:x:9999:
#修改组gid
[root@master ~]# ansible web -m group -a "name=vvv  gid=99"
192.168.136.129 | SUCCESS => {
    "ansible_facts": {
        "discovered_interpreter_python": "/usr/libexec/platform-python"
    },
    "changed": false,
    "gid": 99,
    "name": "vvv",
    "state": "present",
    "system": false
}
[root@slave01 ~]# cat /etc/group|grep vvv
vvv:x:99: