经常在工作中须要在各个Linux机间进行跳转,每次password的输入成了麻烦,并且也不安全。在实际使用中,在windows下常使用secureCRT工具或teraterm工具进行SSH登录。以及实现hadoop集群部署要求的无password跳转问题。

SSH分为有password登录和证书登录。考虑到安全性因素,一般都是採用证书登录。即:每次登录无需输入password。

假设是password登录,非常easy遭受到外来的攻击。

一、证书登录的过程:

1.client生成证书的私钥和公钥。

私钥放在client。公钥上传到服务端(远程登陆端)。

一般为了安全,訪问有黑客拷贝client的私钥。client在生成私钥时。会设置一个password,以后每次登录sshserver时,client都要输入password解开私钥(假设工作中,你使用了一个没有password的私钥,有一天server被黑了,你是跳到黄河都洗不清)。

2.server加入信用公钥。

把client生成的公钥,上传到sshserver,加入到指定的文件里。这样,就完毕ssh证书登录的配置了。

如果client想通过私钥要登录其它sshserver,同理。能够把公钥上传到其它sshserver。

实际应用举例:

工生成好私钥和公钥(千万要记得设置私钥password)。然后把公钥发给运维人员,运维人员会登记你的公钥。为你开通一台或者多台server的权限。然后员工就能够通过一个私钥,登录他有权限的server做系统维护等工作。所以。员工是有责任保护他的私钥的。假设被别人恶意拷贝。你又没有设置私钥password。那么,server就全完了,员工也能够放长假了。

二、证书登陆实例:

  环境:A通过ssh方式登陆B。即:A为本地机,B为远程登陆server

1.A机配置

①生成公钥和私钥

# ssh-keygen -t rsa           (连续三次回车,即在本地生成了公钥和私钥,不设置password)

②将公钥拷到B端

         # scp  root@B的iP:root/.ssh/id_rsa.pub  ./.ssh/id_rsa.pub  (须要输入password)

2.B机配置

①创建authorized_keys2文件

# touch /root/.ssh/authorized_keys2      (假设已经存在这个文件, 跳过这条)

②追加公钥到authorized_keys2中

# cat /root/.ssh/id_rsa.pub   >> /root/.ssh/authorized_keys2 (将id_rsa.pub的内容追加到 authorized_keys2 中)

3.SSH证书登陆验证

# ssh root@B的iP           (由于没有设置私钥password, 所以不须要password, 登录成功)

三、其它应用场景:

SecureCRT密钥key远连接程ssh证书登录Linux

国内大部分人用的系统是windows,而windows下有非常多sshclient图形工作,最流行,功能最强大的就是SecureCRT了,所以我会单独针对SecureCRT简单讲下实现ssh证书登录Linux的要点,过程例如以下:

1:在SecureCRT创建私钥和公钥:

主菜单->工具->创建公钥->选择RSA->填写私钥的password->密钥长度填为1024->点击完毕,生成两个文件,默认名为identity和identity.pub

2.把私钥和公钥转换为OpenSSH格式:

主菜单->工具->转换私钥到OpenSSH格式->选择刚生成私钥文件identity->输入私钥的password->生成两个文件,指定为id_rsa, id_rsa.pub

3.把公钥id_rsa.pub上传到sshserver,依照之前配置server端的证书,再配置一次。

另外,假设你之前用windows的 SecureCRT的证书登录linux的,有一天你换成了linux,并希望通过原来的私钥登录公司的server,那么能够把id_rsa拷贝倒~/.ssh/文件夹下。

备注:

ssh对证书的文件和文件夹权限比較敏感,要么依据出错提示设置好文件和文件夹权限。要么是把StrictModes选项设置为no。

hadoop部署的无passwordssh登录

hadoop要求master要无password跳转到每一个slave,那么master就是上文中的sshclient了。过程例如以下:

1.在hadoop master上,生成公钥私钥。这个场景下。私钥不能设置password。

2.把公钥上传到每一个slave上指定的文件夹。这样就完毕了ssh的无password跳转了。

四、总结:

ssh证书登录,在实际工作才是最经常使用的登录方式,本人结合了真正工作的场景普及了ssh证书登录的知识,并依据流行的hadoop部署和windows下最经常使用的SecureCRT实例解说了证书登录。

SSH证书登录方式(无password验证登录)的更多相关文章

  1. vty密码登录,到AAA验证登录,以及远程配置网络

    华为的的最简易的远程登录方式,就是密码登录了. 配置命令如下图: 最重要的是权限: 访问级(0级).监控级(1级).系统级(2级)和管理级(3级) 在以上基础上,做了一个远程配置方式,通过一台,修改其 ...

  2. 修改官方发行openstack镜像的cloud-init登录方式为账号密码登录

    openstack使用的镜像多为qcow2格式,各个发行商也开源了针对openstack制作的镜像.但是这些镜像的登录方式都是注入用户名和密码的方式,就是说不能够直接通过账号和密码登录.那么如何将一个 ...

  3. Thinkphp框架 表单自动验证登录注册 ajax自动验证登录注册

    说明:这里没练习静态自动验证:如果用到静态验证首先自定义一个控制器,再在Model文件夹里创建一个NiHaoModel.php 类  NiHao是自定义的,前缀可以随意,但是一定要用驼峰法(首字母大写 ...

  4. SSH无password登陆配置

    摘录一 在192.168.42.142机器上 1)执行:ssh-keygen -t rsa 2)然后拍两下回车(均选择默认) 3)执行: ssh-copy-id -i /root/.ssh/id_rs ...

  5. 配置OpenVpn使用证书和用户名密码双验证

    修改OpenVpn的主配置文件 添加一下内容: [root@check1 openvpn]# tail -3 server.conf auth-user-pass-verify /etc/openvp ...

  6. 实现ssh的无password登录

    这里所说的ssh是指OpenSSH SSHclient.是用于登录远程主机.而且在远程主机上运行命令.它的目的是替换rlogin和rsh,同一时候在不安全的网络之上,两个互不信任的主机之间,提供加密的 ...

  7. Ssh 证书验证登录

    一般使用 PuTTY 等 SSH 客户端来远程管理 Linux 服务器.但是,一般的密码方式登录,容易有密码被暴力破解的问题.所以,一般我们会将 SSH 的端口设置为默认的 22 以外的端口,或者禁用 ...

  8. h3c交换机配置ssh密码验证登录方式

    一.背景: 1.由于PC机串口不支持热插拔,请不要在交换机带电的情况下,将串口插入或者拔出PC机.当连接PC和交换机时,请先安装配置电缆的DB-9端到PC机,再连接RJ-45到交换机:在拆下时,先拔出 ...

  9. 以证书的方式登录ssh

    常常要登录多台Linux服务器,过去在Windows下使用SecureCRT,比较省心,配置还可以放到云盘,实时同步.现在改用MAC貌似就没有那么好用的东西了,每次ssh命令登录都需要输入密码,很烦. ...

随机推荐

  1. 在安装mysql出现的错误以及解决方法

    因为手贱更新了一下驱动,结果导致无线网卡出了问题.然而就算是从官网上下载了驱动各种折腾也没有弄好,心里特别堵.无奈只有重装系统这一条路了.这里表示特别难过,因为电脑上东西实在太多了,而且各种环境变量. ...

  2. mongodb在PHP下的应用学习笔记

    1.连接 mongodb默认端口是:27017,因此我们连接mongodb:$mongodb = new Mongo('localhost') 或者指定IP与端口 $mongodb = new Mon ...

  3. 只能从脚本中调用在类定义上有[ScriptService]属性的Web服务问题的解决方案

    ajax调用webservice中的接口时, 会出现[只能从脚本中调用在类定义上有[ScriptService]属性的...]的异常. 这是因为, 在.net3.5中, 访问web服务, 要对web服 ...

  4. 百度map android sdk3.5实现定位 并跳转的指定坐标,加入标记

    前几天又下载了新的百度地图sdk,3.5版本号.发现百度地图api有了较大变化 定位和3.0版本号差点儿相同 可是设置地图中心和加入maker标记有较大变化 设置地图中心点 // 定义地图状态zoom ...

  5. Kiwi Syslog server 日志服务器搭建

    Kiwi syslog server 是一款很不错的日志服务器软件,安装过程就不多说,Linux 服务器日志由于本身就是syslog的,所以不用转换,但是windows 系统的日志格式是event形式 ...

  6. Android判断应用程序从后台回到前台

    MainActivity如下: package cc.testbackgroundtofront; import java.util.List; import android.app.Activity ...

  7. POJ 2524 :Ubiquitous Religions

    id=2524">Ubiquitous Religions Time Limit: 5000MS Memory Limit: 65536K Total Submissions: 231 ...

  8. getline与get函数的区别

    get()函数相对getline来说使用方法要灵活的多了. 1.   int get()是指从流中抽取单个字符并返回,这个是没有參数的形式.由于c++不像c语言使用getchar() 2.istrea ...

  9. warning: directory not found for option ' '

    解决: 选择项目名称-->Targets-->Build Settings-->Search Paths-->Library Search Paths 删除相应路径

  10. SWT中一些细节的说明

    1.shell.pack();函数的效果是将程序打包,使其以合适的大小显示出来,不会太大有很多多余空间,也不会太小导致有些控件无法显示. 2. while(!shell.isDisposed()){ ...