浏览模式: 标准 | 列表 2020年04月的文章

CentOS下使用rsync通过ssh同步文件夹

需求:有A和B这2个CentOS服务器,A的IP为192.168.1.1,B的IP为192.168.1.2,现在需要将A中/test文件夹同步到B中。前提要求开启ssh服务。

方法1:在B上执行(文件夹后面要加/保证只同步该文件夹下的文件夹和文件,如果不加/则会把test文件夹也同步过来),将A上/test/文件夹下的所有文件同步到B上的/test/文件夹中

  • rsync -arvuz /test/ root@192.168.1.1:/test/
ssh默认端口是22,为了安全会A修改成别的端口号比如1688,那么命令就要改成
  • rsync -arvuz /test/ -e 'ssh -p 1688' root@192.168.1.1:/test/
方法2:在A上执行
  • rsync -arvuz root@192.168.1.1:/test/ /test/
以下为rsync命令的相关参数:
  • -v:显示rsync过程中详细信息。可以使用"-vvvv"获取更详细信息。
  • -P:显示文件传输的进度信息。(实际上"-P"="--partial --progress",其中的"--progress"才是显示进度信息的)。
  • -n --dry-run  :仅测试传输,而不实际传输。常和"-vvvv"配合使用来查看rsync是如何工作的。
  • -a --archive  :归档模式,表示递归传输并保持文件属性。等同于"-rtopgDl"。
  • -r --recursive:递归到目录中去。
  • -t --times:保持mtime属性。强烈建议任何时候都加上"-t",否则目标文件mtime会设置为系统时间,导致下次更新
  •           :检查出mtime不同从而导致增量传输无效。
  • -o --owner:保持owner属性(属主)。
  • -g --group:保持group属性(属组)。
  • -p --perms:保持perms属性(权限,不包括特殊权限)。
  • -D        :是"--device --specials"选项的组合,即也拷贝设备文件和特殊文件。
  • -l --links:如果文件是软链接文件,则拷贝软链接本身而非软链接所指向的对象。
  • -z        :传输时进行压缩提高效率。
  • -R --relative:使用相对路径。意味着将命令行中指定的全路径而非路径最尾部的文件名发送给服务端,包括它们的属性。用法见下文示例。
  • --size-only :默认算法是检查文件大小和mtime不同的文件,使用此选项将只检查文件大小。
  • -u --update :仅在源mtime比目标已存在文件的mtime新时才拷贝。注意,该选项是接收端判断的,不会影响删除行为。
  • -d --dirs   :以不递归的方式拷贝目录本身。默认递归时,如果源为"dir1/file1",则不会拷贝dir1目录,使用该选项将拷贝dir1但不拷贝file1。
  • --max-size  :限制rsync传输的最大文件大小。可以使用单位后缀,还可以是一个小数值(例如:"--max-size=1.5m")
  • --min-size  :限制rsync传输的最小文件大小。这可以用于禁止传输小文件或那些垃圾文件。
  • --exclude   :指定排除规则来排除不需要传输的文件。
  • --delete    :以SRC为主,对DEST进行同步。多则删之,少则补之。注意"--delete"是在接收端执行的,所以它是在
  •             :exclude/include规则生效之后才执行的。
  • -b --backup :对目标上已存在的文件做一个备份,备份的文件名后默认使用"~"做后缀。
  • --backup-dir:指定备份文件的保存路径。不指定时默认和待备份文件保存在同一目录下。
  • -e          :指定所要使用的远程shell程序,默认为ssh。
  • --port      :连接daemon时使用的端口号,默认为873端口。
  • --password-file:daemon模式时的密码文件,可以从中读取密码实现非交互式。注意,这不是远程shell认证的密码,而是rsync模块认证的密码。
  • -W --whole-file:rsync将不再使用增量传输,而是全量传输。在网络带宽高于磁盘带宽时,该选项比增量传输更高效。
  • --existing  :要求只更新目标端已存在的文件,目标端还不存在的文件不传输。注意,使用相对路径时如果上层目录不存在也不会传输。
  • --ignore-existing:要求只更新目标端不存在的文件。和"--existing"结合使用有特殊功能,见下文示例。
  • --remove-source-files:要求删除源端已经成功传输的文件。

参考:https://www.cnblogs.com/f-ck-need-u/p/7220009.html

解决可道云KodCloud分享链接失效问题

有一个内部的数据分享平台是基于目前最新的可道云KodCloud免费版搭建的,系统版本为v4.40, 2019-3-21

而有用户反映就是自己分享的文件链接都失效了,经过查找资料并测试比对发现造成这个问题的原因就是:分享了A目录下的B文件,但是之后却移动了目录或者文件,或者是重命名他们中的目录名或者文件名。

解决方法:找到data/User/用户名/data/share.php文件,一一对应把修改过的目录名或者文件名恢复到之前就可以了。

那么为什么这个系统不能自动修改share.php文件中的信息达到用户重命名目录名或者文件名后分享链接也不会失效呢?这个问题,只能等官方解决了。

参考资料:

基本上都是变动了分享文件造成的,可以检查下:data/User/用户名/data/share.php,这里记录的分享信息,通过分享id查找对应的文件地址,id不存在或文件地址不存在,就都会找不到;这个文件删除了也会找不到。

解决ThinkPHP报错: SQLSTATE[HY000] [2002] No ...

有一个程序是基于ThinkPHP框架写的,直接访问其中的方法是没问题的,但是通过命令行访问就出问题了,提示: SQLSTATE[HY000] [2002] No such file or directory

解决方法就是:在database.php中奖localhost改为127.0.0.1就好了。