rsync报错:rsync: chgrp ".hejian.txt.D1juHb" (in backup) failed: Operation not permitted (1)

问题背景:在配置好rsync服务和客户端后,客户端从服务端拉取是正常的,但从客户端推送到服务端报错。
a,单独推送目录会报这个错误
rsync: recv_generator: mkdir "opt" (in backup) failed: Permission denied (13)

[root@nfs01:/opt]# rsync -avz /opt rsync_backup@10.0.0.41::backup
Password:
sending incremental file list
rsync: recv_generator: mkdir "opt" (in backup) failed: Permission denied (13)
*** Skipping any contents from this failed directory ***
opt/

sent 472 bytes  received 172 bytes  257.60 bytes/sec
total size is 697,812  speedup is 1,083.56
rsync error: some files/attrs were not transferred (see previous errors) (code 23) at main.c(1178) [sender=3.1.2]

如果从客户端向服务端推送目录和文件也报错rsync: chgrp ".backup.sh.RwFAWn" (in backup) failed: Operation not permitted (1)。但文件传过去了,目录并没有传过去

[root@nfs01:/opt]# rsync -avz /opt/ rsync_backup@10.0.0.41::backup
Password:
sending incremental file list
./
backup.sh
hejian.txt
services
rsync: chgrp ".backup.sh.RwFAWn" (in backup) failed: Operation not permitted (1)
rsync: chgrp ".hejian.txt.iLqEOb" (in backup) failed: Operation not permitted (1)
rsync: chgrp ".services.vxwJGZ" (in backup) failed: Operation not permitted (1)

sent 136,811 bytes  received 340 bytes  21,100.15 bytes/sec
total size is 697,812  speedup is 5.09
rsync error: some files/attrs were not transferred (see previous errors) (code 23) at main.c(1178) [sender=3.1.2]

然后检查/backup目录的权限被修改成了550,原来设置的是755,然后把权限修改成755后再重新操作

[root@backup:/backup]# ls -ld /backup/
dr-xr-x--- 3 rsync rsync 312 Sep  1 07:54 /backup/
root@backup:/backup]# chmod 755 /backup/
[root@backup:/backup]# ls -ld /backup/
drwxr-xr-x 4 rsync rsync 324 Sep  1 08:03 /backup/

但修改完后再通过客户端同步,还是报上面的错,并且刚修改的目录权限又变成了550

从网上查询的说是selinux影响,但我检查两台服务器的selinux设置的都是disabled,防火墙也处于关闭状态

[root@backup:/backup]# getenforce
Disabled

经排查是由于-a参数导致的,因为-a是归档模式传输,并保持所有文件属性,等价于-rtopgDl(还没有具体深入研究),可以使用下面这个命令替代

[root@nfs01:/opt]# rsync -rltDvz /opt/ rsync_backup@10.0.0.41::backup

如果还想使用-avz这个参数组合的话,可以在rsyncd.conf配置文件中添加一个参数fake super = yes也能解决问题
,同样的命令和配置文件rsync在CentOS6系统之前是不需要的,CentOS7系统需要增加这个参数才不会报错

转载于:https://www.cnblogs.com/hejian2836/p/11441383.html

  • 1
    点赞
  • 2
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
你可以按照以下步骤配置rsync https://maven.aliyun.com/repository/public: 1. 首先安装rsync,如果你使用的是Ubuntu系统,可以通过以下命令来安装: ``` sudo apt-get install rsync ``` 2. 创建一个本地的目录,用来存放从阿里云下载的Maven仓库文件,例如: ``` mkdir -p /path/to/local/maven/repo ``` 3. 在阿里云的Maven仓库中创建一个新的rsync用户,并分配一个密码。 4. 在本地创建一个rsyncd.conf文件,并将以下内容添加到文件中: ``` uid = root gid = root use chroot = no max connections = 10 pid file = /var/run/rsyncd.pid [aliyun-maven] path = /path/to/local/maven/repo comment = Aliyun Maven Repository auth users = rsync secrets file = /etc/rsyncd.secrets list = true read only = false ``` 这个配置文件中,我们创建了一个名为“aliyun-maven”的rsync模块,它会将所有的文件同步到本地的“/path/to/local/maven/repo”目录下。 5. 创建一个rsyncd.secrets文件,并将以下内容添加到文件中: ``` rsync:your_password ``` 这里的“your_password”应该替换为你在第三步中设置的rsync用户的密码。 6. 确保rsyncd.conf和rsyncd.secrets文件的权限设置为只有root用户可读取和写入。 ``` sudo chmod 600 /etc/rsyncd.conf sudo chmod 600 /etc/rsyncd.secrets ``` 7. 在阿里云的Maven仓库中使用rsync命令同步文件到本地: ``` rsync -avz --delete rsync://rsyncuser:password@maven.aliyun.com/repository/public/ /path/to/local/maven/repo/ ``` 这个命令会将阿里云Maven仓库中的所有文件同步到本地的“/path/to/local/maven/repo”目录下。 8. 启动rsync服务: ``` sudo systemctl start rsync ``` 9. 验证配置是否正确。你可以使用以下命令来查看rsync服务是否在运行: ``` sudo systemctl status rsync ``` 如果服务正在运行,你可以尝试从本地访问阿里云Maven仓库中的文件,看看是否可以正常访问: ``` ls /path/to/local/maven/repo ``` 以上就是在Ubuntu系统中配置rsync https://maven.aliyun.com/repository/public的详细步骤。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值