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

在天文学研究中,通常会采用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

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

相关推荐
SkyXZ~35 分钟前
Jetson有Jtop,Linux有Htop,RDK也有Dtop!
linux·运维·服务器·rdkx5·rdks100·dtop
黑牛儿1 小时前
MySQL 索引实战详解:从创建到优化,彻底解决查询慢问题
服务器·数据库·后端·mysql
舒一笑2 小时前
一次“翻车”的部署,让我看清了技术、权力和职场的真相
运维·程序员·创业
杨云龙UP2 小时前
Oracle Data Pump实战:expdp/impdp常用参数与导入导出命令整理_20260406
linux·运维·服务器·数据库·oracle
想唱rap2 小时前
线程池以及读写问题
服务器·数据库·c++·mysql·ubuntu
我科绝伦(Huanhuan Zhou)3 小时前
分享一个服务故障自愈系统
运维·人工智能·自动化
失伟4 小时前
Stratovirt安装及使用
运维·虚拟化
萌萌哒草头将军4 小时前
CloudDock(云仓):新一代开源NAS网络代理工具
服务器·网络协议·docker
捧月华如5 小时前
Linux 系统性能压测工具全景指南(含工程实战)
linux·运维·服务器
s19134838482d5 小时前
vlan实验报告
运维·服务器·网络