宝塔SSH公钥设置与免密登录教程
时间:2026-05-27 19:43:42 198浏览 收藏
本文详细讲解了如何在宝塔面板环境下绕过Web终端限制,安全、高效地配置SSH公钥认证以实现服务器免密登录,涵盖四种实用方法:通过文件管理器图形化上传并设置authorized_keys权限、使用宝塔终端执行命令部署密钥并验证sshd配置、借助计划任务批量同步公钥提升多机管理效率,以及在配置异常时利用系统快照精准还原sshd_config关键参数——无论你是Linux新手还是运维老手,都能找到适配自身场景的可靠方案,轻松提升服务器访问安全性与操作便捷性。

如果您在宝塔面板中希望为服务器配置SSH公钥认证以实现免密登录,则需绕过面板默认的Web终端限制,直接操作系统级SSH配置文件。以下是具体实施步骤:
一、通过宝塔文件管理器上传并配置authorized_keys
该方法利用宝塔内置的文件管理功能,将本地生成的公钥内容写入目标用户的授权密钥文件,无需命令行交互,适合不熟悉Linux终端操作的用户。
1、在本地电脑使用ssh-keygen生成密钥对,保留私钥(如id_rsa)并复制公钥内容(如id_rsa.pub中的全部文本)。
2、登录宝塔面板,进入【文件】→【/root】目录(若为非root用户,请进入对应用户的家目录,如/home/www)。
3、检查是否存在.ssh隐藏目录,若不存在,则点击右上角【新建目录】,输入.ssh并创建。
4、进入.ssh目录,点击【新建文件】,命名为authorized_keys。
5、点击该文件进入编辑界面,将本地复制的公钥内容完整粘贴进去,确保无换行缺失或多余空格,保存更改。
6、返回.ssh目录,选中authorized_keys文件,点击【权限】,设置权限值为600;再选中.ssh目录本身,设置权限值为700。
二、通过宝塔终端执行命令配置公钥
该方法适用于已开启宝塔终端且具备sudo权限的场景,通过标准Linux命令完成密钥部署,过程可控性强,能即时验证路径与权限状态。
1、在宝塔面板中打开【终端】,确认当前用户为root或具有sudo权限的用户。
2、执行命令创建SSH目录:mkdir -p ~/.ssh。
3、执行命令设置目录权限:chmod 700 ~/.ssh。
4、执行命令生成空白authorized_keys文件并写入公钥(假设公钥内容已复制到剪贴板):echo "your_public_key_content_here" >> ~/.ssh/authorized_keys(请将your_public_key_content_here替换为实际公钥字符串,含ssh-rsa开头部分)。
5、执行命令设置密钥文件权限:chmod 600 ~/.ssh/authorized_keys。
6、执行命令检查sshd服务配置是否允许公钥认证:grep -E '^(PubkeyAuthentication|AuthorizedKeysFile)' /etc/ssh/sshd_config,确认输出中包含PubkeyAuthentication yes及AuthorizedKeysFile .ssh/authorized_keys。
三、使用宝塔计划任务自动同步公钥
该方法适用于多台服务器统一管理场景,通过定时任务将预置公钥文件同步至各主机的对应位置,避免逐台手工操作,提升批量部署效率。
1、在宝塔面板中进入【计划任务】→【添加计划任务】。
2、任务类型选择Shell脚本,执行周期设为一次性立即执行(后续可按需调整)。
3、在脚本内容框中输入以下命令(请预先将公钥内容存为/root/mykey.pub):mkdir -p /root/.ssh && cp /root/mykey.pub /root/.ssh/authorized_keys && chmod 700 /root/.ssh && chmod 600 /root/.ssh/authorized_keys。
4、点击【添加任务】,然后在任务列表中找到该项,点击【运行】按钮触发执行。
5、执行完成后,在终端中运行ls -l /root/.ssh/authorized_keys,确认文件存在且权限显示为-rw-------。
四、通过宝塔数据库管理间接注入公钥配置
该方法仅限特殊场景:当SSH服务被误关闭且无法通过常规方式恢复时,可借助宝塔备份的系统配置快照还原关键SSH配置片段,其中可能包含已启用的公钥路径定义。
1、进入宝塔面板【备份】→【系统快照】,查找最近一次包含/etc/ssh/sshd_config变更的快照记录。
2、点击该快照右侧【还原】,在弹出窗口中勾选/etc/ssh/sshd_config单项,取消其他所有选项。
3、确认还原操作,等待进度条完成。
4、还原后立即在终端中执行:systemctl restart sshd,确保新配置加载生效。
5、再次运行:grep PubkeyAuthentication /etc/ssh/sshd_config,验证输出是否为PubkeyAuthentication yes。
以上就是本文的全部内容了,是否有顺利帮助你解决问题?若是能给你带来学习上的帮助,请大家多多支持golang学习网!更多关于文章的相关知识,也可关注golang学习网公众号。
-
501 收藏
-
501 收藏
-
501 收藏
-
501 收藏
-
501 收藏
-
150 收藏
-
293 收藏
-
351 收藏
-
364 收藏
-
426 收藏
-
321 收藏
-
116 收藏
-
393 收藏
-
359 收藏
-
196 收藏
-
216 收藏
-
188 收藏
-
- 前端进阶之JavaScript设计模式
- 设计模式是开发人员在软件开发过程中面临一般问题时的解决方案,代表了最佳的实践。本课程的主打内容包括JS常见设计模式以及具体应用场景,打造一站式知识长龙服务,适合有JS基础的同学学习。
- 立即学习 543次学习
-
- GO语言核心编程课程
- 本课程采用真实案例,全面具体可落地,从理论到实践,一步一步将GO核心编程技术、编程思想、底层实现融会贯通,使学习者贴近时代脉搏,做IT互联网时代的弄潮儿。
- 立即学习 516次学习
-
- 简单聊聊mysql8与网络通信
- 如有问题加微信:Le-studyg;在课程中,我们将首先介绍MySQL8的新特性,包括性能优化、安全增强、新数据类型等,帮助学生快速熟悉MySQL8的最新功能。接着,我们将深入解析MySQL的网络通信机制,包括协议、连接管理、数据传输等,让
- 立即学习 500次学习
-
- JavaScript正则表达式基础与实战
- 在任何一门编程语言中,正则表达式,都是一项重要的知识,它提供了高效的字符串匹配与捕获机制,可以极大的简化程序设计。
- 立即学习 487次学习
-
- 从零制作响应式网站—Grid布局
- 本系列教程将展示从零制作一个假想的网络科技公司官网,分为导航,轮播,关于我们,成功案例,服务流程,团队介绍,数据部分,公司动态,底部信息等内容区块。网站整体采用CSSGrid布局,支持响应式,有流畅过渡和展现动画。
- 立即学习 485次学习