Remote SSH连接方法
方法一 MobaXterm
在MobaXterm连接remote可以直接指定IP地址,对应的端口以及用户名、密码,直接连接即可。同时,如果连接错误也会显示对应的问题(对应的IP或端口不存在也会显示Connection Refused)
方法二 VSCode+RSA免密登录
首先需要安装VSCode的remote ssh扩展,之后就可以尝试连接ssh remote服务器,可以在选择连接之后打开ssh配置文件进行设置,默认存在C:\Users\name.ssh\config中
格式如下
Host 目标主机的别名
HostName IP地址
User 用户名
Port 端口号(ssh默认22)
IdentityFile 用于免密登录的私钥
可以看到是不能配置明文密码的,这样每次通过vscode连接remote和切换远程都需要重新输入密码,比较麻烦,因此可以对SSH进行免密登录配置
首先,在CMD中输入ssh-keygen -t rsa生成密钥(存储位置默认也是C:\Users\name.ssh)
然后,将目录下id_rsa.pub中的公钥内容复制到remote服务器中(linux位于/root/.ssh/authorized_keys,如果没有那么在服务器中输入 ssh localhost指令生成)
上面这个步骤也可以通过ssh-copy-id -i /root/.ssh/id_rsa.pub root@192.168.150.148完成,利用了SCP,但我的机器没有这个功能
最后,在VSCode config中的IdentityFile中加入对应的私钥地址即可,即为C:\Users\name.ssh\id_rsa
扩展 linuxSCP
Linux scp 命令用于 Linux 之间复制文件和目录。
scp 是 secure copy 的缩写, scp 是 linux 系统下基于 ssh 登陆进行安全的远程文件拷贝命令。
scp 是加密的,rcp 是不加密的,scp 是 rcp 的加强版。
语法
scp [-1246BCpqrv] [-c cipher] [-F ssh_config] [-i identity_file]
[-l limit] [-o ssh_option] [-P port] [-S program]
[[user@]host1:]file1 […] [[user@]host2:]file2
简易写法:
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: 指定加密传输时所使用的程序。此程序必须能够理解 ssh(1) 的选项。
2.2 实例
2.2.1、从本地复制到远程
命令格式:
scp local_file remote_username@remote_ip:remote_folder
或者
scp local_file remote_username@remote_ip:remote_file
或者
scp local_file remote_ip:remote_folder
或者
scp local_file remote_ip:remote_file
root@目标服务器ip
第 1,2 个指定了用户名,命令执行后需要再输入密码,第 1 个仅指定了远程的目录,文件名字不变,第 2 个指定了文件名;
第 3,4 个没有指定用户名,命令执行后需要输入用户名和密码,第 3 个仅指定了远程的目录,文件名字不变,第 4 个指定了文件名;
应用实例:
scp /home/space/music/1.mp3 root@ip地址:/home/root/others/music
scp /home/space/music/1.mp3 root@10.80.1.253:/home/root/others/music/001.mp3
scp /home/space/music/1.mp3 www.runoob.com:/home/root/others/music
scp /home/space/music/1.mp3 www.runoob.com:/home/root/others/music/001.mp3
复制目录命令格式:
scp -r local_folder remote_username@remote_ip:remote_folder
或者
scp -r local_folder remote_ip:remote_folder
第 1 个指定了用户名,命令执行后需要再输入密码;
第 2 个没有指定用户名,命令执行后需要输入用户名和密码;
应用实例:
scp -r /home/space/music/ root@www.runoob.com:/home/root/others/
scp -r /home/space/music/ www.runoob.com:/home/root/others/
上面命令将本地 music 目录复制到远程 others 目录下。
#进入 对应目录
scp -r mnt root@10.80.1.252:/www/algorithm/old_code
从远程复制到本地,只要将从本地复制到远程的命令的后 2 个参数调换顺序即可,如下实例
应用实例:
scp root@www.runoob.com:/home/root/others/music /home/space/music/1.mp3
scp -r www.runoob.com:/home/root/others/ /home/space/music/
如果远程服务器防火墙有为 scp 命令设置了指定的端口,我们需要使用 -P 参数来设置命令的端口号,命令格式如下:
#scp 命令使用端口号 4588
scp -P 4588 remote@www.runoob.com:/usr/local/sin.sh /home/administrator
使用 scp 命令要确保使用的用户具有可读取远程服务器相应文件的权限,否则 scp 命令是无法起作用的。
部分内容引自:
https://blog.csdn.net/sinat_39620217/article/details/139521611?utm_medium=distribute.pc_relevant.none-task-blog-2defaultbaidujs_baidulandingword~default-0-139521611-blog-131721687.235v43pc_blog_bottom_relevance_base4&spm=1001.2101.3001.4242.1&utm_relevant_index=1
https://blog.csdn.net/Oxford1151/article/details/137228119
https://blog.csdn.net/weixin_43551076/article/details/131721687?utm_medium=distribute.pc_relevant.none-task-blog-2defaultbaidujs_baidulandingword~default-0-131721687-blog-135903171.235%5Ev43%5Epc_blog_bottom_relevance_base1&spm=1001.2101.3001.4242.1&utm_relevant_index=3