
Estou tendo um problema em que os arquivos são copiados para o servidor remoto, exceto que o proprietário/grupo de arquivos replicados no servidor de destino é sempre '1002'. As permissões da origem são respeitadas e replicadas corretamente no destino. Simplesmente não consigo descobrir uma maneira de preservar o proprietário (e o grupo) dos arquivos replicados.
Versão do Lsyncd: 2.2.2
minha configuração abaixo:
settings {
logfile = "/var/log/lsyncd/lsyncd.log",
statusFile = "/var/log/lsyncd/lsyncd.status"
}
sync {
default.rsyncssh,
source="/home",
host="1*52.*.15",
targetdir="/home/",
delete = "running", -- prevents deletion of files on startup (ie when a server comes back online, don't delete files that are new on the backup)
delay = 5, -- run every 5 seconds instead of default 20
exclude = {
"/home/backup",
},
rsync = {
archive = true, -- use the archive flag in rsync
perms = true, -- Keep the permissions
owner = true, -- Keep the owner
compress = true,
acls = true,
xattrs = true,
_extra = {"-a"}, -- Sometimes permissions and owners isn't copied correctly so the _extra can be used for any flag in rsync
}
}
Erro de registro lsyncd:
Dec 15 21:42:47 server1.*.group lsyncd[21033]: sending incremental file list
Dec 15 21:42:47 server1.*.group lsyncd[21033]: rsync: failed to set times on "/home/admin/conf": Operation not permitted (1)
Dec 15 21:42:47 server1.*.group lsyncd[21033]: admin/conf/
Dec 15 21:42:47 server1.*.group lsyncd[21033]: sent 5,387 bytes received 160 bytes 3,698.00 bytes/sec
Dec 15 21:42:47 server1.*.group lsyncd[21033]: total size is 2,849,404,839 speedup is 513,683.94
Dec 15 21:42:47 server1.*.group lsyncd[21033]: rsync error: some files/attrs were not transferred (see previous errors) (code 23) at main.c(1178) [sender=3.1.2]
Responder1
Acredito que o problema é que o uid/gid dos arquivos no sistema local não corresponde ao uid/gid no seu sistema de destino.
Verifique os IDs de usuário/grupo no sistema local e crie o mesmo usuário/grupo no sistema de destino.
# On source system
$ ls -l /home/admin/conf
-rw-r--r--. 1 user1 user1 1.0K Jul 13 2018 /home/admin/conf
$ id user1
uid=1002(user1) gid=1002(user1) groups=1002(user1)
# On target system
$ useradd -u 1002 -g 1002 user1
Responder2
Quando o RSYNC transmite um arquivo com propriedade preservada, ele transmite não o nome de usuário/nome do grupo, mas o UID e GID do proprietário.
Portanto, sua experiência com o 1002 significa que esse UID não está em uso no sistema de destino.
Você pode resolver isso de duas maneiras:
- Exclua o usuário antigo e recrie-o usando a configuração UID em useradd. - Esta é provavelmente a maneira mais limpa de fazer isso, já que você não precisará chown ou chmod nada.
- Atualize o UID e o GID usando usermod. -- Se você fizer isso, precisará chown os arquivos em seu diretório inicial e poderá experimentar outros efeitos colaterais inesperados em outros arquivos pertencentes a esse usuário.
Item da lista