centos6.5免密码登录

由于对linux接触时间比较短,导致免密码登录整了好长一段时间,不过付出的努力没有白费。实现不仅在root用户下实现免密码登录而且也实现普通用户的免密码登录。

在机器A(192.168.98.3)创建用户一个普通用户slave1:  usradd -m slave1

查看机器是否安装了ssh :  rpm -qa|grep ssh 一般安装好系统ssh都会安装好的,但是建议重新安装一下: yum install openssh-server。

使用visudo配置开启免密码登录的配置:  将第二张图中的三个注释去掉  ,保存后使用sudo service sshd restart重启生效(sudo是为了因为普通用户没有权限)。

centos6.5免密码登录_第1张图片

备注:配置sudo : 切换到root用户下:visudo 然后找到下面的root All ...行在下面添加新的用户。

centos6.5免密码登录_第2张图片

首先登陆root用户,修改/etc/ssh/sshd_config文件,将其中的下面三行的#号去掉,开启rsa密码验证。

centos6.5免密码登录_第3张图片

切换到master用户的家目录。生成公钥: ssh-keygen -t rsa 一路点击回车就行。生成后会在家目录中生成.ssh文件夹。使用ls -a加上-a参数才能看新以开头的文件。文件中会生成id_rsa和id_rsa.pub两个文件。authorized_keys文件放的是别的机器上公

钥,know_hosts是免密码连接的主机。

然后将本机的公钥拷贝到A(192.168.98.4)机器的hadoop用户下:ssh-copy-id -i id_rsa.pub  [email protected]此时在hadoop下,此时hadoop家目录的.ssh/文件下就会出现authorized_keys文件并且包含A机器的公钥。此时可以使用在A机器上连接B机器的hadoop用户:   ssh [email protected]不需要密码即可登录。(其中多的公钥拷贝有相同的是因为考了多份,没影响)

centos6.5免密码登录_第4张图片

centos6.5免密码登录_第5张图片

但是此时你可以能还不能登录到别的用户上比如相互之间的root以及B机器登录A机器。解决:分别在各个的普通用户和root用户上都生成相应的公钥,并且互相拷贝到各自机器的authorized_keys文件,使用命令ssh-copy-id -i id_rsa.pub  用户名@ip。

然后相互访问即可。(如果A配置了主机名和ip的映射也可以使用     用户名@映射)

centos6.5免密码登录_第6张图片centos6.5免密码登录_第7张图片

如果还是不行,检查是否要登录机器的公钥在authorized_keys文件里面,并且用户是一致的用户。

你可能感兴趣的:(学习)