shell脚本实现服务器免密登录

需求:半自动化实现服务器免密登录(需要手动输入密码)

知识点解析

复制代码
#生成一个数组,存储服务器的ip,配置几个服务器就写几个
SERVERS=("服务器1的地址" "服务器2的地址" "服务器3的地址")

把本机的 id_rsa.pub 公钥,自动追加到远程服务器用户的 ~/.ssh/authorized_keys 文件里。

id_rsa

SSH 生成的 RSA 算法私钥文件,和它配对的公钥文件是 id_rsa.pub,它们是免密登录的基础:

  • 私钥 id_rsa:必须保存在本机,相当于你的 "钥匙",绝对不能泄露给别人

  • 公钥 id_rsa.pub:可以分发到远程服务器,相当于服务器上的 "锁孔",只有你的私钥能打开它

    [ ! -f HOME/.ssh/id_rsa ] && ssh-keygen -t rsa -N "" -f HOME/.ssh/id_rsa

复制代码
ssh-copy-id -o StricHostKeyChecking=no $USER@server

ssh-copy-id

把本地的公钥上传到远程服务器的工具,会自动写入远程用户的~/.ssh/authorized_keys文件
-o StrictHostKeyChecking=no

关闭主机密钥检查,首次连接服务器时,不会弹出 "是否信任主机" 的交互式确认提示,避免脚本卡住
USER@server

远程服务器的登录信息,$USER是用户名(这里是 root),$server是服务器 IP 地址(比如 192.168.88.101)显示出来就是root@192.168.88.101

完整脚本

⚠️ 重要注意事项

  • 远程服务器必须开启 SSH 服务,且防火墙允许 22 端口。

  • 脚本中使用的 root 用户,需要确保远程服务器允许 root 用户 SSH 登录(部分服务器默认关闭)。

    1. 检查 SSH 服务状态

    systemctl status sshd

    2. 如果没开启,启动服务

    systemctl start sshd

    3. 设置开机自启(避免重启后失效)

    systemctl enable sshd

firewalld(CentOS/RHEL 系列默认)

复制代码
# 1. 放行 22 端口
firewall-cmd --permanent --add-port=22/tcp

# 2. 重载防火墙规则(让配置生效)
firewall-cmd --reload

# 3. 验证端口是否放行成功
firewall-cmd --list-ports

vim mianmi.sh

#!/bin/bash
SERVERS=("192.168.88.101" "192.168.88.102" "192.168.88.103")
USER="root"

[ ! -f $HOME/.ssh/id_rsa ] && ssh-keygen -t rsa -N "" -f $HOME/.ssh/id_rsa

for server in "${SERVERS[@]}"
do      
        echo "开始配置免密登录: $server"
        ssh-copy-id -o StrictHostKeyChecking=no $USER@server
done    
复制代码
chmod +x mianmi.sh
./mianmi.sh

看一下有没有生效

复制代码
ssh root@192.168.88.102
相关推荐
AlfredZhao1 天前
生产环境里,为什么不建议把普通端口直接暴露到公网?
linux·https·443·80
戴为沐2 天前
Linux内存扩容指南
linux
zylyehuo3 天前
Linux 彻底且安全地删除文件
linux
用户805533698033 天前
主线 U-Boot 上 RK3506:和闭源 rkbin 拔河的三个隐性契约
linux·嵌入式
用户034095297913 天前
linux fcitx 5 雾凇拼音 设置在中文输入法下仍然输入英文标点
linux
乘云数字DATABUFF3 天前
5分钟部署开源APM Databuff:OpenTelemetry全链路追踪入门实战
运维·后端
Web3探索者5 天前
可视化服务器管理和传统命令行区别是什么?新手教程:Linux 运维到底该用图形界面还是 SSH 命令行?
linux·ssh
zylyehuo5 天前
Linux系统中网线与USB网络共享冲突
linux
荣--5 天前
一键部署不是为了省时间 —— 它是把"买来的 PaaS"变成"自己的平台"的拐点
运维·zabbix·工程化·一键部署·平台化·边界设计
江华森5 天前
动手实战学 Docker — 从零到集群编排完全指南
运维