Linux培训
达内IT学院

400-996-5531

Linux上实现SSH免密码登陆远程服务器

  • 发布:Linux培训
  • 来源:网络
  • 时间:2017-05-24 15:00

0.说明

平常使用SSH登陆远程服务器时,都需要使用输入密码,希望可以实现通过密钥登陆而免除输入密码,从而可以为以后实现批量自动部署主机做好准备。

环境如下:

1.客户端生成密钥对

生成密钥对:

查看生成的密钥对:

linuxidc@linuxidc:~$ ls .ssh

id_rsa id_rsa.pub

# id_rsa为私钥,这个一般需要保密;id_rsa.pub为公钥,这个可以公开。

2.上传公钥到服务器端

使用scp命令操作:

linuxidc@linuxidc:~$ scp . ssh /id_rsa .pub root@10.0.0.128: /root

The authenticity of host '10.0.0.128 (10.0.0.128)' can't be established.

RSA key fingerprint is SHA256:0Tpm11wruaQXyvOfEB1maIkEwxmjT2AklWb198Vrln0.

Are you sure you want to continue connecting ( yes /no )? yes

Warning: Permanently added '10.0.0.128' (RSA) to the list of known hosts.

root@10.0.0.128's password:

id_rsa.pub 100% 393 0.4KB /s 00:00

3.服务器端操作

把从客户端传来的公钥添加到.ssh/authorized_keys中:

[root@linuxidc ~] # cat id_rsa.pub >> .ssh/authorized_keys

[root@linuxidc ~] # chmod 600 .ssh/authorized_keys

# authorized_keys的权限需要为600

修改ssh配置文件/etc/ssh/sshd_config,找到下面一行:

PubkeyAuthentication no

修改为:

PubkeyAuthentication yes

4.测试

在客户端上使用密钥登陆到服务器上:

linuxidc@linuxidc:~$ ssh -i . ssh /id_rsa root@10.0.0.128

Last login: Tue May 9 15:14:01 2017 from 10.0.0.129

[root@linuxidc ~] #

5.注意事项

在服务器端需要把selinux关闭,否则最后无法使用密钥进行远程登陆;

客户端使用scp命令时,在服务器端也需要安装ssh客户端,否则无法把公钥上传到服务器端,另外也可以使用ssh-copy-id root@10.0.0.128 来代替scp操作(这样在服务器端也不需要执行创建.ssh目录等这些操作,即相当于该命令可以一步帮我们完成密钥的上传与配置工作)

预约申请免费试听课

填写下面表单即可预约申请免费试听! 怕学不会?助教全程陪读,随时解惑!担心就业?一地学习,可全国推荐就业!

上一篇:机器人要抢饭碗,这几种职业危险了
下一篇:快学习使用Linux吧,避免勒索病毒大肆入侵

Linux中高效编写Bash脚本的10个技巧

拯救者Linux:我是如何给我的团队引入Linux的

Linux只有十三个字符的经典Fork炸弹

Copyright © 2023 Tedu.cn All Rights Reserved 京ICP备08000853号-56 京公网安备 11010802029508号 达内时代科技集团有限公司 版权所有

选择城市和中心
黑龙江省

吉林省

河北省

湖南省

贵州省

云南省

广西省

海南省