Linux网络编程 网络基础知识

简介: Linux网络编程 网络基础知识

1.网络的历史和协议的分成

Internet-"冷战"的产物

1957年十月和十一月,前苏联先后欧两颗”Spuinik”卫星上天

1958年美国总统艾森豪威尔向美国国会提出建立DARPA,即国防部高级研究计划署,简称ARPA.1968年6月DARPA提出“资源共享计算机网络”,目的在于让DARPA的所有电脑互连起来,这个网络就叫做ARPAnet,即“阿帕网”,是Internet的最早雏形。


2.网络互联促成了TCP/IP协议的产生

早期的ARPAnet使用网络控制协议,不能互联不同类型的计算机和不同类型的操作系统,没有纠错功能


1973年有Rober Kahn 和 Vinton Cerf 两人合作为ARPAnet开发了新的互联网协议


1974年12月两人正式发表第一份TCP协议详细说明,但此协议在有数据包丢失时不能有效的纠正


  • 用来检测网络传输中差错的传输控制协议TCP
  • 专门负责对不同网络进行互联的互联网协议IP
  • 从此TCP/IP协议诞生

1983年ARPAnet上停止使用NCP,互联网上的主机全部使用TCP/IP协议,TCP/IP协议成为Internet中的“世界语”。


3.网络的体系结构

  • 网络采用分而治之的方法设计,将网络的功能划分为不同的模块,以分层的形式有机组合在一起
  • 每层实现不同的功能,其内部实现方法对外部其他层次来说是透明的。每层向上层提供服务,同时使用下层提供的服务。
  • 网终体系结构即指网络的层次结构和每层所使用的协议的集合
  • 两类非常重要的体系结构:OSI和 TCP/IP。

  • OSI模型相关的协议已经很少使用,但模型本身非常通用                                                             OSI模型是一个理想化的模型,尚未有完整的实现
  • OSI模型共有七层
  • 二层交换机,三层交换机


4.TCP/IP协议族体系

  • TCP/IP协议族体系是Internet事实上的工业标准
  • 一共有四层
应用层 Relnet,FTP,HTTP,DNS,SMTP等
传输层 TCP和UDP
网络层 IP,ICMP和IGMP,端到端传输
网络接口和物理层 以太网,令牌环网,FDDI,wifi,gps/2G/3G/4G,驱动(屏蔽硬件差异)

5.网络各层的协议解释

1.网络接口和物理层

mac地址: 48位全球唯一,网络设备的身份标识

  • ARP:地址解析协议,IP地址找到mac地址
  • RARP:mac地址--找到P地址
  • PPP协议: 拨号协议 (GPRS/3G/4G)


2.网络层


  • IP地址
  • IP协议: Internet protocol(分为IPV4和IPv6)
  • ICMP:Internet控制管理协议,Ping 命令属于ICMP
  • IGMP:Internet分组管理协议,广播和组播


3.传输层


TCP: (Transfer Control protocol,传输控制协议) 提供面向连接的,一对一的可靠传输的协议


  • 数据无误,数据不丢失,数据无失序
  • 适用场景
  • 适合对传输质量要求较高,以及传输大量数据的通信
  • 在需要可靠数据传输的场合,通常适用TCP协议
  • MSN/QQ等即时通讯软件的用户登录账号管理相关的功能通常采用TCP协议


UDP: (user Datagram Protocol,用户数据报协议) : 提供不可靠,无连接的传输协议


  • 适用场景
  • 发送小尺寸数据 (如对DNS服务器进行IP地址查询时)
  • 在接收数据,给出应答较困难的网终中适用UDP (如无线网络)
  • 适合于广播/组播式通信中MSN/QQ/Skype等即时通讯软件的点对点文本通讯以及音视频通常采用UDP协议流媒体VOD,VoIP,IPTV等网络多媒体服务中通常采用UDP方式进行实时数据传输        

SCTP: (Stream Control Transmission Protocol:流控制传输协议),TCP的增强版,他能实现多主机多链路的通信。      


4.应用层            


网页访问协议: HTTP/HTTPS0

邮件发送接收协议: POP3(收)/SMTP(发),IMAP(可接受邮件的一部分)

FTP: 文件传输协议

Telnet/ssh:远程登录

嵌入式相关

  • NTP:网络时钟协议
  • SNMP:简单网络管理协议 (实现对网络涉及集中式管理)
  • RTP/RSTP:用于传输音视频的协议 (安防监控)        

6.网络的封包和拆包

TCP/IP协议下的数据包

7.网络预备知识    

1.socket


  • 是一个编程接口,是一个特殊的文件描述符(对他执行IO的操作函数,比如read,write,close等),并不 仅限于TCP/IP协议,面向连接TCP,无连接UDP。  
  • socket代表网络编程的一种资源                                            


分类


  • 1.流式套接字(SOCK_STREAM)。唯一对应TCP 提供了一个面向连接,可靠的数据传输服务,数据无差错,无重复的发送顺序接收。内射击流量控 制,避免数据流淹没慢的接收方。数据被看作式字节流,无长度限制。
  • 2.数据包套接字(SOCK_DGRAM)。唯一对应UDP 提供无连接服务器,数据包以独立数据包的形式被发送,不提供无差错保证,数据可能丢失或重 复,顺序发送,可能乱序接收。
  • 3.原始套接字(SOCK_RAW)。对应多个协议,发送穿透了传输层 可以对较低层次协议如IP,ICMP直接访问。


