首页 > 其他分享 >第二章 Ansible服务搭建

第二章 Ansible服务搭建

时间:2022-09-19 14:47:08浏览次数:76  
标签:cfg ansible etc Ansible ssh m01 第二章 root 搭建

一、环境准备

主机名 IP 身份
m01 10.0.0.61 Ansible 控制端
web01 172.16.1.7 Ansible 被控端
web03 172.16.1.9 Ansible 被控端

二、安装Ansible

[root@m01 ~]# yum install -y ansible

三、Ansible命令详解

# ansible <host-pattern> [options]
--version   #ansible版本信息
-i          #主机清单文件路径,默认是在/etc/ansible/hosts
-m          #使用的模块名称,默认使用command模块
-a          #使用的模块参数,模块的具体动作
-k          #提示输入ssh密码,而不使用基于ssh的密钥认证
-C          #模拟执行测试,但不会真的执行
-T          #执行命令的超时

#查看Ansible版本及模块路径
[root@m01 ~]# ansible --version
ansible 2.9.10
  config file = /etc/ansible/ansible.cfg
  configured module search path = [u'/root/.ansible/plugins/modules', u'/usr/share/ansible/plugins/modules']
  ansible python module location = /usr/lib/python2.7/site-packages/ansible
  executable location = /usr/bin/ansible
  python version = 2.7.5 (default, Oct 30 2018, 23:45:53) [GCC 4.8.5 20150623 (Red Hat 4.8.5-36)]

四、Ansible配置文件读取顺序

[root@m01 ~]# vim /etc/ansible/ansible.cfg 
# nearly all parameters can be overridden in ansible-playbook
# or with command line flags. ansible will read ANSIBLE_CONFIG,
# ansible.cfg in the current working directory, .ansible.cfg in
# the home directory or /etc/ansible/ansible.cfg, whichever it
# finds first

[root@m01 ~]# rpm -ql ansible
[root@m01 ~]# zcat /usr/share/man/man1/ansible-config.1.gz

#要查看完整列表,请访问https://docs.ansibe.com/或使用ansibe-config命令。
For a full list check \fI\%https://docs.ansible.com/\fP\&. or use the \fIansible\-config\fP command.

#/etc/ansible/ansible.cfg 配置文件,如果存在则使用
/etc/ansible/ansible.cfg \-\- Config file, used if present

#~/.ansible.cfg 用户配置文件,覆盖默认配置(如果存在)
~/.ansible.cfg \-\- User config file, overrides the default config if present

