Linux网络基础编程|学习笔记

简介: 快速学习Linux网络基础编程

开发者学堂课程【TCP/IP 网络基础:Linux网络基础编程】学习笔记,与课程紧密联系,让用户快速学习知识。

课程地址https://developer.aliyun.com/learning/course/791


Linux网络基础编程

内容简介

一、socket的概念

二、socket的类型

三、socket的位置

四、网络地址

五、端口号

六、字节序

七、socket基础编程

一、socket的概念

image.png

在Linux中的网络编程是通过socket接口来进行的。

socket是一种特殊的I/O接口,它也是一种文件描述符。它是一种常用的进程之间的通信,而且通过网络能够在不同的机器上的进程之间进行通信。

socket也有一个类似于打开文件的函数调用,该函数返回一个整型的 socket描述符,随后的连接建立,数据传输等操作都是通过socket来实现的。

二、socket的类型

image.png

(1)流式socket((socket《SOCKSTREAM)

流式套接字提供可靠的、面向连接的通信流:它使用TCP协议,从而保证了数据传输的正确性和顺序性。

(2)数据报socket(SOCK DGRAM)

数据报套接字定义了一种无连接的服务,数据通过相互独立的报文进行传输,是无序的,而且是不保证是可靠、无差错的。它使用数据报协议UDP

(3)原始socket

原始套接字允许对底层协议如P或ICMP进行直接访问,它功能强大但使用较为不便,主要用于一些协议的开发。

三、socket的位置

image.pngimage.pngimage.png

四、网络地址

image.png

image.png

image.png

五、端口号

端口号

为了区分一台主机接收到的数据包应该转交给哪个进程来进行处理,使用端。口号来区分TCP端口号与UDP端口号独立。

端口号一般由ANA(Internet Assigned Numbers Authority)管理

众所周知端口:1~1023(1-255之间为众所周知端口,256~1023端口通常由UNX系统占用)

注册端口:1024~49150

动态或私有端口:49151~65535

image.png

套接字和端口

image.pngimage.png

六、字节序

字节序

不同类型CPU的主机中,内存存储多字节整数序列有两种方法,称为主机字节序(HO):

小端序(little-endian-)

低序字节存储在低地址,将低字节存储在起始地址IntelAMD等采用的是这种方式。

大端序(big-endian-)

高序字节存储在低地址,将高字节存储在起始地址ARM、Motorola等采用这种方式。

网络中传输的数据必须按网络字节序,即大端字节序。

在大部分PC机上,当应用进程将整数送入 socket前,需要转化成网络字节序;当应用进程从socket取出整数后,要转化成小端字节序。

image.pngimage.png

网络字节序(n- Network Byte Order)

把给定系统所采用的字节序称为主机字节序,为了避免不同类别主机之间在数据交换时由于字节序不同而导致的差错,引入了网络字节序。使用统一的字节顺序,避免兼容性问题

不同主机的HBO(Host Byte Order)是不一样的,这与CPU的设计有关。

Motorola68K系列,ARM系列,HBO与NBO是一致的。

Intel X86系列,HBO与NBO是不一致的

image.png

字节序转换函数

这里用到了四个函数: htons, ntohs0, htonl和htohl0,这四个函数分别实现网络字节序和主机字节序的转化,这里的h代表ost,n代network表,s代short表代表long.通常16位的P端口号用s表示,而P地址用I表示。

image.png

七、Socket基础编程

网络编程相关API

网络编程常用函数:

socket:用于建立个socketi连接,可指定socket类型等信息在建立了socket连接之后可对sockaddrsockaddr或 in结构进行初始化,以保存所建立的socket地址信息。

bind:用于将本地IP地址绑定到端口号,若绑定其他P地址则不能成功另外,它主要用于TCP连接,而在UDP的连接中则无必要。

listen():在服务端程序成功建立套接字和与地址进行绑定之后,还需要准备在该套接字上接收新的连接请求此时调用listen()函数来创建一个等待队列,在其中存放未处理的客户端连接请求。

accept():服务端程序调用listen()函数创等待队列之后,调用 accept函数等待并接收客户端的连接请求。它通常从bind()所创建的等待队列中取出第一个未处理的连接请求

image.png

网络编程常用函数:

connect():

该函数在TCP中是用于bind()的之后的客户端,用于与服务器建立连接,而在

UDP中由于没有了bind()函数,因此用connect有点类似bind函数的作用

send()和recv():

这两个函数分别用于发送和接收数据,可以用在TCP中,也可以用在UDP

中当用在UDP时,可以在connect)函数建立连接之后再用

sendto()和recvfrom():

