百度360必应搜狗淘宝本站头条
当前位置:网站首页 > 编程文章 > 正文

今天我们聊聊什么是ip地址,什么又是公网和私网

qiyuwang 2024-10-19 08:54 14 浏览 0 评论

一、IP 地址

ip 地址相当于收发快递时的收货地址和发货地址

IPV4 的地址:192.168.0.1

11000000.10101000.00000000.00000001

windows 使用 >ipconfig;linux 使用 ifconfig

可以看到 IPV4 地址 / inet 旁边的就是 IP 地址

  1. IP 地址的分类

IP 地址有 32 位,分为 A B D E 四类

  • A 类:0 + 7 位网络号 + 24 位主机号
  • B 类:10 + 14 位网络号 +16 位主机号
  • C 类:110 +21 位网络号 +8 位主机号
  • D 类:1110 +28 位组播地址
  • E 类:1111 +28 位以后用

网络号:相当于停车场主机号:相当于停车位

1 个停车场可以有多个停车位;A 类相当于大型停车场少,但是大型停车场内停车位多;C 类相当于小型停车场多,但是小型停车场内停车位少

以上的分类机制已经被取代,因为不同类别的网络号和主机号数量悬殊取而代之,不再使用分类 ABCD 法,使用以下分类机制:CIDR 无类别域间路由

只保留网络号和主机号,用 “/” 告诉用户多少位是网络号,其余是主机号172.20.61.69/20 网络号:20 位;主机号:12 位能够放 2*12 次方 = 4096 台机子

二、让 IP 够用

就算把所有 IP 分出去:2*32 次方 = 4294967296 42 亿也不够用,这是基于每人都处在一层的情况下

【取而代之,将网络分为两层,如下图】

2 个人组成小网络(5 6)公用一个 IP,但是 5 6 内部的 IP 不一样 ,5 6 构成的网络叫做:局域网(内网)5 6 的 IP 叫做:私有 IP(内网 IP)

1 2 构成的网络叫做:广域网,1 2 的 IP 叫做:公有 IP(公网 IP)

在 ABC 类 IP 中,也有私有和公有两部分

  • A 类局域网部分 IP:10.0.0.0~10.255.255.255
  • B 类局域网地址 IP:172.16.0.0~172.31.255.255
  • C 类局域网地址 IP:192.168.0.0~192.168.255.255

上面只考虑了一层局域网,其实局域网内还能再分成多层,局域网内再嵌套局域网。就像下面这样,这样能用的 IP 数量就更多了。

三、我自己的 IP 地址怎么看

ipconfig 里面的 IPV4 地址 == 内网 IP百度搜索:我的 IP 地址 == 公网 IP

四、局域网内的私有 IP 如何访问局域网外的公有 IP?

需要进行 IP 转换:NAT:全称NetworkAddressTranslation,网络地址转换。基本上家用路由器都支持这功能。

发送 / 接收的数据包相当于 收发快递的快递包

数据包的内容:

发送数据包的过程:

IP 转换过程:

  • 1、A 发送 C:在 a 准备发送数据包时:我的电脑会构造 IP 数据包,发送端 IP 地址是 192.168.30.5, 接收端 IP 地址是 192.168.30.5;电脑把数据包发到 NAT 路由器,路由器把源 IP 地址 192.168.30.5 改成:20.20.20.20,这个过程叫做 SNAT(Source Network Address Translation,源地址转换)

并且会在 NAT 路由器里,留下192.168.30.5-》20.20.20.20 的映射记录,下次就会直接在记录里读取了。最后就去找接收端 IP 了

  • 2、C 响应 A:接收端填:20.20.20.20,发送端填:30.30.30.30,在经过 NAT 时,会找到之前192.168.30.5-》20.20.20.20 的映射记录,然后把目的 IP 地址修改为内网 IP192.168.30.5,,这个过程叫做DNAT(Destination Network Address Translation,目的地址转换)。

但是一个公网 IP 下,有多个私网 IP,响应时怎么找映射哪个?

这个时候用到的是 NAPTNAPT(Network Address Port Transfer , 网络地址端口转换 )。

加入其他信息区分内网里的各个网络连接,就是端口

IP 数据包属于【网络层】,端口存在于【传输层】的 TCP 和 UDP 数据报文里

那么最后数据包的组成是:IP header + TCP header / UDP header + 数据

为什么 PING 没有带端口信息,也能够接收响应?

ICMP 协议,NAT 路由器做了特殊处理。ping 报文头里有个Identifier的信息,它其实指的是放出 ping 命令的进程 id。对 NAT 路由器来说,这个Identifier的作用就跟端口一样。

当我们去抓包的时候,就会发现有两个Identifier,一个后面带个BE(Big Endian),另一个带个LE(Little Endian)。

其实他们都是同一个数值,只不过大小端不同,读出来的值不一样。就好像同样的数字 345,反着读就成了 543。这是为了兼容不同操作系统(比如 linux 和 Windows)下大小端不同的情况。

五、内网穿透

家里启动了一个 http 服务,地址是 192.168.30.5:5000,公司里的手机想访问,却访问不了

