局域网地址为什么是192.168.X.X?为什么连上公司的VPN就上不了网?

注:本文主要目的是给程序员讲述一些局域网/VPN的基本知识,并不涉及到具体的实操。关于如何安装VPN服务器、配置VPN客户端及修改Windows路由表等具体实操内容,请自行搜索。

RFC

局域网地址为什么是192.168.X.X?简单地说这是RFC的建议,具体请查看: https://tools.ietf.org/html/rfc5735#section-4

准确说,不只有192.168.X.X,一共有3段地址可以作为局域网的地址:


所以看到10开头的或者192.168开头的IPv4地址,那就可以认为是局域网地址了,比较特殊的是172开头的,因为它的掩码是12,不是8的整数倍,所以光看到172开头的地址还不能马上确定是不是局域网地址,要看是否在172.16.X.X至172.31.X.X之间。

既然是建议,那就不是技术上的硬性要求,那么我能不能把局域网地址设置成别的?答案是肯定的。

比如你可以设置成20.8.13.46,看起来像个公网地址对不?但这样并不会有什么好处,反而很可能会引起冲突,想一下假如这真的是一个你要访问的公网地址,那你可能就访问不到了,因为你的网络适配器认为这是个局域网地址,不会走网关到公网去。

我们有个客户的局域网就是类似这种“非标”的,不按套路出牌,造成了不少困扰。

另外提一下RFC,RFC是Request For Comments的意思,意思就是“草案”,Internet开始构建的时候,全世界的工程师们起草的各种文档,不断讨论更新和修正,所以叫RFC,时过境迁,很多文档都成为了事实上的标准,但RFC这个名字惯性太大,保留了下来。

为什么要弄3个网段?

因为这3个网段正好对应了A类、B类和C类地址。

A类地址组成的局域网可以容纳海量主机,B类地址能容纳的主机数量也很多,C类地址则只可以容纳254台主机。

事实上,就算你用了A类地址,你也可以设置子网掩码为24(255.255.255.0的表示,即24个1)来使得这个A类地址和C类地址一样,只容纳254台主机。

但不管怎么说,这是一种广泛被接受的约定,所以当系统看到一个A类地址的时候,如果没有额外的配置说明,就默认它的子网掩码是8,同理,默认B类地址子网掩码为16,C类为24。

那我们应该选择哪个网段好呢?我认为用B类地址最为灵活!为什么?要解释可不是那么容易,接着看吧。

为什么连上公司的VPN就上不了网?

嗯?怎么突然扯这么一个风马牛不相关的问题?没事,接着看呗。

为什么连上公司的VPN就上不了网?这是一个困扰了很多人的问题,“通俗”(但不正确)的说法就是一旦连上了VPN,就相当于接入了目标的内网去,当然不能正常访问其它网络了。我首先声明这种说法并不正确,下面具体来说说。

站在我们的视角来说,VPN干了两件事情:

1,创建一个虚拟网卡,未连接的时候这个网卡是灰色的,即未启用,这个虚拟网卡我们称之为VPN网络适配器
2,连接VPN的时候,虚拟网卡启用,并修改Windows的路由表使得部分或全部网络访问都透过VPN网络适配器

VPN网络适配器可以在Windows的控制面板的“控制面板\网络和 Internet\网络和共享中心”里的“更改适配器设置”里看到。我们程序员先了解到这里即可,至于VPN客户端如何与VPN服务器打交道,使用怎样的隧道协议,过程如何,这个是另一个超级大的话题了,这里不表。

从“适配器”这个驱动层面的东西来看,VPN是比较“底层”的,我们的程序不需要关心这个,不像代理服务器,需要在程序里设。

现在,连VPN就上不了网这个问题应该怎么解释?根据前面提到的那1、2两步,我们不难知道,问题出在第2步上,比如你在家里,你要连接公司的内网,IP地址是192.168.20.0/24,现在连接,成功,你能轻松访问192.168.20.112这台主机了,但不幸的是,根据Windows当前的路由表配置,你的任何网络访问都会走VPN网络适配器,于是你访问taobao.com也会走VPN,但公司的网络限制了对taobao.com的访问啊,所以就出现这个问题了。

很显然,此问题有两种解,一是让你们公司IT开放对taobao.com的访问;二是自己修改Windows路由表,使得对其它网络(包括公网)的访问不走VPN。显然你只能采取第二种方案。

