c++ 检查远程主机端口_SSH只能用于远程Linux主机?那说明你见识太小了!

今天小编为大家分享一篇关于SSH 的介绍和使用方法的文章。本文从SSH是什么出发,讲述了SSH的基本用法,之后在远程登录、端口转发等多种场景下进行独立的讲述,希望能对大家有所帮助。

1

什么是SSH?

SSH是一种网络协议,用于计算机之间的加密登录。最早的时候,互联网通信都是明文通信,一旦被截获,内容就暴露无疑。1995年,芬兰学者Tatu Ylonen设计了SSH协议,将登录信息全部加密,成为互联网安全的一个基本解决方案,迅速在全世界获得推广,目前已经成为Linux系统的标准配置。

2

SSH登录原理

3af01b57d15a387552bc5f44d109d54c.png

3

SSH基本用法

语法:

ssh -p 22 user@host
参数: -p:指定端口号。 user:登录的用户名。 host:登录的主机。

默认的端口号为22,当端口号为22的时候,可以省略,直接使用如下方式:

ssh user@host

此外,如果本地正在使用的用户名与远程登录的用户名一致,登录用户名也是可以省略的,即如下:

ssh host

4

SSH远程登录实例

现在我有两台linux虚拟机,上面安装都是centOS6.5,ip分别为192.168.13.135和192.168.13.138,如下图:

a5d313ed368fbf96720a47a4f40be20e.png

c546daafb47def978197ed152948b60a.png

现在,我需要操作的是通过SSH在192.168.13.138上面,登录到192.168.13.135上面。 首先,我们可以使用如下命令,查看两台机器是否启用了ssh。
netstat -ntlp |grep ssh

b4f2ab5ee43891df5635e4203eb045be.png

使用如下命令进行连接。

ssh -p 22 root@192.168.13.135
若在本机上是首次登录该远程主机,则会出现如下界面。

6a13318edcc97348fd55ea9d3af5b5d6.png

大致意思就是,无法确认host主机的真实性,只知道它的公钥指纹,问你还想继续连接吗?输入yes即可。

140568c0eccf793e0ea673a3d42f8e07.png

然后输入密码,即可连接ok了。

12cf5f9ac23df8fb3dd8baf4b2b98cb9.png

要想退出,直接输入exit即可。

2588ca228a7fb8a4280f15f7b063ea89.png

5

SSH端口转发

SSH 不仅仅能够自动加密和解密 SSH 客户端与服务端之间的网络数据,同时,SSH 还能够提供了一个非常有用的功能,那就是端口转发,即将TCP 端口的网络数据,转发到指定的主机某个端口上,在转发的同时会对数据进行相应的加密及解密。如果工作环境中的防火墙限制了一些网络端口的使用,但是允许 SSH 的连接,那么也是能够通过使用SSH转发后的端口进行通信。转发,主要分为本地转发与远程转发两种类型。

1.转发的参数

-C:压缩数据-f :后台认证用户/密码,通常和-N连用,不用登录到远程主机。-N :不执行脚本或命令,通常与-f连用。-g :在-L/-R/-D参数中,允许远程主机连接到建立的转发的端口,如果不加这个参数,只允许本地主机建立连接。-L : 本地端口:目标IP:目标端口-D : 动态端口转发-R : 远程端口转发-T :不分配 TTY 只做代理用-q :安静模式,不输出 错误/警告 信息

2.本地转发

有本地网络服务器的某个端口,转发到远程服务器某个端口。说白了就是,将发送到本地端口的请求,转发到目标端口。格式如下: ssh -L 本地网卡地址:本地端口:目标地址:目标端口 用户@目标地址。 现在我们利用本地转发来解决一个问题,比如我们有两台机器,如下: centos A(192.168.13.139) centos B(192.168.13.142)

7165a7fd09fac059decf96597e8f1fe3.png

现在,centos B(192.168.13.142)机器上面安装了mysql,并设置了运行任何主机连接,如下:

5267b003e2d858548686d2c9dbd7bb73.png

此时,在centos A(192.168.13.139)上面是可以连上centos B(192.168.13.142)的mysql,如下:

2d814abf7608a7d7c24df3fd5f7cf2eb.png

那么,现在我开始centos B(192.168.13.142)限制不允许外部ip连接,仅仅让127.0.0.1连接,如下:

5d510ec49c042a1a1dac08bda7afa6d3.png

此时,centos A(192.168.13.139)上面怎么连接上centos B(192.168.13.142)的mysql呢?

此时,我们还是使用上面的mysql连接方式,肯定会报错,如下:

4918bc244a515d53624fd5c438d03ee6.png

当然在centos B(192.168.13.142)mysql还是可访问的。

8a186a759ba670175e59c38f5df087b6.png

这个时候,我们就可以使用本地端口转发了,将本地的某个端口,映射到centos B(192.168.13.142)机器上面的,如下:

ssh -L 127.0.0.1:3306:127.0.0.1:3306 root@192.168.13.142

因为本地网卡地址是可以省略的,上面的转发,可以简写为:

ssh -L 3306:127.0.0.1:3306 root@192.168.13.142

当然,ssh连接的时候,若两台机器的用户名相同,也是可以省略的,即命令可以简写为:

ssh -L 3306:127.0.0.1:3306 192.168.13.14

上面的代码就是将本地的3306端口,转发到192.168.13.142的3306端口。因为centos B(192.168.13.142)上面的mysql使用的3606端口。当然,我们首先得看看本地的3306端口是否被占用,如被占用,可以使用其他的端口。

数据流向如图:

98ed41d8d6d0214f92f7f772c36e223f.png

首先,centos A(192.168.13.139)上的应用将数据发送到本地的127.0.0.1上面的3306端口。 然后,centos A(192.168.13.139)将3306端口的数据,通过SSH转发到centos B(192.168.13.142)的3306端口。 接着,centos B(192.168.13.142)将处理后的数据,原路返回给centos A(192.168.13.139)。 如果是首次通过ssh连接cetosB该机器,则会提示确认公钥,并让你选择是否确定连接。

e6f9ead245d5594528af3806fb4f0e1a.png

此时,我们在centos A上面连接centos B上面的mysql,就可以这么写了。

bin/mysql -h127.0.0.1 -uroot -p
如下:

80f04bb8b99816ebecb8a819a987f54c.png

我们可以通过下面命令,在centosA查看ssh转发监听的进程。

80944f3fc764701158664892f2aec632.png

3.远程转发

由远程服务器的某个端口,转发到本地网络的服务器某个端口。说白了,就是将发送到远程端口的请求,转发到目标端口。格式如下: ssh -R 远程网卡地址:远程端口:目标地址:目标端口 下面三台机器为例,如下: centos A(192.168.13.139) centos B(192.168.13.142) win7(10.18.78.135) 假设,win7(10.18.78.135)与centos B(192.168.13.142)不能直接连接,但是win7(10.18.78.135)与centos A(192.168.13.139)可以连接centos B(192.168.13.142)也可以centos A(192.168.13.139)连接,那么,我们就可以在centos A(192.168.13.139)上面使用远程端口转发了,让win7(10.18.78.135)与centos B(192.168.13.142)进行通信。
ssh -R 127.0.0.1:80:10.18.78.135:80 root@192.168.13.142
即centos B(192.168.13.142)监听自己的80端口,然后将所有数据,由centos A(192.168.13.139)发给win7(10.18.78.135)。

6

SSH的远程操作

ssh远程操作,主要用于在远程的机器上面执行某个操作,格式如下:

ssh user@host 'command'
案例1、在机器A(192.168.13.148)中查看机器B(192.168.13.149)的操作系统类型。 在A机器上面执行如下代码:
ssh  dequan@192.168.13.149  'uname -a'
案例2、将机器A(192.168.13.148)中test文件夹复制到B机器(192.168.13.149)。 在A机器上面,执行如下命令:
tar -cz test | ssh dequan@192.168.13.149 'tar -xz'
当然,我们也可以使用scp命令或rz命令,传输文件。 案例3、在机器A(192.168.13.148)处查看B机器(192.168.13.149)是否监听了1080端口。 在A机器上面,执行如下命令:
ssh dequan@192.168.13.149 'netstat -tln |grep 1080'

1e16e8db6911d45d801f44801e419e1d.png

7

SSH的本地转发

本地转发,说白了,就是把发到本地的某个端口请求,转发到远程的某台机器上面。格式如下:

ssh -L  [本地地址:]本地端口:远程地址:远程端口 远程用户@远程地址

案例1、在机器B(192.168.13.149)上面访问机器A(192.168.13.148)的服务。

现在,我们在A机器上面,启动了Nginx服务,如下:

bf416c5f1fe04497152ca1bf98aa28b3.png

我们希望B机器也能够这样使用A机器上面的服务。需要把B机器上面80端口请求,转发到A机器上面。目前在B机器这样执行,是报错的,如下:

a81596fb95a3f9a5d209520649171097.png

需要在B机器上面,执行如下代码:
ssh -f -N -L 127.0.01:80:192.168.13.148:80 dequan@192.168.13.148

然后,在B机器上面,访问A机器的服务,就想访问自身的服务一样。

44e88cbafa0c7989a347bc30f96d6b08.png

8

SSH的远程转发

远程转发,即把发给远程机器的某个端口请求,转发到本地的机器上面。格式如下:

ssh -R [远程地址:]远程端口:本地地址:本地端口 远程用户@远程地址

在上面的案例中,我们也可以通过远程转发来实现。即在A机器上面执行如下代码:

