SSH登录介绍

说明:一般登录服务器,我们可以用远程连接工具,如XShell、Windterm等,或者通过公司搭建的JumpServer(跳板机、堡垒机)来连接。前者是点对点登录,输入主机、端口,通过SSH协议登录;后者可以管理主机(资产)、账户,通过给账户分配主机,可以在页面上直接登录,管理起来非常方便。

但是,如果需要登录到客户,或者其他企业的第三方服务器,以上两种方式可能不行。原因有:1)第三方服务器大多不能直接通过公网IP连接,可能需要先登录到他们的跳板机(中间环境),才能连接到服务器;2)客户/其他企业一般不会开放JumpServer账户给你,或者他们压根也没有搭建JumpServer;

这种情况下,可以通过在CMD命令中直接用SSH命令登录。本文介绍如何使用SSH登录服务器,假设我现在是在Windows操作系统下:

基本操作

打开CMD窗口,敲下面的命令,连接服务器,默认通过22端口

powershell 复制代码
ssh user@host

其中,

  • user:表示账户名;

  • host:表示主机,即IP;

如下:

登录我的阿里云服务器,提示登录失败,因为需要SSH秘钥;

指定秘钥登录

敲下面的命令,用-i参数,指定秘钥登录;

powershell 复制代码
ssh -i 秘钥路径 user@host

如下:

这里我遇到了下面这个错误,说我的秘钥权限过于开放,拒绝使用。

我修改了文件了所有者仅为自己,并且只开放了读取和执行权限,再试就可以了。改完需要重新打开CMD。

指定端口登录

一般SSH默认端口是22,如果对方更改了,需要用-p指定端口,如下:

powershell 复制代码
ssh -i 秘钥 -p 端口号 user@host

生成SSH秘钥对(rsa类型)

敲下面的命令,可以生成一对SSH公私钥,可以将公钥放到目标服务器上,后续登录就不需要秘钥了。生成SSH密钥对敲下面的命令:

powershell 复制代码
ssh-keygen -t rsa

敲完命令,连续敲三次回车,就能在当前用户的.ssh文件夹下生成一对SSH秘钥,如下:

详细说明,以及如何传到目标服务器上,可以看下面这篇文章:

验证秘钥正确性

最后一个命令,如何验证秘钥是否正确,有时候我们会把秘钥的内容拷贝出来,放到一个文件里。在传来传去的过程中,可以破坏了秘钥的完整,我们可以敲下面的命令先验证一下秘钥是否正确,再去连接服务器,排查登录不上去是不是有其他原因。如下:

powershell 复制代码
ssh-keygen -l -f ssh秘钥路径

如下,就是一个正确的秘钥

相关推荐
江畔何人初3 分钟前
/etc/profile,.profile,.bashrc三者区分
linux·运维·云原生
会飞的土拨鼠呀14 分钟前
Ubuntu系统缺少 iptables 工具
linux·运维·ubuntu
前端玖耀里14 分钟前
详细介绍Linux命令dig和nslookup
linux·运维·服务器
星期五不见面22 分钟前
jetson naon super使用 sudo /opt/nvidia/jetson-io/jetson-io.py 界面闪退
linux·运维·服务器
FreeBuf_34 分钟前
AutoPentestX:面向 Linux 系统的自动化渗透测试工具包
linux·运维·自动化
Fᴏʀ ʏ꯭ᴏ꯭ᴜ꯭.36 分钟前
Nginx 平滑升级与回滚超详细指南
运维·nginx
网硕互联的小客服43 分钟前
linux服务器忘记远程端口怎么办?如何找回?
linux·运维·服务器
历程里程碑44 分钟前
Linux 16 环境变量
linux·运维·服务器·开发语言·数据库·c++·笔记
ZeroNews内网穿透1 小时前
关于飞牛fnOS重要安全更新的提醒
运维·服务器·web安全·ssh
故乡de云1 小时前
2026年谷歌云价格走势深度分析:企业如何在高成本时代保持竞争力?
运维·kubernetes·云计算