修改路由表是解决这类问题的必杀技,这是可以肯定的,但有时候会比较麻烦,假如你用的VPN客户端不是Windows自带的,而是公司/客户提供的,每次连接的时候,它就会在你的Windows的路由表中塞入一大堆很令人费解的配置,这些乱七八糟配置使得你的正常网络的访问变得不可能,你要一条条把这些配置删除,然后把必要的一条路由规则加进去,符合这条规则的才走VPN,否则走原先默认的适配器,这样是可以的,但是但是,这种VPN一旦断开,你重连的时候,你会发现你辛辛苦苦配的Windows路由表又被它重置了,每次都如此,让人无法接受,前面我提到的那个用“非标”局域网地址的客户的VPN就是这样的……这种情况很难有好的解,现在我们讨论另一种更普遍的情况,那就是使用的是Windows自带的VPN客户端。

可以在前面提到的控制面板的对应的VPN网络适配器里进行下图这样的设置,把“在远程网络上使用默认网关”这个选项去掉。

这样在VPN连接的时候它就基本上不会修改Windows的路由表,我是说基本上不会,实际上,它会默认加一条路由规则,我研究下来是这样的一条规则:

假如你连接的网络是192.168.20.0/24,那它就会加这么一条规则:

192.168.20.0/24 => VPN Adapter

因为Windows认为192开头的这个地址是个C类地址,掩码自然是24,这个时候如果服务主机就在192.168.20.0/24这个网段上,你可以直接访问,并且你访问别的网络照旧,不会受VPN的影响,很好!

但你要注意,很可能你VPN连接到的只是一个VPN LAN的虚拟网络,而真实的服务器的地址是在192.168.21.0/24这个网段,这时候你发现你访问不了服务器,因为对192.168.21.0/24这个地址段的访问不符合路由规则,不走VPN。怎么办?

方法一,自行增加一条路由规则:

192.168.21.0/24 => VPN Adapter

这次不算很麻烦,因为规则明确且只有一条,你可以把这条规则作为永久规则,即便VPN断开之后,它依旧还在,不受影响。但要自己设规则,还是有些麻烦,万一有些人就是不会呢?能不能更加简单点?

方法二,重新规划IP地址!

嗯!绕了半天,终于回来了!

以10.X.X.X作为局域网地址的情况

假如连接目标为10.186.2.0/24,而服务主机所在的网段是10.186.3.0/24,我们看看实际发生什么事。

由于10开头的地址被视作A类地址,它的子网掩码是8。Windows自动增加的路由规则是:

10.0.0.0/8 => VPN Adapter

你尝试访问10.186.3.0/24网段的时候,是符合这条路由规则的,因此你可以访问10.186.3.0/24网段的主机。

是不是很神奇?设置成192.168.X.X有问题,换成10.X.X.X就好了。

但是,这里面可能有问题!那就是前面一直没提到的地址冲突的问题。

假如你所在的局域网也是10.X.X.X这样的地址,那就糟糕了,你会发现你本地网络都没法访问了,原因就是符合了这条路由规则,走了VPN。

那使用192.168.X.X地址有没有可能出现冲突?当然有,比如你的本地网络是192.168.1.0/24,目标网络也是192.168.1.0/24,这非常有可能啊,网管们都喜欢这么设置,那么冲突是肯定的。

以172.X.X.X作为局域网地址的情况

我前面提到了,并不是172开头的地址都表示是局域网地址,只有172.16.X.X到172.31.X.X才是。大家注意,172是属于B类地址,它默认的掩码是16,这就很有趣了,请看下面这个图:

按照我的掩码设计,A、B、C、D是4个不同的网络,而根据B类地址默认的掩码,A和B是同一个网络,C和D是同一个网络。假如我是网管,我就用IP地址的第二个数字来区分厂区,厂区和厂区间不直连,而厂区内再用IP地址的第三个数字来区分不同的内网,这就是我前面所说的“灵活”。

现在你在图中的“你的位置”,即A网中,由于直接的物理连接,你是能直接访问B网的,现在你要用VPN拨到D网,想想会怎样?按前面说的,Windows会创建这么一条路由规则:

172.19.0.0/16 => VPN Adapter

OK不OK?非常OK,你能顺利访问D网,且访问本地的A网和B网都不受影响。你要注意的只是好好规划地址,避免直接的冲突就行,比如用172.21.14.0/24这种偏冷门的地址。

猜你喜欢

转载自www.cnblogs.com/guogangj/p/10991120.html