#\&/ansible.cfg 本地配置文件(在当前工作目录中)假定为(aqproject-specific)(aq,如果存在,则重写其余文件)。
\&./ansible.cfg \-\- Local config file (in current working directory) assumed to be \(aqproject specific\(aq and overrides the rest if present.

#如上所述,ANSIBLE_CONFIG环境变量将覆盖所有其他环境变量。
As mentioned above, the ANSIBLE_CONFIG environment variable will override all others.

#生效优先级
ANSIBLE_CONFIG  >>  $ANSIBLE_CONFIG/ansible.cfg  >>  ~/.ansible.cfg  >>  /etc/ansible/ansible.cfg

五、配置Ansible

[root@m01 ~]# cat /etc/ansible/ansible.cfg 
#inventory      = /etc/ansible/hosts      #主机列表配置文件
#library        = /usr/share/my_modules/  #库文件存放目录
#remote_tmp     = ~/.ansible/tmp          #临时py文件存放在远程主机目录
#local_tmp      = ~/.ansible/tmp          #本机的临时执行目录
#forks          = 5                       #默认并发数
#sudo_user      = root                    #默认sudo用户
#ask_sudo_pass = True                     #每次执行是否询问sudo的ssh密码
#ask_pass      = True                     #每次执行是否询问ssh密码
#remote_port    = 22                      #远程主机端口
host_key_checking = False                 #跳过检查主机指纹
log_path = /var/log/ansible.log           #ansible日志

#普通用户提权操作
[privilege_escalation]
#become=True
#become_method=sudo
#become_user=root
#become_ask_pass=False 

六、配置主机清单

1.单主机配置方式一

#ip+端口+用户+密码
[root@m01 ~]# vim /etc/ansible/hosts 
[web01]
172.16.1.7 ansible_ssh_port=22 ansible_ssh_user=root ansible_ssh_pass='1'
[web03]
172.16.1.7 ansible_ssh_port=22

#测试主机清单
[root@m01 ~]# ansible '*' -m ping

2.单主机配置方式二

[root@m01 ~]# vim /etc/hosts
172.16.1.7 web01
172.16.1.9 web03

[root@m01 ~]# vim /etc/ansible/hosts 
[web01]
web01 ansible_ssh_port=22 ansible_ssh_user=root ansible_ssh_pass='1'
[web03]
web03 ansible_ssh_port=22 ansible_ssh_user=root ansible_ssh_pass='1'

3.单主机配置方式三

[root@m01 ~]# vim /etc/ansible/hosts 
[web1]
web01 
[web3]
web03
[web1:vars]
ansible_ssh_pass='1'
[web3:vars]
ansible_ssh_pass='1'

4.单主机配置基于秘钥方式

#生成密钥对
[root@m01 ~]# ssh-keygen

#推送秘钥
[root@m01 ~]# ssh-copy-id 172.16.1.7
[root@m01 ~]# ssh-copy-id 172.16.1.9

#配置
[root@m01 ~]# vim /etc/ansible/hosts 
[web1]
web01
[web3]
web03

5.单主机主机组配置

[root@m01 ~]# vim /etc/ansible/hosts 
[web_group]
web01
web03
[nfs_group]
nfs ansible_ssh_pass='1'

#查看组下面的机器
[root@m01 ~]# ansible 'web_group' --list-host
  hosts (2):
    web01
    web03

6.单主机操作多个组

[root@m01 ~]# ansible 'web_group,nfs_group' -m ping

定义包含组
[root@m01 ~]# vim /etc/ansible/hosts 
[web_group]
web01
web03

[nfs_group]
nfs ansible_ssh_pass='1'

[mysql_group]
db01 ansible_ssh_pass='1'
db02 ansible_ssh_pass='1'

[nfs_zu:children]
web_group
nfs_group

#注意:
	主机名和组名称不要一样,否则执行命令时不知道找主机还是主机组

标签:cfg,ansible,etc,Ansible,ssh,m01,第二章,root,搭建
From: https://www.cnblogs.com/GAO321/p/16707621.html

相关文章

  • 第一章 Ansible入门
    一、Ansible概述、Ansible是一种IT自动化工具。它可以配置系统、部署软件并协调更高级的IT任务,例如持续部署或零停机滚动更新。Ansible的主要目标是简单易用。它......
  • 通过外网服务器搭建frp服务实现本地内网穿透
    背景:疫情期间在家远程办公,一般公司办公室开发测试环境是内网服务,为了远程使用公司的内网服务,那就需要做内网穿透,本文已阿里云服务搭建,其它云服务也是一样的。1、下载部署......
  • kubernetes1.24环境搭建实验——docker准备
    Docker准备1、dockeryum源安装参考网址:docker-ce镜像-docker-ce下载地址-docker-ce安装教程-阿里巴巴开源镜像站(aliyun.com)curl-o/etc/yum.repos.d/docker-ce.rep......
  • 第十一章 Redis分布式主从搭建
    一、redis主从原理1.从库配置主从同步2.从库像主库发起sync命令3.主库接收sync命令,执行bgsave,生成持久化rdb文件4.主库将新的数据临时写入缓冲区5.主库将rdb文件推送......
  • rabbit-mq集群docker搭建笔记
    1.安装docker1、yum包更新到最新yumupdate2、安装需要的软件包,yum-util提供yum-config-manager功能,另外两个是devicemapper驱动依赖的yuminstall-yyum-uti......
  • 12.ansible lineinfile模块
    前言:lineinfile模块,功能有点类似sed常用功能:对文件的行替换、插入、删除PS:替换/插入:如果有重复的,都是匹配最后一个,如果不加backrefs项,替换/插入如无匹配者,则将line......
  • 本次介绍如何利用ansible一键初始化centos7
    本次介绍如何利用ansible一键初始化centos7。本文介绍的运行环境是CentOS7.6:[root@localhost~]#cat/etc/redhat-releaseCentOSLinuxrelease7.6.1810(Core)[r......
  • 第二章 Redis-6.0概述安装
    一.缓存数据库的概念传统的数据库管理系统把所有数据都放在磁盘上进行管理,所以称做磁盘数据库(DRDB:Disk-ResidentDatabase)。磁盘数据库需要频繁地访问磁盘来进行数据的操......
  • elasticsearch集群搭建
    elasticsearch集群搭建 我们会在单机上利用docker容器运行多个es实例来模拟es集群。不过生产环境推荐大家每一台服务节点仅部署一个es的实例。部署es集群可以直接使用d......
  • java三大版本以及开发环境搭建
    Java三大版本JavaSE标准版JavaME嵌入式开发JavaEEE企业级开发JDK:javaDevelopmentKit(Java开发者工具)JRE:JavaRuntimeEnvironment(运行环境)JVM:JavaVirtualMa......