Linux设置远程密钥登录并禁用密码登录

一、设置远程密钥登录

1.生成公钥和私钥

ssh-keygen

或者(效果相同)

ssh-keygen -t rsa

运行上面的命令后,系统会出现一系列提示,可以一路回车,例如:

[root@iZm5ef9dh7rrcbptrvly9bZ .ssh]# ssh-keygen
Generating public/private rsa key pair.
Enter file in which to save the key (/root/.ssh/id_rsa):(回车)
Enter passphrase (empty for no passphrase):(回车)
Enter same passphrase again:(回车)

注:如果不要对私钥设置口令(passphrase),如果担心私钥的安全,可以设置一个。没有特殊需求直接回车即可。

运行结束以后, 默认在 ~/.ssh目录生成两个文件:
id_rsa :私钥
id_rsa.pub :公钥

2.切换到文件所在目录:cd ~/.ssh/

将公钥写入authorized_keys文件,执行命令:cat id_rsa.pub >> authorized_keys

3.在目标服务器上更改权限(必须)

chmod 700 ~/.ssh
chmod 600 ~/.ssh/authorized_keys  

4.将私钥id_rsa拷贝至需要远程连接的服务器

在远程服务器执行拷贝命令:scp root@47.104.189.163:/root/.ssh/id_rsa ./

(./表示拷贝至当前目录下)

5.在终端设置快捷登录配置:vim ~/.ssh/config

Host zjk
HostName 47.104.189.163
Port 22
User root
PreferredAuthentications publickey
IdentityFile ~/.ssh/id_rsa

在终端执行:ssh zjk  即可快速登录远程服务器

二、禁用密码登录

1、修改配置文件

vim /etc/ssh/sshd_config

#禁用密码验证
PasswordAuthentication no
#启用密钥验证
PubkeyAuthentication yes

2、重启ssh服务

#centos系统
service sshd restart
#ubuntu系统
service ssh restart 
#debian系统
/etc/init.d/ssh restart 

注:如果出现如下提示:Redirecting to /bin/systemctl restart sshd.service

执行命令,重启sshd服务:systemctl start sshd.service

  • 3
    点赞
  • 8
    收藏
    觉得还不错? 一键收藏
  • 1
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值