您的位置:首页 > 运维架构 > Linux

Linux实用工具(一)

2016-06-15 19:13 218 查看

rsync

是一个功能强大的同步工具。

cmd 格式

 rsync [OPTION]… SRC DEST

 rsync [OPTION]… SRC [USER@]HOST:DEST

 rsync [OPTION]… [USER@]HOST:SRC DEST

 rsync [OPTION]… [USER@]HOST::SRC DEST

 rsync [OPTION]… SRC [USER@]HOST::DEST

 rsync [OPTION]… rsync://[USER@]HOST[:PORT]/SRC [DEST]

1)拷贝本地文件。当SRC和DES路径信息都不包含有单个冒号”:”分隔符时就启动这种工作模式。如:rsync -a /data /backup

2)使用一个远程shell程序(如rsh、ssh)来实现将本地机器的内容拷贝到远程机器。当DST路径地址包含单个冒号”:”分隔符时启动该模式。如:rsync -avz *.c foo:src

3)使用一个远程shell程序(如rsh、ssh)来实现将远程机器的内容拷贝到本地机器。当SRC地址路径包含单个冒号”:”分隔符时启动该模式。如:rsync -avz foo:src/bar /data

4)从远程rsync服务器中拷贝文件到本地机。当SRC路径信息包含”::”分隔符时启动该模式。如:rsync -av root@172.16.78.192::www /databack

5)从本地机器拷贝文件到远程rsync服务器中。当DST路径信息包含”::”分隔符时启动该模式。如:rsync -av /databack root@172.16.78.192::www

6)列远程机的文件列表。这类似于rsync传输,不过只要在命令中省略掉本地机信息即可。如:rsync -v rsync://172.16.78.192/www

参数详解

-v, - -verbose 详细模式输出

-q, - -quiet 精简输出模式

-c, - -checksum 打开校验开关,强制对文件传输进行校验

-a, - -archive 归档模式,表示以递归方式传输文件,并保持所有文件属性,等于-rlptgoD

-r, - -recursive 对子目录以递归模式处理

-R, - -relative 使用相对路径信息

-b, - -backup 创建备份,也就是对于目的已经存在有同样的文件名时,将老的文件重新命名为~filename。可以使用–suffix选项来指定不同的备份文件前缀。

- -backup-dir 将备份文件(如~filename)存放在在目录下。
-suffix=SUFFIX 定义备份文件前缀

-u, - -update 仅仅进行更新,也就是跳过所有已经存在于DST,并且文件时间晚于要备份的文件。(不覆盖更新的文件)

-l, - -links 保留软链结

-L, - -copy-links 想对待常规文件一样处理软链结

- -copy-unsafe-links 仅仅拷贝指向SRC路径目录树以外的链结

- -safe-links 忽略指向SRC路径目录树以外的链结

-H, - -hard-links 保留硬链结

-p, - -perms 保持文件权限

-o, - -owner 保持文件属主信息

-g, - -group 保持文件属组信息

-D, - -devices 保持设备文件信息

-t, - -times 保持文件时间信息

-S, - -sparse 对稀疏文件进行特殊处理以节省DST的空间

-n, - -dry-run现实哪些文件将被传输

-W, - -whole-file 拷贝文件,不进行增量检测

-x, - -one-file-system 不要跨越文件系统边界

-B, - -block-size=SIZE 检验算法使用的块尺寸,默认是700字节

-e, - -rsh=COMMAND 指定使用rsh、ssh方式进行数据同步

- -rsync-path=PATH 指定远程服务器上的rsync命令所在路径信息

-C, - -cvs-exclude 使用和CVS一样的方法自动忽略文件,用来排除那些不希望传输的文件

- -existing 仅仅更新那些已经存在于DST的文件,而不备份那些新创建的文件

- -delete 删除那些DST中SRC没有的文件

- -delete-excluded 同样删除接收端那些被该选项指定排除的文件

- -delete-after 传输结束以后再删除

- -ignore-errors 及时出现IO错误也进行删除

- -max-delete=NUM 最多删除NUM个文件

- -partial 保留那些因故没有完全传输的文件,以是加快随后的再次传输

- -force 强制删除目录,即使不为空

- -numeric-ids 不将数字的用户和组ID匹配为用户名和组名

- -timeout=TIME IP超时时间,单位为秒

-I, - -ignore-times 不跳过那些有同样的时间和长度的文件

