zoukankan      html  css  js  c++  java
  • 二十五、SSH服务企业级应用场景

    一、需求分析:

        要求所有服务器在同一个用户oldboy1系统用户下,实现A机器从本地分发数据到BC机器上,在分发过程中不需要BC的提示系统密码验证,除了分发功能,还需要可以批量查看客户上的cpu、load、men,系统版本等使用信息。

        即实现从A服务器发布数据到BC客户端服务器或者查看信息的免密登陆验证。

       1.增加用户,在三台机器上都进行增加oldboy1用户和密码。

        1)useradd oldboy1

        2)id  oldboy1

        3)echo 123456| passwd --stdin  oldboy1

      2.选择A-server创建密钥

          ssh-keygen   -t   dsa/rsa

     

     id_dsa.pub就是要传给BC的公钥,文件权限是644,目录权限是700

    3.分发密钥到其他每一个机器上:

       ssh-copy-id   -i   .ssh/id_dsa.pub  "-p22 oldboy1@192.168.0.102"

    其实 ssh-copy-id原理就是把公钥.ssh/id_dsa.pub复制到对应的oldboy1下面并且名命为authorized_keys,目录权限是700,但是文件权限为600

     4.进行脚本编写,进行服务器文件的分发:(脚本和分发)

      一般我们在进行分发的话,都不会用root进行,那么相对安全的有两种方法:

      1)用sudo  -t

     例子:ssh -P52113 -t oldboy1@192.168.0.102  sudo  /bin/cp   ~/file/etc

     2)  用 suid

     例子:chmod  4755 "which  rsync"

    ssh 批量分发与管理方案小结:

    1.利用root做ssh key验证。

         优点:简单、易用

         缺点:安全查,同时无法禁用root远程连接

         企业80%

    2.利用普通用户如oldboy1来做,思路是先把分发的文件拷贝到服务请求用户家目录,然后sudo提权拷贝到服务器的对用权限目录

         优点:安全

         缺点:配置复杂

    3.拓展:同方案2,只是不用sudo,而是设置suid对固定命令授权

        优点:相对安全

        缺点:复杂,安全性较差。任何人都可以用suid命令

     私钥永远是发送端的。

  • 相关阅读:
    物流能力和综合层次结构
    new Eclipse 3.0+Lomboz 3.0+Tomcat 5.0.16配置
    30件你不知道可以通过Internet来办到的事
    《网上苏州》电子地图建设方案
    IT从业人员必看的10个论坛
    非常在线网站站长自述创业经历
    防止对 Visual Basic .NET 或 C# 代码进行反相工程
    略论中国人的思维方式
    C# vs. Java:相反的思维方式 (译文)
    Java多线程编程经验谈
  • 原文地址:https://www.cnblogs.com/dangjingwei/p/10990795.html
Copyright © 2011-2022 走看看