外网机器如何访问内网服务?

因为 NAT 的存在,我们只能从内网主动发出连接,NAT 没有记录映射关系的话,也转发不了数据。

为了解决这个问题,可以在公网加一台服务器 X,暴露一个访问域名,让内网服务主动连接服务器 X,NAT 也会有一个内网到服务器 X 的映射关系,然后所有人去访问服务器 X,就可以了。

六、两个局域网设备如何建立连接?

  • 1.小明的 QQ 和小红的 QQ 客户端如何建立连接?

两个 QQ 客户端之间隔了一个聊天服务器,QQ 登录时,主动向公网的聊天服务器建立连接,两边的 NAT 都有公网聊天服务器和私网的映射关系,

  • 2.P2P 下载,没有第三方服务器,怎么进行通讯

P2P 下载 = 种子迅雷下载

下图为NAT 打洞,我们现在常见的都是锥形 NAT

来源:入门小站

相关推荐

# 安装打开 ubuntu-22.04.3-LTS 报错 解决方案

#安装打开ubuntu-22.04.3-LTS报错解决方案WslRegisterDistributionfailedwitherror:0x800701bcError:0x80070...

利用阿里云镜像在ubuntu上安装Docker

简介:...

如何将Ubuntu Kylin(优麒麟)19.10系统升级到20.04版本

UbuntuKylin系统使用一段时间后,有新的版本发布,如何将现有的UbuntuKylin系统升级到最新版本?可以通过下面的方法进行升级。1.先查看相关的UbuntuKylin系统版本情况。使...

Ubuntu 16.10内部代号确认为Yakkety Yak

在正式宣布Ubuntu16.04LTS(XenialXerus)的当天,Canonical创始人MarkShuttleworth还非常开心的在个人微博上宣布Ubuntu下个版本16.10的内...

如何在win11的wsl上装ubuntu(怎么在windows上安装ubuntu)

在Windows11的WSL(WindowsSubsystemforLinux)上安装Ubuntu非常简单。以下是详细的步骤:---...

Win11学院:如何在Windows 11上使用WSL安装Ubuntu

IT之家2月18日消息,科技媒体pureinfotech昨日(2月17日)发布博文,介绍了3中简便的方法,让你轻松在Windows11系统中,使用WindowsSubs...

如何查看Linux的IP地址(如何查看Linux的ip地址)

本头条号每天坚持更新原创干货技术文章,欢迎关注本头条号"Linux学习教程",公众号名称“Linux入门学习教程"。...

怎么看电脑系统?(怎么看电脑系统配置)

要查看电脑的操作系统信息,可以按照以下步骤操作,根据不同的操作系统选择对应的方法:一、Windows系统通过系统属性查看右键点击桌面上的“此电脑”(或“我的电脑”)图标,选择“属性”。在打开的...

如何查询 Linux 内核版本?这些命令一定要会!

Linux内核是操作系统的核心,负责管理硬件资源、调度进程、处理系统调用等关键任务。不同的内核版本可能支持不同的硬件特性、提供新的功能,或者修复了已知的安全漏洞。以下是查询内核版本的几个常见场景:...

深度剖析:Linux下查看系统版本与CPU架构

在Linux系统管理、维护以及软件部署的过程中,精准掌握系统版本和CPU架构是极为关键的基础操作。这些信息不仅有助于我们深入了解系统特性、判断软件兼容性,还能为后续的软件安装、性能优化提供重要依据。接...

504 错误代码解析与应对策略(504错误咋解决)

在互联网的使用过程中,用户偶尔会遭遇各种错误提示,其中504错误代码是较为常见的一种。504错误并非意味着网站被屏蔽,它实际上是指服务器在规定时间内未能从上游服务器获取响应,专业术语称为“Ga...

猎聘APP和官网崩了?回应:正对部分职位整改,临时域名可登录

10月12日,有网友反映猎聘网无法打开,猎聘APP无法登录。截至10月14日,仍有网友不断向猎聘官方微博下反映该情况,而猎聘官方微博未发布相关情况说明,只是在微博内对反映该情况的用户进行回复,“抱歉,...

域名解析的原理是什么?域名解析的流程是怎样的?

域名解析是网站正常运行的关键因素,因此网站管理者了解域名解析的原理和流程对于做好域名管理、解决常见解析问题,保障网站的正常运转十分必要。那么域名解析的原理是什么?域名解析的流程是怎样的?接下来,中科三...

Linux无法解析域名的解决办法(linux 不能解析域名)

如果由于误操作,删除了系统原有的dhcp相关设置就无法正常解析域名。  此时,需要手动修改配置文件:  /etc/resolv.conf  将域名解析服务器手动添加到配置文件中  该文件是DNS域名解...

域名劫持是什么?(域名劫持是什么)

域名劫持是互联网攻击的一种方式,通过攻击域名解析服务器(DNS),或伪造域名解析服务器(DNS)的方法,把目标网站域名解析到错误的地址从而实现用户无法访问目标网站的目的。说的直白些,域名劫持,就是把互...

取消回复欢迎 发表评论: