• Linux配置SSH连接方式


    1. SSH介绍

    1) 什么是SSH
    SSH是一种安全协议,主要用于给远程登录会话数据进行加密,保证数据传输的安全

    2)SSH服务端和客户端
    SSH服务端是一个守护进程,一遍为sshd进程,在后端运行并响应来自客户端的请求。
    SSH客户端常用的有BvSsh,SecureCRT,putty等。

    3)基本工作机制

    • 客户端发送一个请求到服务端
    • 服务端做数据验证,如包及ip地址等,在发送一个秘钥给ssh客户端
    • 客户端再将密钥发回服务端,自此建立连接

    2. ssh密钥登录

    1) 首先在服务器中创建密钥对

    1. [root@localhost .ssh]# ssh-keygen -t rsa
    2. Generating public/private rsa key pair.
    3. Enter file in which to save the key (/root/.ssh/id_rsa):
    4. Enter passphrase (empty for no passphrase):
    5. Enter same passphrase again:
    6. Your identification has been saved in /root/.ssh/id_rsa.
    7. Your public key has been saved in /root/.ssh/id_rsa.pub.
    8. The key fingerprint is:
    9. SHA256:+LTzDddLCyrFVb9bHRMnOssHgOGJbffji/NV5/hPAEA root@localhost.localdomain
    10. The key's randomart image is:
    11. +---[RSA 2048]----+
    12. | .+E |
    13. | +.... o..|
    14. | . = ...o oo|
    15. | o . .=. o.|
    16. | . S. oo+. B|
    17. | o .o.oo.*+|
    18. | +.. +.= =|
    19. | .o.* = * |
    20. | .+o+ o +|
    21. +----[SHA256]-----+

    在创建的过程中会提示输入密码,在次不用输入,直接回车即可,创建的密钥对默认放当前登录用户的家目录下的.ssh目录中。

    2)在服务器中安装公钥

    1. [root@localhost .ssh]# cat id_rsa.pub >> authorized_keys
    2. [root@localhost .ssh]# ls
    3. authorized_keys id_rsa id_rsa.pub

    注:此处特别要注意文件名称不能错误(包括大小写), 存放公钥的文件名为: authorized_keys。多个用户多需要登录linux,每个用户都需要密钥,则可以只用上面的追加命令直接将多个用户的公钥直接追加进去即可。

    3) 设置文件权限

    1. [root@localhost .ssh]# chmod 600 authorized_keys
    2. [root@localhost .ssh]# chmod 700 ~/.ssh
    1. 设置ssh的配置文件
    [root@localhost .ssh]# vim /etc/ssh/sshd_config
    

    修改如下的配置:

    1. # 加密算法
    2. RSAAuthentication yes
    3. # 使用密钥进行认证
    4. PubkeyAuthentication yes

    5)重启ssh服务

    [root@localhost .ssh]# systemctl restart sshd
    
    1. 拷贝私钥到PC端(注意:是私钥 id_rsa),使用软件导入秘钥,然后测试登录

    xshell配置如下:

    bitvise配置:

    点击出现如下图: 

  • 相关阅读:
    控制反转 IOC 理论推导
    要努力,但也别焦虑
    从一道面试题来学习前台进程和后台进程、孤儿进程和僵尸进程
    FlinkCDC for mysql to Clickhouse
    【学习笔记】尚未用过的图论知识
    QT之可自由折叠和展开的布局
    分布式版本控制系统Git的使用最全最细;
    关于git版本管理与分支管理
    uniapp onLoad生命周期 uni.$on接受参数无法改变data数据解决办法
    【LeetCode每日一题:891. 子序列宽度之和~~~排序+数学推导】
  • 原文地址:https://blog.csdn.net/qq_62898618/article/details/127716635