Ansible自动化运维--1--ansible设置控制节点到所有子节点的批量免密登录

简介: 管理节点control到所有node节点设置密钥对免密登录,告别ssh-copy-id
+关注继续查看

1、测试环境

centos7.9 阿里云ECS

IP地址角色
10.0.0.235control
10.0.0.236node1
10.0.0.237node2

ansible版本

​[root@ceshi ~]# ansible --versionansible 2.9.27  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, Jun 28 2022, 15:30:04) [GCC 4.8.5 20150623 (Red Hat 4.8.5-44)]

2、操作步骤

2.1 设置hosts

​[root@ceshi ~]# cat /etc/ansible/hosts |grep -v "#" |grep -v "^$"[test]10.0.0.[236:237] ansible_ssh_port=22 ansible_ssh_user=root ansible_ssh_pass=password

注意:

1、这里直接在hosts文件里边指定了账号、密码、端口,也可以在环境变量里边指定2、如果是使用多台主机且IP连续,可以使用上述方式进行设置,比如:10.0.0.[1:255]表示10.0.0.1-10.0.0.255这个段的地址  10.0.[1:255].[1:255] 表示10.0.1-255.1-255这个地址段

2.2 在crontrol生成公钥和私钥

[root@ceshi ~]# ssh-keygen

Generating public/private rsa key pair.

Enter file in which to save the key (/root/.ssh/id_rsa):

/root/.ssh/id_rsa already exists.

Overwrite (y/n)?

输入命令,一路回车

2.3 编写yaml文件

[root@ceshi ~]# cat add_key.yml

---

- name: add key

 hosts: all

 tasks:

   - name: key

     authorized_key:

       user: root

       key: "{{ lookup('file', '/root/.ssh/id_rsa.pub') }}"

       state: present

       

注意:yml文件可以在任意路径

2.4 运行playbook

[root@ceshi ~]# ansible-playbook add_key.yml

PLAY [add key] *********************************************************************************************************************************************************

TASK [Gathering Facts] *************************************************************************************************************************************************

ok: [10.0.0.236]

ok: [10.0.0.237]

TASK [key] *************************************************************************************************************************************************************

ok: [10.0.0.236]

ok: [10.0.0.237]

PLAY RECAP *************************************************************************************************************************************************************

10.0.0.236                 : ok=2    changed=0    unreachable=0    failed=0    skipped=0    rescued=0    ignored=0

10.0.0.237                 : ok=2    changed=0    unreachable=0    failed=0    skipped=0    rescued=0    ignored=0

2.5 取消hosts文件里边关于端口、密码的设置

[root@ceshi ~]# cat /etc/ansible/hosts |grep -v "#" |grep -v "^$"

[test]

10.0.0.[236:237]

2.6 验证测试

[root@ceshi ~]# ansible all -m shell  -a "ip -4 a |grep inet"

10.0.0.237 | CHANGED | rc=0 >>

   inet 127.0.0.1/8 scope host lo

   inet 10.0.0.237/24 brd 10.0.0.255 scope global dynamic eth0

10.0.0.236 | CHANGED | rc=0 >>

   inet 127.0.0.1/8 scope host lo

   inet 10.0.0.236/24 brd 10.0.0.255 scope global dynamic eth0

如果是可以正常输出IP地址,表示免密设置成功

相关文章
|
6天前
|
运维 关系型数据库 Shell
小白带你学习linux自动化运维ansible
小白带你学习linux自动化运维ansible
67 0
小白带你学习linux自动化运维ansible
|
2月前
|
运维 Linux
Ansible自动化运维工具之常用模块使用实战(6)
Ansible自动化运维工具之常用模块使用实战(6)
|
2月前
|
运维 Shell Linux
Ansible自动化运维工具之常用模块使用实战(5)
Ansible自动化运维工具之常用模块使用实战(5)
|
2月前
|
运维 应用服务中间件 网络安全
Ansible自动化运维工具之解决SSH连接使用明文密码问题(4)
Ansible自动化运维工具之解决SSH连接使用明文密码问题(4)
|
2月前
|
运维 搜索推荐 Shell
Ansible自动化运维工具之个性化定制SSH连接登录端口(3)
Ansible自动化运维工具之个性化定制SSH连接登录端口(3)
|
2月前
|
运维 Kubernetes 网络安全
Ansible自动化运维工具之主机管理与自定义配置文件(2)
Ansible自动化运维工具之主机管理与自定义配置文件(2)
|
2月前
|
存储 运维 Linux
Ansible自动化运维工具安装入门,看这一篇就够了(1)
Ansible自动化运维工具安装入门,看这一篇就够了(1)
|
3月前
|
运维 固态存储 定位技术
Ansible_自动化运维实战(一)
Ansible_自动化运维实战(一)
|
4月前
|
运维 关系型数据库 应用服务中间件
【运维知识进阶篇】Ansible自动化运维-PlayBook详解
【运维知识进阶篇】Ansible自动化运维-PlayBook详解
74 0
|
4月前
|
运维 Shell 网络安全
【运维知识进阶篇】Ansible自动化运维-ad-hoc详解
【运维知识进阶篇】Ansible自动化运维-ad-hoc详解
64 0
热门文章
最新文章
推荐文章
更多