rsync 密钥文件错误问题总结
Posted cposture
tags:
篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了rsync 密钥文件错误问题总结相关的知识,希望对你有一定的参考价值。
rsync
可以使用 --password-file
选项指定密钥文件,密钥文件中简单存放 rsync
密码;在第一次使用密钥文件的时候经常遇到文件权限相关问题;这里总结一下,我遇到的问题。
问题描述
在开发环境下,手动执行 python ccmcx_tdw_data_sync.py
,执行前还确保了 rsync.secret
具体读写权限,chmod u+rw rsync.secret
,执行正常;后面将脚本加入 crontab
,
运行报错:password file must be owned by root when running as root
简单的处理,让所有用户都有权限读写:chmod a+rw rsync.secret
;运行报错:password file must not be other-accessible
结论
password file must be owned by root when running as root
:后面检查发现,每个用户都有自己的crontab
,而我是以root
用户设置crontab
任务的,因此执行脚本的用户也是root
,看第一个报错是因为 file owner 不是root
,chown root rsync.secret
简单解决;password file must not be other-accessible
:可以看出rsync
对密钥文件管理的严格,owner 不仅仅要求是 run user,而且读写权限需要做收敛,不能被其他用户读写,执行chmod o-rw rsync.secret
从这里可以看出
rsync
对密钥文件的管理原则:密钥文件的拥有者只能是运行命令的用户,且只能由拥有者读写,这样文件就为运行用户专属了,其他普通用户不能通过密钥文件传输文件或者读写密钥文件了一个题外话:每个用户都有自己的
crontab
,crontab
不在一个配置文件中,运维难以管理,大部分的crontab
都会由运维统一放在 root 的crontab
下,除此之外,还可以直接在/etc/crontab
文件中添加,不过需要是root
身份。这个文件的crontab
与用户的不太一样,可以指定运行命令的用户,这样的一个好处是:运维方便管理,而且可以指定运行命令的用户,普通用户的环境变量等相关信息不需要对齐到root
。
以上是关于rsync 密钥文件错误问题总结的主要内容,如果未能解决你的问题,请参考以下文章