- -size-only 当决定是否要备份文件时,仅仅察看文件大小而不考虑文件时间

- -modify-window=NUM 决定文件是否时间相同时使用的时间戳窗口,默认为0

-T - -temp-dir=DIR 在DIR中创建临时文件

- -compare-dest=DIR 同样比较DIR中的文件来决定是否需要备份
-P 等同于 - -partial

- -progress 显示备份过程

-z, - -compress 对备份的文件在传输时进行压缩处理

- -exclude=PATTERN 指定排除不需要传输的文件模式

- -include=PATTERN 指定不排除而需要传输的文件模式

–exclude-from=FILE 排除FILE中指定模式的文件

- -include-from=FILE 不排除FILE指定模式匹配的文件

- -version 打印版本信息

- -address 绑定到特定的地址

- -config=FILE 指定其他的配置文件,不使用默认的rsyncd.conf文件

- -port=PORT 指定其他的rsync服务端口

- -blocking-io 对远程shell使用阻塞IO

-stats 给出某些文件的传输状态

- -progress 在传输时现实传输过程

- -log-format=formAT 指定日志文件格式

- -password-file=FILE 从FILE中得到密码

- -bwlimit=KBPS 限制I/O带宽,KBytes per second

-h, - -help 显示帮助信息

scp

cmd 格式

scp是secure copy的简写,用于在Linux下进行远程拷贝文件的命令,和它类似的命令有cp,不过cp只是在本机进行拷贝不能跨服务器,而且scp传输是加密的。

scp [可选参数] file_source file_target

参数详解

-1 强制scp命令使用协议ssh1

-2 强制scp命令使用协议ssh2

-4 强制scp命令只使用IPv4寻址

-6 强制scp命令只使用IPv6寻址

-B 使用批处理模式(传输过程中不询问传输口令或短语)

-C 允许压缩。(将-C标志传递给ssh,从而打开压缩功能)

-p 保留原文件的修改时间,访问时间和访问权限。

-q 不显示传输进度条。

-r 递归复制整个目录。

-v 详细方式显示输出。scp和ssh(1)会显示出整个过程的调试信息。这些信息用于调试连接,验证和配置问题。

-c cipher 以cipher将数据传输进行加密,这个选项将直接传递给ssh。

-F ssh_config 指定一个替代的ssh配置文件,此参数直接传递给ssh。

-i identity_file 从指定文件中读取传输时使用的密钥文件,此参数直接传递给ssh。

-l limit 限定用户所能使用的带宽,以Kbit/s为单位。

-o ssh_option 如果习惯于使用ssh_config(5)中的参数传递方式,

-P port 注意是大写的P, port是指定数据传输用到的端口号

-S program 指定加密传输时所使用的程序。

sftp

cmd 格式

scp是secure copy的简写,用于在Linux下进行远程拷贝文件的命令,和它类似的命令有cp,不过cp只是在本机进行拷贝不能跨服务器,而且scp传输是加密的。

登陆:sftp <user>@< host>

加l表示操作本地

下载:get [-Ppr] remote [local]

上传:put [-Ppr] local [remote]

注:在文件夹名dirname后加上’/’,传输后,目标位置没有新建文件夹dirname,只有dirname文件夹下的各个文件。

在文件夹名dirname后不加’/’,传输后,目标位置新建文件夹dirname,所有文件位置新建文件夹dirname下。

ssh 远程脚本

cmd 格式

ssh [options][remote host][command]

参数详解

usage: ssh [-1246AaCfgKkMNnqsTtVvXxYy] [-b bind_address] [-c cipher_spec]
[-D [bind_address:]port] [-e escape_char] [-F configfile]
[-I pkcs11] [-i identity_file]
[-L [bind_address:]port:host:hostport]
[-l login_name] [-m mac_spec] [-O ctl_cmd] [-o option] [-p port]
[-R [bind_address:]port:host:hostport] [-S ctl_path]
[-W host:port] [-w local_tun[:remote_tun]]
[user@]hostname [command]


-l 指定登入用户

-p 设置端口号

-f 后台运行,并推荐加上 -n 参数

-n 将标准输入重定向到 /dev/null,防止读取标准输入

-N 不执行远程命令,只做端口转发

-q 安静模式,忽略一切对话和错误提示

-T 禁用伪终端配置

内容来自用户分享和网络整理,不保证内容的准确性,如有侵权内容,可联系管理员处理 点击这里给我发消息
标签: