ssh免密登录(详细)

在分布式系统中,经常需要各台主机之间相互配合工作。如hadoop启动的时候,各台主机之间必须配置ssh免密登录

1 ssh安装

ubuntu

sudo apt-get install openssh-server openssh-client

centos7

yum  install -y openssh-server openssh-clients

2 配置ssh

在原来的配置文件基础上:打开root用户登录选项,开启密码验证。

vim /etc/ssh/sshd_config

在这里插入图片描述

配置完成,可以使用以下命令启动ssh:

# 启动
systemctl start ssh  
# 停止
systemctl stop ssh
# 查看状态
systemctl status ssh
# 开机自启动
systemctl enable ssh
# 关闭开机自启动
systemctl disable ssh

3 域名解析配置(可选)

域名解析配置是为了让我们每次访问别的机器时,可以不用输入ip,而是使用方便记忆的域名来替代。配置域名后将极大地提升用户体验。如果跳过这一步,后面过程需要使用ip来替代后续过程中的域名。

现在假设有三台主机,ip分别为192.168.2.2、192.168.2.3、192.168.2.4,三台主机能相互ping通。

编辑第一台主机/etc/profile

vim /etc/profile

在文件末尾插入以下语句

echo 192.168.2.2 node01 >> /etc/hosts
echo 192.168.2.3 node02 >> /etc/hosts
echo 192.168.2.4 node03 >> /etc/hosts

保存退出后,使profile生效,然后将文件分发到其他两台主机

cd /etc
# 使文件生效
source profile
# 分发
scp profile node02:$PWD
scp profile node03:$PWD

然后分别登录另外两台主机,使profile文件生效即可配置成功。

4 ssh相互免密

4.1 生成秘钥

每台主机都执行以下指令:

ssh-keygen -t rsa

途中有三次会让你输入,直接回车即可。

4.2 ssh相互免密

每台主机都执行以下指令(在分布式系统中,每台主机与自身也需要配置免密登录):

ssh-copy-id node01
ssh-copy-id node02
ssh-copy-id node03

在遇到需要输入的地方,输入yes。现在即可免密登录其他主机了。

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

一朝英雄拔剑起

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值