件,该服务器既没有配置ftp服务器,也没有做共享,无法通过常规途径获得文件时,只需要通过简单的scp命令便可达到目的。
一、 Linux ssh scp 的使用方法
如图通过root用户登录远程服务器,输入yes表示同意建立ssh连接
2:将本地目录上传到远程服务器上:
-r 参数表示递归复制(即复制该目录下面的文件和目录);/home/test/表示准备要上传的目录,root@10.20.61.160:/etc/test表示使用root用户登录远程服务器,:/etc/test 表示保存在远程服务器上的目录位置。
10.20.61.160 远程服务器的 ip地址(当然也可以使用该服务器域名ip地址)
/usr/local/sin.sh 欲复制到本机的位于远程服务器上的文件
/home/testr 将远程文件复制到本地的绝对路径
r 参数表示递归复制(即复制该目录下面的文件和目录);root@www.vpser.net 表示使用root用户登录远程服务器www.vpser.net,:/user/local/ 表示远程服务器上的目录,最后面的/home/test/表示保存在本地上的路径。
5、可能有用的几个参数 :
-v 和大多数 linux 命令中的 -v 意思一样 , 用来显示进度 . 可以用来查看连接 , 认证 , 或是配置错误 .
-C 使能压缩选项 .
-4 强行使用 IPV4 地址 .
-6 强行使用 IPV6 地址
注意两点:
1.如果远程服务器防火墙有特殊限制,scp便要走特殊端口,具体用什么端口视情况而定,命令格式如下:
#scp -p 4588 remote@www.abc.com:/usr/local/sin.sh /home/administrator
2.使用scp要注意所使用的用户是否具有可读取远程服务器相应文件的权限。
1. ssh登录基本命令为
ssh 192.168.1.1
表示登录到192.168.1.1主机
2. 删除ssh中旧的RSA key
登陆过的服务器的RSA公钥保存在.ssh/known_hosts中,由于更换了服务器,使用了相同IP,这会导致公钥与服务器的私钥配对失败,无法登陆服务器。这时候需要删除旧服务器(192.168.1.254)的公钥才行,操作如下:
ssh-keygen -f "~/.ssh/known_hosts" -R 192.168.1.254
3. 使用scp命令传送文件
scp的基本命令格式为:
$scp [user1@]host1:]file1 [user2@]host2:]file2
将把host1的file1传送到host2的file2
scp传送目录/文件夹命令加上-r选项
$scp -r [user1@]host1:]folder1 [user2@]host2:]folder2
4. scp的简单优化
在选项中加入-C选项,C是大写,这个选项指明使用压缩传输方式,传输速率会有很大提升
5. ssh可以登录,但是scp不能使用
我自己的经验是scp命令格式写错了,我当时是把要传送的文件名写到了scp的选项的前面,应当先写选项然后才是源文件,目标文件
6. ssh直接远程执行命令
ssh root@192.168.1.1 ls -l
如果执行的命令需要使用sudo权限,那么这么写
ssh root@192.168.1.1 sudo -S mkdir test
要加上大写的S选项,否则会报错sudo: no tty present and no askpass program specified