Linux操作系统编程——网络

网络编程

目的:不同主机进程间通信

需要解决的问题:

1,主机与主机之间物理层面必须互联互通

2,进程与进程之间在软件层面必须互联互通

交换机:短距离网络通信,实现局域网内通信

局域网:短距离的数据传输

路由器:负责路由,即路径选择,将数据上传至广域网内的路由器

广域网:多个路由器组成的数据转发集合中心。可以实现远距离数据传输

IP地址:计算机的软件地址,用来标识计算机设备

同一局域网中不可能出现IP地址相同的设备

MAC地址:计算机的硬件地址(固定)

网络的端口号:标记同一主机上的不同网络进程

网络协议

是一种网络通信标准

OSI七层模型(理论模型)

开放系统互联模型,规定了不同设备间网络通信的通信标准

|-------|--------------------------------------------------------------------|
| 模型 | 功能 |
| 应用层 | 要传呼的数据信息,例如文件传输,电子邮件 |
| 表示层 | 数据加密、解密操作,压缩,解压缩 |
| 会话层 | 建立数据传输通道,即会话 |
| 传输层 | 决定数据的传输方式:UDP、TCP。例如端口号 |
| 网络层 | 实现数据路由,路径规划。例如路由器 |
| 数据链路层 | 封装成帧,点对点通信(局域网内通信),差错检测。例如交换机 |
| 物理层 | 定义物理设备标准、电器特征,比如网线、光纤等传输介质,将数据链路层中的数字信号转为物理信号,即高低电频的方式进行数据发送,称为比特流 |

注:从下到上,依次接近用户,应用层最接近用户,物理层位最底层

TCP/IP五(或者四)层模型(应用模型)

|-------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 模型 | 功能 |
| 应用层 | http:超文本传输协议 https:加密版超文本传输协议(SSL加密算法) FTP:文件传输协议(在传输层使用TCP的传输方式) TFTP:简单文件传输协议(使用UDP传输方式)(效率高但可能数据丢失) MQTT:消息队列遥测传输协议(物联网协议) DNS:域名解析服务(www.***.com)将域名转为IP地址 |
| 传输层 | TCP:传输控制协议,必须优先确认数据传输的通道,相对安全可靠 UDP:用户数据报协议,无需建立连接通道 |
| 网络层 | IPv4:32位整型数据表示IP地址 IPv6:128位 |
| 数据链路层 | ARP:地址解析协议,实现IP地址和MAC地址的转换 |
| 物理层 | 规定设备标准等 |

注:四层模型就是在五层模型的基础上,将数据链路层和物理层结合起来称网络接口层

IP协议

在Windows系统上,win+r,cmd,密令ipconfig查看

Linux系统上,密令为ifconfig

例:192.168.0.140,点分十进制,为用户看到的表示形式。在内存中的存储形式是,192、168、0、140分别占一个字节,总共32bit

IPv4地址的组成形式:IP地址 = 网络位 + 主机位

网络位:该IP地址位于那个网段(局域网)内

主机位:这个网段(局域网)第几台主机

子网掩码为全为1的位为当前IP地址的网络位,全为0的位为主机位,例如255.255.255.0的子网掩码,对应到IP地址上,192.168.0是网络位,0为主机位,表示的是该主机位于192.168.0这个网段的第140台主机

如果是例如192.168.0.121/24这种带有"/"的IP地址,其中24表示该IP地址网络位的位数,即3个字节

特殊的IP地址

网段号

192.168.1.0:该主机的网段号,即IP地址网络位不变,主机位全是0.则为该IP地址的网段号,不表示某台主机

广播号

192.168.1.255:IP地址网络位不变,主机位全为1,则为该IP地址的广播号,向广播号发送信息,所有局域网内IP都能受到此消息

网关地址

192.168.1.1,192.168.1.2:主机位为1或2

IP地址的划分

公有IP:由电信公司直接分配,并需要付费的IP地址, 可以直接访问internet

私有IP:不能直接访问internet的ip地址

为了节省ip地址

网络端口号

端口号:16位的整型数据(unsigned short)

范围:0-65535

端口号功能:标记同一主机上的不同网络进程

分类

1,任何TPC/IP实现锁提供的服务都用1-1023之间的端口号

http:80

FTP:20/21

TFPT:69

HTTPS:443

2,端口号从1024-49151是被注册的端口号,被IANA指定的特殊服务使用

MQTT:1833和8883

3,49152-65535是动态或私有端口号

数据包的封装和解封过程

网络配置

ubuntu网络联通

相关推荐
Java.熵减码农3 小时前
解决Linux修改环境变量后导致登录循环进不去系统的问题
linux·运维·服务器
明天好,会的3 小时前
分形生成实验(五):人机协同破局--30万token揭示Actix-web状态管理的微妙边界
运维·服务器·前端
天骄t4 小时前
嵌入式系统与51单片机核心原理
linux·单片机·51单片机
猫头虎4 小时前
如何在浏览器里体验 Windows在线模拟器:2026最新在线windows模拟器资源合集与技术揭秘
运维·网络·windows·系统架构·开源·运维开发·开源软件
C_心欲无痕4 小时前
nginx - alias 和 root 的区别详解
运维·前端·nginx
阿部多瑞 ABU4 小时前
`chenmo` —— 可编程元叙事引擎 V2.3+
linux·人工智能·python·ai写作
徐同保5 小时前
nginx转发,指向一个可以正常访问的网站
linux·服务器·nginx
HIT_Weston5 小时前
95、【Ubuntu】【Hugo】搭建私人博客:_default&partials
linux·运维·ubuntu
实心儿儿5 小时前
Linux —— 基础开发工具5
linux·运维·算法
oMcLin5 小时前
如何在SUSE Linux Enterprise Server 15 SP4上通过配置并优化ZFS存储池,提升文件存储与数据备份的效率?
java·linux·运维