1, 无密码SSH登录
ssh-copy-id user@host
ssh-keygen命令可生成密钥。
一句话登陆: ssh-keygen; ssh-copy-id user@host; ssh user@host
2, 上传 下载
上传:
scp 源文件 用户名@主机:目的文件名
scp -r 原文件夹 用户名@主机:目的文件夹 (递归复制)
-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 指定加密传输时所使用的程序。此程序必须能够理解ssh(1)的选项。
下载:
scp 用户名@主机:path 本地path
选项同上传
3, 比较远程和本地文件
ssh user@host cat /path/to/remotefile | diff /path/to/localfile –
4, 通过SSH远程执行shell命令
ssh host -l user "`cat cmd.txt`"
5 将文件中的数据重定向
ssh user@host 'cat >> list' < file
6 压缩功能
ssh -C user@host commonds
7, 通过SSH将MySQL数据库复制到新服务器
mysqldump –add-drop-table –extended-insert –force –log-error=error.log -uUSER -pPASS OLD_DB_NAME | ssh -C user@newhost "mysql -uUSER -pPASS NEW_DB_NAME"