Oracle Cloud利用VNC拯救失联服务器(Linux和Windows)

前几天Oracle Cloud注册成功率又放水!又有一批网友上车了!这个马甲将甲骨文云VNC部分内容完善一下!

什么情况下会用到 VNC ?比如服务器无法正常启动,SSH无法正常登陆到服务器,这个时候需要利用VNC上服务器上排查一下问题!

常的场景:1)DD 系统服务器失联。 2)SSH密码忘记。

本文主要分为2部分。第一部分是利用Linux,第二部分是利用Windows 10。其中Linux相对来说简单一些!

Linux版

这部分操作使用的是利用CentOS 7 + VNCviewer绿色版!

准备工作

1)VNC链接工具,【VNC Connect】或者【VNCviewer绿色版(解压密码:RUYO.net)】。

2)准备一台Linux服务器。

生成SSH KEY

1)登陆Linux服务器输入命令!

1
2
//生成SSH KEY
ssh-keygen

2)命令执行效果如下!

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

3)获取SSH公钥:cat ~/.ssh/id_rsa.pub (公钥后面会用到)

SSH私钥位置: ~/.ssh/id_rsa

配置控制台

1)登陆Oracle Cloud控制台,打开实例详细信息 – 控制台连接 – 点击【创建控制台链接】

img

2)将 SSH公钥 复制到SSH密钥输入框内,保存!

img

3)等到链接的状态变成【活动】,点击【⋮】 – 【复制Linux/Mac的VNC连接】

img

创建SSH代理

1)需要在Linux服务器上将端口开放,默认使用的端口是5900,建议不要使用这个端口,我已经将端口换成 8000!

将上面复制的内容中的 5900 换成 8000 (如果8000被占用,就换其他的)

1
ssh -o ProxyCommand='ssh -W %h:%p -p 443 ocid1.instanceconsoleconnection.oc1.ap-seoul-1.anuwgljr2ano4pqcwnhqj5tw4wgrxxxo6ba@instance-console.ap-seoul-1.oraclecloud.com' -N -L localhost:**5900**:ocid1.instance.oc1.ap-seoul-1.anuwgljr2ano4pqcpkcs63uecyrs5bqmhsblzgtkygtjvhb666kytctumtoa:5900 ocid1.instance.oc1.ap-seoul-1.anuwgljr2ano4pqcpkcs63uecyrs5xxxkytctumtoa

2)将命令粘贴到Linux服务器命令行执行。

注意:第一次执行命令有2个位置,需要输入 yes 回车!

img

VNC连接服务器

使用VNC 客户端链接即可!然后就成功了!!

1
服务器IP:8000

img

img

Windows版

这部分操作使用的是 Windows 10 + VNCviewer绿色版

准备工作

1)VNC链接工具,【VNC Connect】或者【VNCviewer绿色版(解压密码:RUYO.net)】。

2)Windows 10 需要安装 Git 和 PuTTY(下载地址参考附录部分)

提醒:PuTTY须安装到 C:\Program Files\

生成SSH KEY

这里严重不建议使用 PuTTY 生成 SSH KEY!

1)利用Git Bash生成!

打开菜单 – Git – Git Bash

img

2)执行命令生成SSH 密钥!

1
2
//生成SSH KEY 
ssh-keygen

img

3)密钥默认存放位置:C:\Users\ruyo\.ssh\ 目录。(其中ruyo为当前操作系统登陆用户的用户名)

img

SSH公钥:id_rsa.pub

SSH私钥: `id_rsa```

配置控制台

这里和Linux版的操作基本一样,将SSH公钥复制进去!

等到链接的状态变成【活动】,点击【⋮】 – 【复制Windows的VNC连接】

img

SSH私钥转换

由于Oracle Cloud VNC 识别不了上面的SSH私钥,需要利用下面的工具转一下!

1)打开菜单 – PuTTY – PuTTYgen

img

2)打开的界面点击【Load】,选择上面生成的SSH私钥。

如图操作,选择id_rsa ,出现提示框点击确定即可!

img

img

3)点击【Save private key】,将转换后的私钥保存到文件目录(记住该文件目录后面要用到!)。

PS:尽量要保存到 .ssh 目录中,命名要ruyo.ppk (后面有一键生成命令必须这样!)

img

img

VNC命令重构

直接复制处理的命令,执行上有一些问题。这里需要将命令修改一下!主要是替换以下内容:

1)替换 plink.exe 文件目录

2)替换PPK文件目录

3)将1条命令 转成 2条命令来执行

原始命令:

1
Start-Job { Echo N | plink.exe -i $env:homedrive$env:homepath\oci\console.ppk -N -ssh -P 443 -l ocid1.instanceconsoleconnection.oc1.ap-seoul-1.anuwgljr2ano4pqcwnhqj5tw4wgrpmkuib4yah2naclpvcemkr27ajq5o6ba -L 5905:ocid1.instance.oc1.ap-seoul-1.anuwgljr2ano4pqcpkcs63uecyrs5bqmhsblzgtkygtjvhb666kytctumtoa:5905 instance-console.ap-seoul-1.oraclecloud.com }; sleep 5; plink.exe -i $env:homedrive$env:homepath\oci\console.ppk -N -L 5900:localhost:5900 -P 5905 localhost -l ocid1.instance.oc1.ap-seoul-1.anuwgljr2ano4pqcpkcs63uecyrs5bqmhsblzgtkygtjvhb666kytctumtoa

转换后命令:

第一条命令:

1
cd 'C:\Program Files\PuTTY\'.\plink.exe -i $env:homedrive$env:homepath\.ssh\ruyo.ppk -N -ssh -P 443 -l ocid1.instanceconsoleconnection.oc1.ap-seoul-1.anuwgljr2ano4pqcwnhqj5tw4wgrpmkuib4yah2naclpvcemkr27ajq5o6ba -L 5905:ocid1.instance.oc1.ap-seoul-1.anuwgljr2ano4pqcpkcs63uecyrs5bqmhsblzgtkygtjvhb666kytctumtoa:5905 instance-console.ap-seoul-1.oraclecloud.com

第二条命令:

1
cd 'C:\Program Files\PuTTY\'.\plink.exe -i $env:homedrive$env:homepath\.ssh\ruyo.ppk -N -L 5900:localhost:5900 -P 5905 localhost -l ocid1.instance.oc1.ap-seoul-1.anuwgljr2ano4pqcpkcs63uecyrs5bqmhsblzgtkygtjvhb666kytctumtoa

启动plink代理

1)我们需要启动2个 PowerShell (Win + X 或者 开始菜单鼠标右键)

img

2)在2个 PowerShell 分别执行 2条VNC命令。

提醒:命令执行后,显示 Access granted. Press Return to begin session. 需要再按一次回车!!

img

img

VNC连接服务器

使用VNC 客户端链接即可!然后就成功了!!

1
localhost:5900

这里我们使用默认端口基本上没啥太大问题!

img

img

附录

Git下载地址:https://git-scm.com/downloads

PuTTY下载地址:https://www.chiark.greenend.org.uk/~sgtatham/putty/latest.html

最后总结

本文有几个疑惑不知道原因,知道的大佬可以留言指导一下!

1)为什么PuTTY 生成的 SHH 密钥 无法识别?(怀疑是密钥类型或者长度)

2)直接复制VNC原始命令不能执行?(原命令有一些错误不显示,命令有2步确认的操作?)

以上博主没有做深入的摸索!

本文引用自:四海部落