Mac、Linux 上实现SSH免密码登陆到Linux服务器

正常登陆服务器是需要密码的,这对于需要频繁访问服务器的操作是不友好的。于是我们可以进行相关配置,通过 SSH 公钥实现免密码登陆。

步骤:

> 机器A:本地或远程的 Mac、Linux 机器
> 机器B:需要登录的Linux服务器
> 实现:从 机器A 免密码登录到 机器B

1、( 机器A上操作 )生成公钥/私钥对

执行命令,生成公钥/私钥对:
ssh-keygen -t rsa -P ''
-P表示密码,-P '' 就表示空密码
回车后,默认在 ~/.ssh/ 目录下生成:id_rsa(私钥) id_rsa.pub(公钥)

2、(机器A上操作)把公钥拷贝到服务器上

scp ~/.ssh/id_rsa.pub sam@192.168.0.100:/home/sam/.ssh/sam.pub
注意:sam@192.168.0.100 需要根据自己服务器用户和ip修改,sam.pub 为自定义的公钥文件名(方便管理)

3、(机器B上操作)把公钥内容添加到authorized_keys中

cat ~/.ssh/sam.pub >> ~/.ssh/authorized_keys
注意:authorized_keys 需要 600 权限
chmod 700 ~/.ssh
chmod 600 ~/.ssh/authorized_keys
完成以上操作,在 机器A 上则可以直接通过:ssh sam@192.168.0.100 登陆到机器B服务器,而不需要输入密码。

常见问题

常见问题:完成了SSH免密码登陆配置,仍然需要输入密码

可能一:权限导致的认证失败

检查 ~/.ssh 和 ~/.ssh/authorized_keys 权限是否正确
chmod 700 ~/.ssh
chmod 600 ~/.ssh/authorized_keys

可能二:SELinux的问题导致的认证失败

查看系统的日志文件( -n 50 最近50条 )
tail /var/log/secure -n 50
发现错误信息:
Jul 18 15:20:06 e1 sshd[32684]: Failed publickey for sam from 192.168.0.80 port 53665 ssh2

进行以下修复:

1、关闭SELinux
setenforce 0
2、修复/home目录的context
restorecon -r -vv /home/
3、打开SELinux
setenforce 1
重新连接SSH,认证成功,正常免密登陆。
可能二出现的原因,有可能是机器安装分区的时候发生了错误,/home目录上的context 异常,修复context即可。

版权声明:本文为博主原创文章,转载请注明出处。

转载于:https://my.oschina.net/magicalSam/blog/1466144

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值