这两个函数的作用与send(和rec函数类似,也可以用在CP和UDP中,当用在TCP时,后面的几个与地址有关参数不起作用,函数作用等同于send和recv;当用在UDP时,可以用在之前没有使用connect()的情况下,这两个函数可以自动寻找指定地址并进行连接。

image.png

socket

image.png

Socket信息数据结构

image.png

地址结构的一般用法

1定义一个struct sockaddr in类型的变量并清空

struct sockaddr in myaddr:

memset(&myaddr, 0, sizeof(myaddr))

2填充地址信息

myaddr.sin family AF INET;

myaddr.sin port =htons (8888);

myaddr.sin addr.s addr inet addr ("192.18.1.100");

image.png

bind()

该函数是用于将本地地址绑定到端口号若绑定其他P地址则不能成功。另外,它主要用于TCP的连接,而在UDP的连接中则无必要。

image.png

image.png

listen()

在服务端程序成功建立套接字和与地址进行绑定之后,还需要在该套接字上接收新的连接请求。此时调用listen()函数来创建一个等待队列,在其中存放未处理的客户端连接请求。


accept()

服务端程序调用listen()函数创建等待队列之后,调用accept()函数等待并接收客户端的连接请求。它通常从由bind()所创建的等待队列中取出第一个未处理的连接请求。



connect()

Socket基础编程

connect)

该函数在TCP中是用于bind之后的client端,用于与服务器端建立连接,而在UDP中由于没有了bind()函数,因此用connect()有点类似bind()函数的作用。


send()和recv():

这两个函数分别用于发送和接受数据。


image.png

相关文章
|
DataWorks 数据管理 大数据
DataWorks操作报错合集之如何解决表字段类型从string改为datetime报错
DataWorks是阿里云提供的一站式大数据开发与治理平台,支持数据集成、数据开发、数据服务、数据质量管理、数据安全管理等全流程数据处理。在使用DataWorks过程中,可能会遇到各种操作报错。以下是一些常见的报错情况及其可能的原因和解决方法。
|
存储 数据挖掘 数据处理
【破晓数据湖新时代!】巴别时代揭秘:Apache Paimon 打造 Streaming Lakehouse 的神奇之旅!
【8月更文挑战第9天】随着数据湖技术的发展,企业积极探索优化数据处理的新途径。Apache Paimon 作为一款高性能数据湖框架,支持流式与批处理,适用于实时数据分析。本文分享巴别时代使用 Paimon 构建 Streaming Lakehouse 的实践经验。Paimon 统一了数据存储与查询方式,对构建实时数据管道极具价值。
746 3
|
机器学习/深度学习 人工智能 监控
利用AI进行代码审查:提升代码质量和开发效率
【10月更文挑战第12天】本文探讨了AI在代码审查中的应用及其优势,介绍了AI辅助代码审查工具如何通过自动化和持续学习提升代码质量和开发效率。文章还提供了实施AI辅助代码审查的具体步骤和实战技巧,帮助团队更好地利用这些工具。
|
监控 数据可视化 Linux
使用Portainer图形化工具轻松管理远程Docker环境并实现远程访问
使用Portainer图形化工具轻松管理远程Docker环境并实现远程访问
|
vr&ar
VGen为数字媒体带来惊喜
【1月更文挑战第7天】VGen为数字媒体带来惊喜
328 1
VGen为数字媒体带来惊喜
|
NoSQL 关系型数据库 MySQL
实时计算 Flink版产品使用合集之大表同步如何优化
实时计算Flink版作为一种强大的流处理和批处理统一的计算框架,广泛应用于各种需要实时数据处理和分析的场景。实时计算Flink版通常结合SQL接口、DataStream API、以及与上下游数据源和存储系统的丰富连接器,提供了一套全面的解决方案,以应对各种实时计算需求。其低延迟、高吞吐、容错性强的特点,使其成为众多企业和组织实时数据处理首选的技术平台。以下是实时计算Flink版的一些典型使用合集。
|
JSON 测试技术 API
Postman Newman 实现 API 自动化测试的快速指南
Newman 是一款专为 Postman 打造的命令行工具,旨在通过自动运行 Postman 集合和环境,实现 API 测试的自动化。它使得开发者无需打开 Postman 图形界面,即可直接在命令行中执行测试用例。
|
机器学习/深度学习 消息中间件 数据可视化
OpenCV入门(C++/Python)- 使用OpenCV调整尺寸大小(三)
OpenCV入门(C++/Python)- 使用OpenCV调整尺寸大小(三)
805 1
NR PDSCH(六) DL data operation
NR中,网络端会根据UE业务动态的调整BWP,进而改变频域资源范围;不同的BWP会配置CORESET/Searchspace确定不同的时频域资源,让UE在对应的资源上进行盲检接收DCI;通过DCI获得调度信息后,再去PDSCH对应的时域资源和频域资源上 decode data。