2.IP地址


  • IP地址是Internet中主机的标识,Internet中的主机要与别的机器通信必须具有一个IP地址,IP地址为32 为(Ipv4)或者128位(Ipv6),每个数据包都必须携带目的IP地址和源IP地址,路由器依靠此信息为数 据包选择路由
  • 表示的形式:常用点分形式,如202.38.64.10,最后都会转化成一个32位的无符号整数
  • mobileIPV6:local IP(本地注册的IP),roma IP(漫游IP)


特殊IP地址


  • 局域网IP: 192.XXX.XXX.XXX 10.XXX.XXX.XXX
  • 广播IP:xxx.xxx.xxx.255 255.255.255.255(全网广播) 网络风暴
  • 组播IP:224.xxx.xxx.xxx ~239.xxx.xxx.xxx

3.端口号


16位数字,1-65535

为了区分一台主机接收到的数据包应该转交给哪个任务进程处理,使用端口号来区别

  • 预留端口,1-1023 (FTP:24,SSH:22,HTTP: 80,HTTPS :469)
  • 保留端口: 1024-5000 (不建议使用)
  • 可以使用的端口: 5000~65535
  • TCP端口号于UDP端口号独立
  • 网络里的通信是由 IP地址+端口号 来决定的

4.字节序


字节序是指不同的CPU访问内存中的多字节数据时候,存在大小端的问题

  • 如果CPU访问的是字符串,则不存在大小端问题
  • 一般来说X86/ARM : 小端模式
  • power/miop:arm作为路由时,大端模式
  • 网络传输的时候采用大端模式


字节转换函数


  • 把给定系统所采用的字节序称为主机字节序,为了避免不同类别主机之间在数据交换时由于对于字 节序的不同而导致的差错,引入了网络字节序。
  • 主机字节序到网络字节序
  • u_long htonl(u_long hostlong);
  • u_short htons(u_short short);
  • 网络字节序到主机字节序
  • u_long ntohl(u_long hostlong);
  • u_short ntohs(u_short short);

IP地址的转换


  • inet_aton()

       将strptr所指的字符串转换成32位的网络字节序二进制值


  • inet_addr()

       功能同上,返回转换后的地址 仅适用于IPV4,出错时返回-1。


       局限性:不能用于255.255.255.255的转换


  • inet_ntoa()

       将32位网络字节序二进制地址转换成点分十进制的字符串


  • inet_pton()

       int inet_pton(int af, const char* src ,void* dst)


       将IPV4/IPV6 的地址转换成binary格式


       使用于IPV4/IPV6 能正确处理255.255.255.255的转换问题


       参数:


       1.地址协议族(AF_INET或AF_INET6)


       2.src:是一个指针(填写分点形式的IP地址(主要指IPV4))


       dst:转换的结果给到dst


  • inet_ntop(int af,const void *src,char *dst,socklen_t size)

       把ipv4和ipv6的网络字节序变成本地的字符串形式的IP地址


       参数


       1.af:地址协议族(AF_INET或AF_INET6)


       2.src:是一个指针(32)


       3.dst:输出结果为32位点分形式的IP地址


       4.size:长度

相关文章
|
3天前
|
消息中间件 Java Linux
2024年最全BATJ真题突击:Java基础+JVM+分布式高并发+网络编程+Linux(1),2024年最新意外的惊喜
2024年最全BATJ真题突击:Java基础+JVM+分布式高并发+网络编程+Linux(1),2024年最新意外的惊喜
|
1天前
|
JSON 安全 网络协议
【Linux 网络】网络基础(二)(应用层协议:HTTP、HTTPS)-- 详解
【Linux 网络】网络基础(二)(应用层协议:HTTP、HTTPS)-- 详解
|
1天前
|
存储 网络协议 Unix
【Linux 网络】网络编程套接字 -- 详解
【Linux 网络】网络编程套接字 -- 详解
|
1天前
|
存储 网络协议 Linux
【Linux 网络】网络基础(一)(局域网、广域网、网络协议、TCP/IP结构模型、网络传输、封装和分用)-- 详解(下)
【Linux 网络】网络基础(一)(局域网、广域网、网络协议、TCP/IP结构模型、网络传输、封装和分用)-- 详解(下)
|
1天前
|
存储 网络协议 安全
【Linux 网络】网络基础(一)(局域网、广域网、网络协议、TCP/IP结构模型、网络传输、封装和分用)-- 详解(上)
【Linux 网络】网络基础(一)(局域网、广域网、网络协议、TCP/IP结构模型、网络传输、封装和分用)-- 详解(上)
|
5天前
|
网络协议 Python
Python 网络编程实战:构建高效的网络应用
【5月更文挑战第18天】Python在数字化时代成为构建网络应用的热门语言,因其简洁的语法和强大功能。本文介绍了网络编程基础知识,包括TCP和UDP套接字,强调异步编程、数据压缩和连接池的关键作用。提供了一个简单的TCP服务器和客户端代码示例,并提及优化与改进方向,鼓励读者通过实践提升网络应用性能。
23 6
|
6天前
|
运维 网络协议 Linux
Docker网络_docker 网络,来看看这份超全面的《Linux运维面试题及解析》
Docker网络_docker 网络,来看看这份超全面的《Linux运维面试题及解析》
|
8天前
|
域名解析 网络协议 Linux
linux网络配置详解
linux网络配置详解
26 0
|
8天前
|
网络协议 Java Linux
【探索Linux】P.29(网络编程套接字 —— 简单的TCP网络程序模拟实现)
【探索Linux】P.29(网络编程套接字 —— 简单的TCP网络程序模拟实现)
16 0