Secure Shell(安全外壳协议,简称SSH)是一种加密的网络传输协议,可在不安全的网络中为网络服务提供安全的传输环境。SSH通过在网络中创建安全隧道来实现SSH客户端与服务器之间的连接。SSH最常见的用途是远程登录系统,人们通常利用SSH来传输命令行界面和远程执行命令。------《*》
1 用途
ssh用于在通信双方之间架设较为安全的信息传输通道
2 概况
假设本地机器A想要(免密)登录远程服务器B,则A需要完成大概以下工作:
2.1 生成密钥对
以A为linux操作系统为例,打开终端,进入用户家目录,假设用户名为username1;
进入/home/username1/.ssh,使用命令ssh-keygen -t ed25519 -C "custom_name",执行之后会在该目录下生成id_ed25519.pub和id_ed25519两个文件;
其中id_ed25519.pub为公钥文件,id_ed25519为私钥文件。
2.2 配置服务器
打开上述id_ed25519.pub公钥文件,复制其中内容,进入服务器B(假设为linux系统)的某个目标用户家目录下,假设用户名为username2;
进入/home/username2/.ssh,建立authorized_keys文件(如果没有的话),将复制内容粘贴进去,即完成服务器配置。
2.3 免密登录
在A上,打开终端,使用命令 "ssh username2@B的ip" 即可免密登录服务器B。
3 其它应用
在gitee、github等git平台上,使用ssh进行仓库管理相比于https的方式更为方便快捷;
与远程登陆应用场景类似,唯一的区别是:生成的公钥文件内容要复制到个人gitee、github账户的ssh密钥管理功能模块中(具体每个平台有自己的公钥配置方式,可自行参看)。