[推荐]ansible在主控机执行实现多个worker机器免密登录

1)先保证3个机器(1个master2个worker)都启动!!!

2)输入ansible --version,没有反应则会提示安装,直接安装即可!!!

3)验证版本

复制代码
[root@bogon mianmi]# python --version
Python 3.9.19


[root@bogon mianmi]# ansible --version
ansible [core 2.14.18]
  config file = /etc/ansible/ansible.cfg
  configured module search path = ['/root/.ansible/plugins/modules', '/usr/share/ansible/plugins/modules']
  ansible python module location = /usr/lib/python3.9/site-packages/ansible
  ansible collection location = /root/.ansible/collections:/usr/share/ansible/collections
  executable location = /usr/bin/ansible
  python version = 3.9.19 (main, Sep 11 2024, 00:00:00) [GCC 11.5.0 20240719 (Red Hat 11.5.0-2)] (/usr/bin/python3)
  jinja version = 3.1.2
  libyaml = True

4)master机器生成一下

复制代码
[root@bogon mianmi]# ssh-keygen -t ed25519 -C "ansible-master" -f ~/.ssh/id_ed25519

5)master机器上查看下~/.ssh下,证明生成完毕

复制代码
[root@bogon .ssh]# cat id_ed25519.pub 
ssh-ed25519 AAAAC3NzaC1lZDI1NTE5AAAAINcv3wV16QWvOQodOAOncKI6I499cRjud+Kovhu7C3fW ansible-master

6)准备好主机清单

hosts.int

复制代码
[workers]
192.168.3.204
192.168.3.205

[all:vars]
ansible_user=root
ansible_port=22
ansible_ssh_common_args='-o StrictHostKeyChecking=accept-new'

7)准备好剧本

push_ssh_key.yml

复制代码
- hosts: workers
  gather_facts: no
  tasks:
    - name: install master's public key to workers
      authorized_key:
        user: "{{ ansible_user }}"
        state: present
        key: "{{ lookup('file', '~/.ssh/id_ed25519.pub') }}"

8)执行

复制代码
[root@bogon mianmi]# ansible-playbook -i hosts.ini push_ssh_key.yml -k
SSH password: 
[WARNING]: Collection ansible.posix does not support Ansible version 2.14.18

PLAY [workers] *******************************************************************************************************************************

TASK [install master's public key to workers] ************************************************************************************************
ok: [192.168.3.204]
changed: [192.168.3.205]

PLAY RECAP ***********************************************************************************************************************************
192.168.3.204              : ok=1    changed=0    unreachable=0    failed=0    skipped=0    rescued=0    ignored=0   
192.168.3.205              : ok=1    changed=1    unreachable=0    failed=0    skipped=0    rescued=0    ignored=0   

9)验证下,发现都已经成功

复制代码
[root@bogon mianmi]# ansible -i hosts.ini workers -m ping
192.168.3.204 | SUCCESS => {
    "ansible_facts": {
        "discovered_interpreter_python": "/usr/bin/python3"
    },
    "changed": false,
    "ping": "pong"
}
192.168.3.205 | SUCCESS => {
    "ansible_facts": {
        "discovered_interpreter_python": "/usr/bin/python3"
    },
    "changed": false,
    "ping": "pong"
}

总结:

可见ansible安装和使用都非常简单,安装就是:输入,不存在则自动安装。

接着写好清单和剧本,一键执行即可!!!

理解ansible的幂等性

相关推荐
忡黑梨13 分钟前
eNSP_ACL原理及应用
运维·服务器·网络·tcp/ip·github·负载均衡
pray~13 分钟前
海外Linux Debian环境临时安装依赖包
linux·运维·debian
日取其半万世不竭16 分钟前
用云服务器搭建Frp内网穿透,实现远程访问家里电脑
运维·服务器
y_m_h17 分钟前
程序调用追踪
linux
代码中介商26 分钟前
Linux 进程间通信(IPC):管道与信号量完全指南
linux·运维·服务器
W.W.H.32 分钟前
远程连接协议(SSH\Telnet\FTP\Serial等)
运维·arm开发·经验分享·ssh
张青贤38 分钟前
linux离线部署docker和docker-compose
linux·docker·docker-compose
oioihoii1 小时前
OpenClaw桌面 UI 自动化中的 Token 消耗问题几种可能的优化方向
运维·ui·自动化
b***25111 小时前
18650与21700电芯在锂电池自动化生产线中的协同发展
运维·自动化
Johnstons1 小时前
网络抓包留存平台怎么选:全量留存、按需抓包与传统镜像方案的边界、场景与判断标准
运维·服务器·网络·网络运维