• ssh打通通道自动登录


     

    自动ssh登录的几种方法

    1. 自动ssh/scp方法==

    A为本地主机(即用于控制其他主机的机器) ;
    B为远程主机(即被控制的机器Server), 假如ip为192.168.60.110;
    A和B的系统都是Linux

    在A上运行命令:
    # ssh-keygen -t rsa (连续三次回车,即在本地生成了公钥和私钥,不设置密码)
    # ssh root@192.168.60.110 "mkdir .ssh" (需要输入密码)
    # scp ~/.ssh/id_rsa.pub root@192.168.60.110:.ssh/id_rsa.pub (需要输入密码)

    在B上的命令:
    # touch /root/.ssh/authorized_keys (如果已经存在这个文件, 跳过这条)
    # cat /root/.ssh/id_rsa.pub >> /root/.ssh/authorized_keys (将id_rsa.pub的内容追加到authorized_keys 中)

    回到A机器:
    # ssh root@192.168.60.110 (不需要密码, 登录成功)
    (注:在生成密钥对的时候系统会提示输入密钥对的密码,这里请直接回车,不要输入密码,否则后面打通通道之后仍然需要密码,只不过是用这里设置的密码而已)
    说明:
    authorized_keys文件的权限很重要,(据说,如果设置为777,那么登录的时候,还是需要提供密码的。)

    我的成功经验是

    chmod  604  authorized_keys

    如果这个时候,还不能登录的话,那么你的目录的读取权限肯定有问题了,要确保你的/home/xuxm/.ssh目录,以及你的根目录/home/xuxm 

    我的成功经验 

    /home/xuxm 755
    /home/xuxm/.ssh 755

     /home/xuxm/.ssh/authorized_keys 604

    2. 控制n个机器如上所述自动登录
    那就需要n对钥匙(密钥和公钥), ssh-keygen 命令可以随意更改钥匙对的名字, 比如:
    # ssh-keygen -t rsa
    Generating public/private rsa key pair.
    Enter file in which to save the key (/root/.ssh/id_rsa): /root/.ssh/id_rsa_192.168.60.110

    这样私钥和公钥的名字分别就是: id_rsa_192.168.60.110和 id_rsa_192.168.60.110.pub;然后将 id_rsa_192.168.60.110.pub 文件的内容, 追加到sever的 ~/.ssh/authorized_keys文件中,最后, 在本地用ssh命令的 -i 参数指定本地密钥, 并登录:
    # ssh -i /root/.ssh/id_rsa_192.168.60.110 someone@192.168.60.110

    scp也是一样的
    # scp -i /root/.ssh/id_rsa_192.168.60.110 filename someone@192.168.60.110:/home/someone

    在文件.bashrc中加下两行,每次做同样的操作就不用敲入这样长的命令了:
    alias sshcell='ssh -i /root/.ssh/id_rsa_192.168.60.110 someone@192.168.60.110'
    alias scpcell='scp -i /root/.ssh/id_rsa_192.168.60.110 filename someone@192.168.60.110:/home/someone'

    这样,直接键入一下指令实现ssh和scp自动登录:
    # sshcell
    # scpcell


    3. 自动ssh/scp脚本
    如果需要从A,到B,然后才能够到C,那么需要ssh和scp两次,是比较麻烦的。
    ssh自动登录:
    #!/usr/bin/expect -f
    set timeout 30
    spawn ssh weiqiong@B
    expect "password:"
    send "pppppp\r"
    expect "]*"
    send "ssh weiqiong@C\r"
    expect "password:"
    send "pppppp\r"
    interact


    scp从A拷贝文件到C:
    #!/usr/bin/expect -f
    set timeout 300
    set file [lindex $argv 0]
    spawn scp $file weiqiong@B:/home/weiqiong
    expect "password:"
    send "pppppp\r"
    expect "]*"
    spawn ssh weiqiong@B
    expect "password:"
    send "pppppp\r"
    expect "]*"
    send "scp $file weiqiong@C:/home/weiqiong\r"
    expect "password:"
    send "pppppp\r"
    expect "]*"
    exit
    interact

    scp从C拷贝文件到A:
    #!/usr/bin/expect -f
    set timeout 300
    set file [lindex $argv 0]
    spawn ssh weiqiong@B
    expect "password:"
    send "pppppp\r"
    expect "]*"
    send "scp weiqiong@C:/home/weiqiong/$file .\r"
    expect "password:"
    send "pppppp\r"
    expect "]*"
    send "exit\r"
    expect "]*"
    spawn scp weiqiong@B:/home/weiqiong/$file .
    expect "password:"
    send "pppppp\r"
    interact

    4. 建立ssh/scp通道
    比如说我的机器是A,中间服务器为B,目标服务器是C<br>
    从A可以ssh到B,从B可以ssh到C,但是A不能直接ssh到C<br>
    现在展示利用ssh通道技术从A直接传输文件到C<br>
    1. ssh -L1234:C:22 userid@B<br>
    input B's password<br>
    (1234是本机A的空闲端口,该指令需要A机器上的root用户权限,实际上是在本机1234端口建立了一个通道)<br>

    2. 打开一个新的console,键入:<br>
    scp -P1234 filename userid@localhost:<br>
    input C's password

  • 相关阅读:
    (转)IntelliJ IDEA 插件 阿里巴巴Java开发手册(Alibaba Java Coding Guidelines)
    idea快捷键整理
    (转)mysql使用Navicat 导出和导入数据库
    (转)Intellij Idea工具栏添加打开选中文件的资源管理器位置
    Intellij IDEA设置类注释和方法注释
    mavn jar包依赖冲突解决
    我的Keras使用总结(3)——利用bottleneck features进行微调预训练模型VGG16
    我的Keras使用总结(2)——构建图像分类模型(针对小数据集)
    我的Keras使用总结(1)——Keras概述与常见问题整理
    数据竞赛实战(5)——方圆之外
  • 原文地址:https://www.cnblogs.com/xuxm2007/p/1818352.html
Copyright © 2020-2023  润新知