ansible常用模块与配置代理
1. 配置免密登陆:
ansible -i costome_hosts all -m authorized_key -a "user=root key='{{ lookup('file', '/root/.ssh/id_rsa.pub')}}' path='/root/.ssh/authorized_keys' manage_dir=no"
costome_hosts 配置
[default] 1.1.1.1 ansible_ssh_pass='qqqqq' 2.2.2.2 ansible_ssh_pass='ddddd' [all:vars] ansible_ssh_user='root'
2. 替换文件中的一行,类似于sed命令
--- - hosts: all remote_user: root gather_facts: false tasks: - name: replace remote line a.root-servers.net. lineinfile: dest: /etc/hosts # 要修改的文件 regexp: "1.1.1.1" # 匹配要替换的行中含有的字符 line: "{{item.line}}" # 来自于下面的with_items insertafter: "1.1.1.1" # 如果没匹配到,且backrefs为no,则在后面新加一行 backrefs: yes with_items: - { line: "2.2.2.2 aroot-servers.net." } # 要替换的新内容 - name: replace remote line a.root-servers.net. lineinfile: dest: /etc/hosts regexp: "3.3.3.3" line: "{{item.line}}" insertafter: "3.3.3.3" backrefs: yes with_items: - { line: "3.3.3.3 a.gtld-servers.net." }
3. ansible使用代理登录其他机器
ansible host ---X--> A机器 B机器(3.3.3.3)------> A机器【ansible机器直连A不通,但与机器B是通的,可以使用B机器作为代理,跳到A机器上】
ansible host -------> B机器(代理)----->A机器
13.134.8.25 18.56.22.7 [all:vars] ansible_ssh_user=root ansible_python_interpreter=/usr/local/ansible_python/python/bin/python3 ansible_ssh_common_args='-o ProxyCommand="ssh -W %h:%p -p 22 -q root@3.3.3.3"'
https://blog.ruanbekker.com/blog/2020/10/26/use-a-ssh-jump-host-with-ansible/
https://www.jeffgeerling.com/blog/2022/using-ansible-playbook-ssh-bastion-jump-host
4. ansible正则匹配删除某几行
ansible -i inventories/host 1.2.2.1 -m lineinfile -a "dest=/home/logs/cd.log regexp='(.*)15:24:59(.*)' state=absent"
可以删除[2021-2-3 15:24:59.34243] [info] dsdjhf fjdjfdjfjk类似行