10分钟掌握!如何在Linux系统中实现无密码使用私钥SSH远程连接

文章目录

    • 前言
    • [1. Linux 生成SSH秘钥对](#1. Linux 生成SSH秘钥对)
    • [2. 修改SSH服务配置文件](#2. 修改SSH服务配置文件)
    • [3. 客户端秘钥文件设置](#3. 客户端秘钥文件设置)
    • [4. 本地SSH私钥连接测试](#4. 本地SSH私钥连接测试)
    • [5. Linux安装Cpolar工具](#5. Linux安装Cpolar工具)
    • [6. 配置SSHTCP公网地址](#6. 配置SSHTCP公网地址)
    • [7. 远程SSH私钥连接测试](#7. 远程SSH私钥连接测试)
    • [8. 固定SSH公网地址](#8. 固定SSH公网地址)
    • [9. 固定SSH地址测试](#9. 固定SSH地址测试)

前言

在当今数字化的时代,企业对于各类技术的需求就如同武侠世界中那些令人眼花缭乱的秘籍一样,不断涌现,层出不穷。远程办公也迅速成为了一种主流趋势,非常多的企业都投身其中。然而,就在大家尽情享受云上办公带来的便捷与高效时,一个令人头疼的问题却悄然浮现 ------ 传统的密码登录方式实在是漏洞百出!它不仅极易成为黑客攻击的突破口,还可能因为员工一时的疏忽大意而发生信息泄露,给企业的信息安全蒙上了一层厚厚的阴影,带来了巨大的风险。

那么,在这种既要保证工作效率,又要确保数据安全的双重需求下,究竟该如何破局呢?其实,答案简单得让人意想不到 ------ 采用私钥进行身份验证,并且搭配一款超级强大的内网穿透工具。今天,就让我们来深入探讨一下,如何借助 Cpolar 这一神器,让你的远程服务器管理变得更加安全可靠,同时又酷炫十足,轻松解决远程办公中的诸多烦恼,为企业在数字化浪潮中保驾护航。

1. Linux 生成SSH秘钥对

本地ssh连接上Linux ,执行ssh-keygen -t rsa 命令生成秘钥对,执行命令后,一路回车即可,执行完成后,我们可以看到生成的秘钥的文件都放在/root/.ssh/这个文件夹下面(具体以自己的路径为准)

生成后,我们执行:cd ~/.ssh 命令进入这个文件夹,然后列出目录,可以看到有两个文件,第一个是私钥 第二个.pub结尾是公钥

然后我们把公钥.pub结尾的那个文件改个名称,执行下面命令,把id_rsa.pub改为authorized_keys

shell 复制代码
mv id_rsa.pub authorized_keys

修改后,我们再次查看列表,id_rsa.pub文件变成了authorized_keys,这样就修改成功了,接下来我们修改一下ssh配置文件

2. 修改SSH服务配置文件

上面秘钥对生成设置好后,我们打开ssh 配置文件,输入命令:vim /etc/ssh/sshd_config,按i 键进入编辑,然后开启公钥验证,把密码验证改为no,表示关闭,然后记得保存

然后重启一下ssh服务,下面我们开始在windows设置连接

shell 复制代码
systemctl restart sshd

3. 客户端秘钥文件设置

本例是使用windows来连接Linux,我们需要在windows设置一下Linux的私钥,首先回到Linux,在Linux中我们输入下面命令查看id_rsa私钥内容

shell 复制代码
cat ~/.ssh/id_rsa

执行命令后,我们可以看到这个id_rsa私钥文件的全部内容,把这些内容全部复制下来

然后我们在windows任意文件夹下,这个文件夹路径自己要知道,比如我这边是放在E:/ssh/文件夹下面,具体以自己设置为准,然后创建一个名称为id_rsa的文件.不用指定后缀

创建好后,我们用记事本或者文本工具打开,把我们在Linux上看到的那个秘钥文件的内容全部粘贴进去,然后保存

接下来设置这个秘钥文件的权限,缩小权限的范围,选中右键点击属性,打开安全,点击高级

首先点击禁用继承

然后点击选择第一个选项

然后我们把这些全部的权限一个个删除掉,全部删掉

全部删除后我们点击添加一个用户权限

然后点击选择主体,输入自己电脑用户名,再点击确定按钮

然后会默认勾选两个权限,直接点击确定即可

然后我们可以看到添加了一个用户权限,直接点击应用再点击确定即可

再点击确定就全部设置完成了,下面我们就可以本地测试连接了

4. 本地SSH私钥连接测试

首先我们本地输入ssh 用户名@局域网IP 测试,可以看到 密码的方式已经无法连接了

现在我们加上指定秘钥文件路径再次连接,命令格式ssh 用户名@局域网IP -i 秘钥文件全路径,可以看到成功连接上了Linux.其中 -i E/ssh/id_rsa 这个参数就是指定我们上面在windows创建设置的秘钥文件全路径.本地测试就成功了,这样Linux ssh连接就设置只能秘钥登录,无法使用密码登录,极大的提高了安全性,下面我们在Linux安装cpolar,实现远程也可以连接访问

5. Linux安装Cpolar工具

上面在本地成功设置了无密码使用私钥方式ssh 连接,并本地局域网测试成功,下面我们在Linux安装Cpolar内网穿透工具,通过Cpolar 转发本地端口创建公网地址,我们可以很容易实现远程访问,而无需自己注册域名购买云服务器.下面是安装cpolar步骤

cpolar官网地址: https://www.cpolar.com

  • 使用一键脚本安装命令
shell 复制代码
sudo curl https://get.cpolar.sh | sh
  • 安装完成后,可以通过如下方式来操作cpolar服务,首先执行加入系统服务设置开机启动,然后再启动服务
shell 复制代码
# 加入系统服务设置开机启动
sudo systemctl enable cpolar

# 启动cpolar服务
sudo systemctl start cpolar

# 重启cpolar服务
sudo systemctl restart cpolar

# 查看cpolar服务状态
sudo systemctl status cpolar

# 停止cpolar服务
sudo systemctl stop cpolar

Cpolar安装和成功启动服务后,内部或外部浏览器上通过局域网IP加9200端口即:【http://192.168.xxx.xxx:9200】访问Cpolar管理界面,使用Cpolar官网注册的账号登录,登录后即可看到cpolar web 配置界面,接下来在web 界面配置即可

6. 配置SSHTCP公网地址

登录cpolar web UI管理界面后,点击左侧仪表盘的隧道管理------创建隧道:

  • 隧道名称:可自定义,注意不要与已有的隧道名称重复
  • 协议:tcp
  • 本地地址:22 (ssh 默认端口)
  • 域名类型:临时随机TCP端口 (首次使用 选择随机地址测试)
  • 地区:选择China vip

点击创建 (注意点击一次即可!)

然后打开左侧在线隧道列表,查看刚刚创建隧道后生成的远程 TCP连接地址,这个地址就是远程连接的地址,在其他设备上使用该地址进行远程连接,下面进行远程地址连接测试

7. 远程SSH私钥连接测试

创建好公网地址后,我们打开cmd窗口 ,使用公网地址进行连接,输入命令格式:ssh 用户名@cpolar公网域名 -p 域名对应的端口 点击回车,我们可以看到,同样密码的方式已经无法连接了

下面我们指定一下私钥文件全路径,可以看到成功连接上了Linux,不需要输入密码,同时也是公网连接,如果其他电脑要连接Linux,我们只要把这个私钥文件拷贝去其他电脑,在连接的时候指定这个私钥文件全路径,就可以在其他电脑进行远程连接Linux了,到这里初步设置就全部完成了!

小结

为了更好地演示,我们在前述过程中使用了Cpolar生成的隧道,其公网地址是随机生成的。这种随机地址的优势在于建立速度快,可以立即使用。然而,它的缺点是网址是随机生成,这个地址在24小时内会发生随机变化,更适合于临时使用。

我一般会使用固定TCP域名,原因是我希望将地址发送给同事或客户时,它是一个固定、易记的公网地址,这样更显正式,便于交流协作。

8. 固定SSH公网地址

上面步骤在cpolar中使用的是随机临时tcp端口地址,所生成的公网地址为随机临时地址,该公网地址24小时内会随机变化。我们接下来为其配置固定的TCP端口地址,该地址不会变化,设置后将无需每天重复修改地址。

登录Cpolar官网,点击左侧的预留,找到保留的tcp地址,我们来为远程联机地址保留一个固定的地址:

  • 地区:选择China vip
  • 描述:即备注,可自定义

点击保留

地址保留成功后,系统会生成相应的固定公网地址,将其复制下来

再次打开cpolar web ui管理界面,点击左侧仪表盘的隧道管理------隧道列表,找到我们上面创建的TCP隧道,点击右侧的编辑

修改隧道信息,将保留成功的固定tcp地址配置到隧道中

  • 端口类型:修改为固定tcp端口
  • 预留的TCP地址:填写官网保留成功的地址,

点击更新(只需要点击一次更新即可,不要重复点击)

隧道更新成功后,点击左侧仪表盘的状态------在线隧道列表,可以看到公网地址已经更新成为了和我们在官网固定的TCP地址和端口一致。这样表示地址已经成功固定了,下面测试固定地址连接

9. 固定SSH地址测试

固定地址设置好后,我们再次使用固定的tcp地址进行连接,同样也需要指定私钥文件全路径,可以看到,成功连接上了Linux ,固定地址测试连接就完成了,不用再担心地址端口会变化了.

有了私钥认证和Cpolar这样的神器加持,不仅能让你的信息系统安全性直线飙升,还能让远程办公变得轻松愉快。希望这篇文章能帮你在数字化转型的路上走得更加稳健。如果你对这些技术有任何疑问或需要更多秘籍,请在评论区留言,我们保证第一时间为你答疑解惑!别忘了点赞、关注和分享哦,让我们一起成为远程工作的江湖高手,笑傲云上江湖!

相关推荐
技术小齐10 分钟前
网络运维学习笔记(DeepSeek优化版)008网工初级(HCIA-Datacom与CCNA-EI)STP生成树协议与VRRP虚拟路由冗余协议
运维·网络·学习
亿佛12 分钟前
自动驾驶平行仿真(基础课程一)
人工智能·机器学习·自动驾驶
Sundayday4723 分钟前
1、CI/CD 平台安装部署(Gitlab+Jenkins)
运维·ci/cd·centos·gitlab·jenkins
AI云极26 分钟前
字节跳动发布 Trae AI IDE!支持 DeepSeek R1 & V3,AI 编程新时代来了!
ide·人工智能
RedefineLim.36 分钟前
Kneser-Ney平滑在自然语言处理中的应用
人工智能·自然语言处理
shelutai38 分钟前
ubuntu 启动不起来,光标闪烁 解决方法
linux·运维·ubuntu
小萌新~~~~1 小时前
Linux常见操作命令以及编辑器VI命令
linux·运维·服务器
神秘的土鸡1 小时前
Linux中WgCloud的服务器与客户端监控系统(完整部署教程)
linux·运维·nginx·adb·监控·自动化运维
Python数据分析与机器学习1 小时前
《基于大数据的相州镇新农村商务数据分析与研究》开题报告
大数据·人工智能·python·算法·数据挖掘·数据分析
楼台的春风1 小时前
【高斯滤波器(Gaussian Filter)详解】
图像处理·人工智能·opencv·算法·计算机视觉·matlab·嵌入式