gpt4 book ai didi

linux - Ansible 'synchronize' 覆盖文件夹,即使 delete=no

转载 作者:太空宇宙 更新时间:2023-11-04 13:00:52 24 4
gpt4 key购买 nike

在我的 Ansible 角色“xen”中,我有这个任务:

---
- name: Install Xen
synchronize: src=install/
dest=/
archive=yes
delete=no

我想将以下结构复制到目的地而不覆盖现有文件夹中的文件,如 /boot/lib64:

root@node51 [~]# tree -L 1 /etc/ansible/xenhost/xen/files/install
/etc/ansible/xenhost/xen/files/install
├── boot
├── etc
├── lib64
├── usr
└── var

5 directories, 0 files

任务成功,但它替换了 /lib64 中的所有文件。那杀死了我的服务器:

[root@localhost ~]# ls /lib64/
-bash: /usr/bin/ls: /lib64/ld-linux-x86-64.so.2: bad ELF interpreter: No such file or directory

这是详细的任务输出,为简洁起见被截断了:

TASK: [xen | Install Xen] ***************************************************** 
<127.0.0.1> EXEC ['/bin/sh', '-c', 'mkdir -p $HOME/.ansible/tmp/ansible-tmp-1448470134.66-193795609318676 && echo $HOME/.ansible/tmp/ansible-tmp-1448470134.66-193795609318676']
<127.0.0.1> PUT /tmp/tmpb7EusD TO /root/.ansible/tmp/ansible-tmp-1448470134.66-193795609318676/synchronize
<127.0.0.1> EXEC ['/bin/sh', '-c', u'LANG=C LC_CTYPE=C /usr/bin/python /root/.ansible/tmp/ansible-tmp-1448470134.66-193795609318676/synchronize; rm -rf /root/.ansible/tmp/ansible-tmp-1448470134.66-193795609318676/ >/dev/null 2>&1']
changed: [192.168.0.123] => {"changed": true, "cmd": "rsync --delay-updates -FF --compress --archive --rsh 'ssh -o StrictHostKeyChecking=no' --out-format='<<CHANGED>>%i %n%L' \"/etc/ansible/xenhost/xen/files/install/\" \"root@192.168.0.123:/\"", "msg": "…truncated…"}

奇怪的是,该任务并没有删除 /boot 中的现有文件。

为了以防万一,我确保明确指定了delete=no,所以它应该Delete files that don't exist (after transfer, not before) in the src path.

为什么 Ansible 的“同步”模块替换了 /lib64 但按预期复制到了 /boot

最佳答案

问题是 /lib64 不是目录。这是一个符号链接(symbolic link):

[root@localhost ~]# file /lib64
/lib64: symbolic link to `usr/lib64'

通过让 Ansible“同步”rsync 您的 lib64 目录,它删除符号链接(symbolic link)并在其位置放置一个实际文件夹

因此,/usr/lib64 中的库不再可以从 /lib64 访问,这就是为什么一切都依赖于在 /中查找库的原因lib64 失败:

[root@localhost ~]# ldd /usr/bin/ls
linux-vdso.so.1 => (0x00007fffa9118000)
libselinux.so.1 => /lib64/libselinux.so.1 (0x00007fe4b9630000)
libcap.so.2 => /lib64/libcap.so.2 (0x00007fe4b9428000)
libacl.so.1 => /lib64/libacl.so.1 (0x00007fe4b9218000)
libc.so.6 => /lib64/libc.so.6 (0x00007fe4b8e50000)
libpcre.so.1 => /lib64/libpcre.so.1 (0x00007fe4b8be8000)
liblzma.so.5 => /lib64/liblzma.so.5 (0x00007fe4b89c0000)
libdl.so.2 => /lib64/libdl.so.2 (0x00007fe4b87b8000)
/lib64/ld-linux-x86-64.so.2 (0x00007fe4b9860000)
libattr.so.1 => /lib64/libattr.so.1 (0x00007fe4b85b0000)
libpthread.so.0 => /lib64/libpthread.so.0 (0x00007fe4b8390000)

补救措施

改为复制到 /usr/lib64。将要复制的库放在 /etc/ansible/xenhost/xen/files/install/usr/lib64 而不是 /etc/ansible/xenhost/xen/files/install/lib64,并确保后面的路径不存在。

关于linux - Ansible 'synchronize' 覆盖文件夹,即使 delete=no,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/33923035/

24 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com