专栏名称: 数据分析与开发
伯乐在线旗下账号,分享数据库相关技术文章、教程和工具,另外还包括数据库相关的工作。偶尔也谈谈程序员人生 :)
目录
相关文章推荐
数据中心运维管理  ·  谷歌云大规模宕机 ·  昨天  
数据中心运维管理  ·  拥有这3张故障对照表,数据中心空调维修变得很简单! ·  2 天前  
dbaplus社群  ·  MySQL 8.0 的这个参数千万别乱改! ·  昨天  
KubeSphere云原生  ·  OceanBase 上架 ... ·  2 天前  
数据中心运维管理  ·  什么是数据中心布线以及主要布线标准? ·  3 天前  
51好读  ›  专栏  ›  数据分析与开发

“懒惰” Linux 管理员的 10 个关键技巧

数据分析与开发  · 公众号  · 数据库  · 2016-08-11 20:57

正文

请到「今天看啥」查看全文


New UNIX password :

Retype new UNIX password :

passwd : all authentication tokens updated successfully

现在可以重启了,机器将使用新密码启动。


技巧 5:SSH 后门


有很多次,我所在的站点需要某人的远程支持,而他却被公司防火强阻挡在外。很少有人意识到,如果能通过防火墙到达外部,那么也能轻松实现让外部的信息进来。 从本意讲,这称为 “在防火墙上砸一个洞”。我称之为 SSH 后门。为了使用它,必须有一台作为中介的连接到 Internet 的机器。 在本例中,将这样台机器称为 blackbox.example.com。公司防火墙后面的机器称为 ginger。此技术支持的机器称为 tech。图 4 解释了设置过程。


图 4. 在防火墙上砸一个洞


以下是操作步骤:


检查什么是允许做的,但要确保您问对了人。大多数人都担心您打开了防火墙,但他们不明白这是完全加密的。而且,必须破解外部机器才能进入公司内部。不过,您可能属于 “敢作敢为” 型的人物。自己进行判断应该选择的方式,但不如意时不抱怨别人。


使用 -R 标记通过 SSH 从 ginger 连接到 blackbox.example.com。假设您是 ginger 上的根用户,tech 需要根用户 ID 来帮助使用系统。使用 -R 标记将 blackbox 上端口 2222 的说明转发到 ginger 的端口 22 上。这就设置了 SSH 通道。注意,只有 SSH 通信可以进入 ginger:您不会将 ginger 放在无保护的 Internet 上。可以使用以下语法实现此操作:


~# ssh -R 2222:localhost:22 [email protected]


进入 blackbox 后,只需一直保持登录状态。我总是输入以下命令:


thedude@blackbox:~$ while [ 1 ]; do date; sleep 300; done


使机器保持忙碌状态。然后最小化窗口。


现在指示 tech 上的朋友使用 SSH 连接到 blackbox,而不需要使用任何特殊的 SSH 标记。但必须把密码给他们:


root@tech:~# ssh [email protected]


tech 位于 blackbox 上后,可以使用以下命令从 SSH 连接到 ginger:


thedude@blackbox:~$: ssh -p 2222 root@localhost


Tech 将提示输入密码。应该输入 ginger 的根密码。


现在您和来自 tech 的支持可以一起工作并解决问题。甚至需要一起使用屏幕!(参见 技巧 4)。


技巧 6:通过 SSH 通道进行远程 VNC 会话


VNC 或虚拟网络计算已经存在很长时间了。通常,当远程服务器上的某类图形程序只能在此服务器上使用时,我才需要 VNC。


例如,假设在 技巧 5 中,ginger 是一台存储服务器。许多设备都使用 GUI 程序来管理存储控制器。这些 GUI 管理工具通常需要通过一个网络直接连接到存储服务器,而这个网络有时保存在专用的子网络中。因此,只能通过 ginger 访问这个 GUI。


可以尝试使用 -X 选项通过 SSH 连接到 ginger 并启动它,但这对带宽要求很高,您需要忍受等待的痛苦。VNC 是一个网络友好的工具,几乎适用于所有操作系统。


假设设置与技巧 5 中的一样,但希望 tech 能访问 VNC 而不是 SSH。对于这种情况,需要进行一些类似的操作,不过转发的是 VNC 端口。执行以下操作步骤:


在 ginger 上启动一个 VNC 服务器会话。运行以下命令:


root@ginger:~# vncserver -geometry 1024x768 -depth 24 :99


这些选项指示启动服务器,分辨率为 1024×768,像素深度为每像素 24 位。如果使用较慢的连接设置,8 也许是更好的选项。使用 :99 指定可访问 VNC 服务器的端口。VNC 协议在 5900 处启动,因此 :99 表示服务器可从端口 5999 访问。


启动该会话时,要求您指定密码。用户 ID 与启动 VNC 服务器时的用户相同(本例中就是根用户)。


从 ginger 连接到 blackbox.example.com 的 SSH 将 blackbox 上的端口 5999 转发到 ginger。这通过运行以下命令在 ginger 中完成:


root@ginger:~# ssh -R 5999:localhost:5999 [email protected]


运行此命令后,需要将此 SSH 会话保持为打开状态,以便保留转发到 ginger 的端口。此时,如果在 blackbox 上,那么运行以下命令即可访问 ginger 上的 VNC 会话:


thedude@blackbox:~$ vncviewer localhost:99


这将通过 SSH 将端口转发给 ginger,但我们希望通过 tech 让 VNC 访问 ginger。为此,需要另一个通道。


在 tech 中,打开一个通道,通过 SHH 将端口 5999 转发到 blackbox 上的端口 5999。这通过运行以下命令完成:


root@tech:~# ssh -L 5999:localhost:5999 [email protected]


这次使用的 SSH 标记为 -L,它不是将 5999 放到 blackbox,而是从中获取。到达 blackbox 后,需要保持此会话为打开状态。现在即可在 tech 中使用 VNC 了!


在 tech 中,运行以下命令使 VNC 连接到 ginger:


root@tech:~# vncviewer localhost:99


.Tech 现在将拥有一个直接到 ginger 的 VNC 会话。


设置虽然有点麻烦,但比为修复存储阵列而四处奔波强多了。不过多实践几次这就变得容易了。


对此技巧我还要补充一点:如果 tech 运行的是 Windows® 操作系统,并且没有命令行 SSH 客户端,那么 tech 可以运行 Putty。Putty 可以设置为通过查找侧栏中的选项来转发 SSH 端口。如果端口是 5902 而不是本例中的 5999,则可以输入图 5 中的内容。


图 5. Putty 可以转发用作通道的 SSH







请到「今天看啥」查看全文


推荐文章
数据中心运维管理  ·  谷歌云大规模宕机
昨天
dbaplus社群  ·  MySQL 8.0 的这个参数千万别乱改!
昨天
数据中心运维管理  ·  什么是数据中心布线以及主要布线标准?
3 天前
乐趣微生活  ·  ?男的女的房中对话,好现实【NO8】
8 年前
十点读书会  ·  你整理的不是衣柜,而是乱糟糟的生活
8 年前
木雕  ·  这样的大烟斗你见过吗?
8 年前
算法与数学之美  ·  看得懂的复数--溯源复数的物理意义
8 年前
程序员大咖  ·  警惕你身边的程序员
8 年前