找回密码
 注册

QQ登录

只需一步,快速开始

搜索
热搜: 活动 交友 discuz
查看: 310|回复: 1

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

[复制链接]
发表于 2022-1-9 12:15:40 | 显示全部楼层 |阅读模式
什么情况下会用到 VNC ?比如服务器无法正常启动,SSH无法正常登陆到服务器,这个时候需要利用VNC上服务器上排查一下问题!
常的场景:1)DD 系统服务器失联。 2)SSH密码忘记。
本文主要分为2部分。第一部分是利用Linux,第二部分是利用Windows 10。其中Linux相对来说简单一些!
Linux版
这部分操作使用的是利用CentOS 7 + VNCviewer绿色版!
准备工作
1)VNC链接工具,【VNC Connect】或者【VNCviewer绿色版(解压密码:http://RUYO.net)】。
2)准备一台Linux服务器。
生成SSH KEY
1)登陆Linux服务器输入命令!

12//生成SSH KEYssh–keygen

2)命令执行效果如下!

12345678910111213141516171819202122[root@localhost ~]# ssh–keygenGenerating 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:SHA256fclO+AvXZ/O6vGNfzo4P2pftiHRoKG2fgc5p9bvu1o root@localhost.localdomainThe 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控制台,打开实例详细信息 – 控制台连接 – 点击【创建控制台链接】


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


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


创建SSH代理
1)需要在Linux服务器上将端口开放,默认使用的端口是5900,建议不要使用这个端口,我已经将端口换成 8000!
将上面复制的内容中的 5900 换成 8000 (如果8000被占用,就换其他的)
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:5900cid1.instance.oc1.ap-seoul-1.anuwgljr2ano4pqcpkcs63uecyrs5bqmhsblzgtkygtjvhb666kytctumtoa:5900 ocid1.instance.oc1.ap-seoul-1.anuwgljr2ano4pqcpkcs63uecyrs5xxxkytctumtoa
2)将命令粘贴到Linux服务器命令行执行。
注意:第一次执行命令有2个位置,需要输入 yes 回车!


 楼主| 发表于 2022-1-9 12:16:59 | 显示全部楼层
VNC连接服务器
使用VNC 客户端链接即可!然后就成功了!!
服务器IP:8000




Windows版
这部分操作使用的是 Windows 10 + VNCviewer绿色版
准备工作
1)VNC链接工具,【VNC Connect】或者【VNCviewer绿色版(解压密码:http://RUYO.net)】。
2)Windows 10 需要安装 Git 和 PuTTY(下载地址参考附录部分)
提醒:PuTTY须安装到 C:\Program Files\
生成SSH KEY
这里严重不建议使用 PuTTY 生成 SSH KEY!
1)利用Git Bash生成!
打开菜单 – Git – Git Bash


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

12//生成SSH KEYssh–keygen



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


SSH公钥:id_rsa.pub
SSH私钥: id_rsa
配置控制台
这里和Linux版的操作基本一样,将SSH公钥复制进去!
等到链接的状态变成【活动】,点击【⋮】 – 【复制Windows的VNC连接】


SSH私钥转换
由于Oracle Cloud VNC 识别不了上面的SSH私钥,需要利用下面的工具转一下!
1)打开菜单 – PuTTY – PuTTYgen


2)打开的界面点击【Load】,选择上面生成的SSH私钥。
如图操作,选择id_rsa ,出现提示框点击确定即可!




3)点击【Save private key】,将转换后的私钥保存到文件目录(记住该文件目录后面要用到!)。
PS:尽量要保存到 .ssh 目录中,命名要ruyo.ppk (后面有一键生成命令必须这样!)




VNC命令重构
直接复制处理的命令,执行上有一些问题。这里需要将命令修改一下!主要是替换以下内容:
1)替换 plink.exe 文件目录
2)替换PPK文件目录
3)将1条命令 转成 2条命令来执行
原始命令:
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 5905cid1.instance.oc1.ap-seoul-1.anuwgljr2ano4pqcpkcs63uecyrs5bqmhsblzgtkygtjvhb666kytctumtoa:5905 http://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
转换后命令:
第一条命令:
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 5905cid1.instance.oc1.ap-seoul-1.anuwgljr2ano4pqcpkcs63uecyrs5bqmhsblzgtkygtjvhb666kytctumtoa:5905 http://instance-console.ap-seoul-1.oraclecloud.com
第二条命令:
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 或者 开始菜单鼠标右键)


2)在2个 PowerShell 分别执行 2条VNC命令。
提醒:命令执行后,显示 Access granted. Press Return to begin session. 需要再按一次回车!!




VNC连接服务器
使用VNC 客户端链接即可!然后就成功了!!
localhost:5900
这里我们使用默认端口基本上没啥太大问题!




附录最后总结
本文有几个疑惑不知道原因,知道的大佬可以留言指导一下!
1)为什么PuTTY 生成的 SHH 密钥 无法识别?(怀疑是密钥类型或者长度)
2)直接复制VNC原始命令不能执行?(原命令有一些错误不显示,命令有2步确认的操作?)
以上博主没有做深入的摸索!

您需要登录后才可以回帖 登录 | 注册

本版积分规则

Archiver|手机版|小黑屋|中国飞逸网

GMT+8, 2024-4-20 10:00

Powered by Discuz! X3.5

© 2001-2024 Discuz! Team.

快速回复 返回顶部 返回列表