sudo ssh -f -N -R 8081:127.0.0.1:80 dequan@192.168.13.149
我们监听了B机器的8081端口,把该端口的请求,转发到A机器上面。 可以在B机器上面看到,我们的监听,如下:

ed25defa455d53ef7b393a3e78efaa8b.png

此时,执行如下命令,就会被转发到A机器的127.0.0.1的80端口,如下:

8ff5e305f81e146b119c0383a2d062b2.png

1、利用远程转发,实现代理功能

目前B机器,只能在自己127.0.0.1的80端口监听并转发,如何让B机器作为代理,转发其他机器的请求到A机器上面呢?比如,现在有一台机器C(192.168.13.143),C不能访问A,但是能够访问B。如何让C利用B来访问A呢? 此时,需要将B的监听,由127.0.0.1:8081,改为0:0.0.0:8081,修改sshd的配置/etc/ssh/sshd_config。
 vim /etc/ssh/sshd_config如果有GatewayPorts no改为GatewayPorts yes没有,添加即可然后重启sshdsudo service sshd restart
然后重新,设置动态转发,如下:
ssh -f -g  -N -R 8081:127.0.0.1:80 dequan@192.168.13.149
可以看到,此时B机器,已经监听了0:0.0.0:8081

d3540cc43ef6735709ef897d34698846.png

在C机器上面,我们通过curl模拟请求,利用B机器做代理,如下:
curl -x 192.168.13.149:8081 127.0.0.1

c93238e6c678efd8300d446aa2ad5a3e.png

当然,如果还有其他机器,也可以使用类似的方式,来请求A机器。

9

SSH的动态转发

对于SSH的本地转发和远程转发,都需要将本地端口和远程端口一一绑定,格式如下:
ssh -D [本地地址:]本地端口号 远程用户@远程地址

比如,把发到B机器上面的请求,都转发到A机器上面,让A机器去执行请求。

10

SSH存在的问题

如果有人截获了登录请求,然后冒充远程主机,将伪造的公钥发给用户,那么用户很难辨别真伪。因为不像https协议,SSH协议的公钥是没有证书中心(CA)公证的,也就是说,都是自己签发的。 可以设想,如果攻击者插在用户与远程主机之间(比如在公共的wifi区域),用伪造的公钥,获取用户的登录密码。再用这个密码登录远程主机,那么SSH的安全机制就荡然无存了。这种风险就是著名的"中间人攻击"(Man-in-the-middle attack)。

11

总结

本篇文章主要介绍了SSH的基本概念和实践中常用的一些方法,并没有涉及深层原理和优化的知识,在底层实现和协议具体内容还能继续深入研究。如果有什么疑问或建议,可以在下方留言。

- END -

精彩文章推荐:

Kubernetes 企业落地核心技术方案

一次搞明白 Docker 容器资源限制

10 分钟部署一个 Kubernetes 集群

部署一套完整的Kubernetes高可用集群(二进制)

一次搞明白 K8s Kubelet 垃圾回收机制

10 个Linux Awk文本处理经典案例Linux 系统故障排查,看这一篇就够了12年老司机总结的 5 条面试忠告,终身受用

5a91f1c4c3e3b4d40402001578cb3904.png

点亮,服务器三年不宕机370b49b755e2756a8e84bb3c96e448fe.gif

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
提供的源码资源涵盖了Java应用等多个领域,每个领域都包含了丰富的实例和项目。这些源码都是基于各自平台的最新技术和标准编写,确保了在对应环境下能够无缝运行。同时,源码中配备了详细的注释和文档,帮助用户快速理解代码结构和实现逻辑。 适用人群: 适合毕业设计、课程设计作业。这些源码资源特别适合大学生群体。无论你是计算机相关专业的学生,还是对其他领域编程感兴趣的学生,这些资源都能为你提供宝贵的学习和实践机会。通过学习和运行这些源码,你可以掌握各平台开发的基础知识,提升编程能力和项目实战经验。 使用场景及目标: 在学习阶段,你可以利用这些源码资源进行课程实践、课外项目或毕业设计。通过分析和运行源码,你将深入了解各平台开发的技术细节和最佳实践,逐步培养起自己的项目开发和问题解决能力。此外,在求职或创业过程中,具备跨平台开发能力的大学生将更具竞争力。 其他说明: 为了确保源码资源的可运行性和易用性,特别注意了以下几点:首先,每份源码都提供了详细的运行环境和依赖说明,确保用户能够轻松搭建起开发环境;其次,源码中的注释和文档都非常完善,方便用户快速上手和理解代码;最后,我会定期更新这些源码资源,以适应各平台技术的最新发展和市场需求。 所有源码均经过严格测试,可以直接运行,可以放心下载使用。有任何使用问题欢迎随时与博主沟通,第一时间进行解答!

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值