服务器的免密登录和文件传输

在天文学研究中,通常会采用ssh登录服务器,把复杂的计算交给服务器,但是如果你没有进行额外的配置,那么登录服务器,以及和服务器进行文件传输,每次都要输入账号和密码,比较不方便,Windows系统下可以使用MobaXterm,可以直接记住账号密码,登录的时候直接点击,传输文件也可以直接拖拽,但是linux和mac系统下并没有类似的成熟工具(或者说作者不知道),本文介绍一下如何在mac/linux系统下与服务器进行免密登录和文件传输

  1. 使用ssh生成公钥和秘钥

在你电脑中的terminal也就是命令行运行如下命令

bash 复制代码
ssh-keygen -t rsa

这会在.ssh文件夹下生成一个id_rsa文件和id_rsa.pub文件

  1. 把公钥上传到服务器的.ssh文件夹中

先使用scp命令把你的公钥上传到服务器里,也就是id_rsa.pub文件

接下来检查一下你服务器端的账号是否有.ssh/authorized_keys文件,如果有,使用如下命令把id_rsa.pub文件追加到该文件中

bash 复制代码
cat id_rsa.pub >> ~/.ssh/authorized_keys

如果没有.ssh文件夹,就使用mkdir .ssh来建立.ssh文件夹,如果没有authorized_keys,就使用

bash 复制代码
touch .ssh/authorized_keys

建立该文件,然后使用

bash 复制代码
cat id_rsa.pub > ~/.ssh/authorized_keys

把公钥写入.ssh/authorized_keys中,之后保存,退出服务器,以后就可以实现无密码登录和文件传输

  1. ssh配置

完成第1步和第2步之后,虽然不用输密码了,但是你还需要输入账号和服务器的IP,这个问题我们可以通过写ssh的配置文件来实现更加简单的登录和文件传输

在本地的电脑中打开.ssh/config文件,如果没有就新建一个,只要位置和文件名对了就行

在里面写入类似我这样子的配置

这里Host后面是你自己起的一个简称,HostName是服务器的IP,Port是服务器登录的端口,默认是22,如果你的服务器修改过可能不是,可以联系你服务器的管理人员获得IP和Port,User是你在服务器的账号,剩下的不要动,写好后保存退出即可

接下来你登录服务器,只需要在本地电脑上写

bash 复制代码
ssh yuan

即可直接登录服务器,无需再输入额外的任何东西,这里执行后可能会报错,因为有些服务器没有打开X11服务的支持,就会拒绝你的登录,那你就把最后面三行删掉就可以了

如果你想要传输文件,那么只需要执行

bash 复制代码
scp test.py yuan:/home/xushuai

如果下载就是

bash 复制代码
scp yuan:/home/xushuai/test.py /Users/xushuai

无需输入任何其他的东西,只需要写清楚本地和远程的文件位置即可,非常方便

相关推荐
桌面运维家5 小时前
IDV云桌面vDisk机房网络管控访问限制部署方案
运维·服务器·网络
ShineWinsu5 小时前
对于Linux:动静态库的制作与原理的解析—下
linux·运维·服务器·进程·链接·虚拟地址空间·
RH2312116 小时前
2026.4.16Linux 管道
java·linux·服务器
handler017 小时前
Linux: 基本指令知识点(2)
linux·服务器·c语言·c++·笔记·学习
Web极客码7 小时前
深入了解WordPress网站访客意图
服务器·前端·wordpress
KKKlucifer7 小时前
国内堡垒机如何打通云网运维安全一体化
运维·安全
橙子也要努力变强7 小时前
Linux信号机制
linux·服务器·网络
wydd99_lll8 小时前
docker特权模式下逃逸
运维·docker·容器
pengyi8710158 小时前
私网IP映射公网基础原理,搭配代理IP远程访问入门
linux·服务器·网络
mseaspring8 小时前
一款用于监控跨多台主机 Docker 容器的实时终端
运维·docker·容器