在Linux网络编程中,errno是一个非常重要的变量。它记录了最近发生的系统调用错误代码。在编写网络应用程序时,合理处理errno可以帮助我们更好地了解程序出现的问题并进行调试。...通常,在Linux网络编程中发生错误时,errno会被设置为一个非零值。因此,在进行系统调用之后,我们应该始终检查errno的值。...我们可以使用perror函数将错误信息打印到标准错误输出中,或者使用strerror函数将错误代码转换为错误信息字符串。在网络编程中,处理网络连接、连接收发数据等经常会涉及到errno的处理。...连接的读写在 Linux 网络编程中,连接读写阶段可能会遇到以下 errno:EINTR:表示系统调用被中断,可以重新尝试读写EAGAIN 或 EWOULDBLOCK:表示当前没有数据可读或没有缓冲区可写...总结本文介绍了在 Linux 网络编程中处理 errno 的方法。
Linux Socket编程 ---- 目录 前言 Socket的功能 Socket基础 Socket类型 基本结构 基本转换函数 基本Socket使用 TCP Socket实例 UDP Socket实例...疑难问题记录 总结 ---- 前言 socket(套接字)是网络编程编程的一种技巧。...本篇不涉及太底层的网络原理,仅说明socket的基本使用方法。主要参考《Linux网络编程》。本篇源码获取方式见文底小字。...在面向连接的通讯中服务器和客户机在交换数据之前先要建立一个连接;在不连接通讯中数据被作为信息的一部分被交换。 ...网络编程非常有趣,能够实现天南海北之间的通讯,让远距离的人与人、人与物或者物与物之间产生联系,很有意思! 最后 用心感悟,认真记录,写好每一篇文章,分享每一框干货。
我们的网络编程主要就是针对应用层. 物理层我们考虑的比较少, 我们只考虑软件相关的内容. 因此很多时候我们直接称为 TCP/IP 四层模型. 再识协议 为什么要有 TCP/IP 协议?...之前我们在学习系统编程的时候知道访问公共资源就是临界资源,那么这里的局域网就是一个临界资源(以太网中, 任何时刻, 只允许一台机器向网络中发送数据)。...据, mac 地址是局域网转发的重要依据 网络通信的宏观流程: IP 网络层存在的意义: 提供网络虚拟层, 让世界的所有网络都是 IP 网络, 屏蔽 最底层网络的差异 Socket 编程预备...sockadder结构 socket API 是一层抽象的网络编程接口,适用于各种底层网络协议,如 IPv4、 IPv6,以及 后面要讲的 UNIX Domain Socket....这实际上就是C++中的多态。 关于Socket套接字编程后续文章会详细讲解。
大家好,又见面了,我是你们的朋友全栈君。 文章目录 前言 一、UDP是什么 二、UDP 数据报服务特点 二、UDP 编程流程 1.服务器 2.客户端 3.输出结果 总结 前言 浅谈UDP。...提示:以下是本篇文章正文内容,下面案例可供参考 一、UDP是什么 UDP是一种不可靠的、无连接的、数据报服务。...并且,如果用户没有指定足够的应用程序缓冲区来读取 UDP 数据,则 UDP 数据将被截断。 因此,采用UDP协议时必须要求接收端可以一次性收取完发送端一次发送的数据,不然就会造成数据丢失。...二、UDP 编程流程 1.服务器 代码如下(示例): int main() { int sockfd = socket(AF_INET,SOCK_DGRAM,0); assert( sockfd...如发现本站有涉嫌侵权/违法违规的内容, 请发送邮件至 举报,一经查实,本站将立刻删除。
TCP/IP协议 TCP/IP 协议栈是一系列网络协议(protocol)的总和,是构成网络通信的核心骨架,它定义了电子设备如何连入因特网,以及数据如何在它们之间进行传输。...OSI 7层模型和TCP/IP四层网络模型对应关系 计算机网路基础的知识不过多讲解,主要是让大家明白接下来的Linux网络编程数据流属于那一层,具体如下图 TCP/IP协议数据流示意图 我们接下来讲解的...Linux网络编程Tcp协议是属于传输层的协议 Linux Socket 网络编程 TCP协议 TCP是面向连接的可靠的传输层协议。...TCP编程 Linux中的网络编程是通过socket接口来进行的。socket是一种特殊的I/O接口,它也是一种文件描述符。常用于不同机器上的进程之间的通信,当然也可以实现本地机器上的进程之间通信。...地址 通用的socket地址不是很好用,所以Linux为各个协议族提供了专门的socket地址结构体 UNIX本地协议族 struct sockaddr_un { sa_family_t sa_family
先要学习网络知识才谈得上编程 讲述计算机网络的最经典的当属Andrew S.Tanenbaum的《计算机网络》第五版,这本书难易适中。...详解的作者还写了另外2本经典著作,《Unix环境高级编程》,《Unix网络编程》二卷本。...说明:搞Linux网络编程的,想学TCP/IP的一定要看大师W.Richard Stevens这六本书,基本上六本书看完基础也就搭好了。 ? ? ? ? ? ?...网络体系结构:linux内核中网络协议的设计与实现》 ?...一并把内核结构和各功能在内核中的关系也搞清楚了。
Java中的网路编程主要是Java的Socket编程,属于JavaEE中的高级的部分,以下内容是对java网路编程的一个小结,代码都是经过编译调试的 C/S程序应用:客户/服务器模式,如QQ客户端...C/S程序分为两种: 基于TCP协议:Socket(套接字), 可靠的编程: A->B 如打电话先建立连接 基于UDP协议:不可靠,如短信功能。...如果编写一个TCP程序需要JAVA的两个包支持: java.net.*: 主要提供网络支持; |-ServerSocket类:服务器端程序 ...*:传递信息流 客户端的两个功能: 1.建立Socket 2.接收输入的命令(输入流)->网络上传输的程序考的是字节流 以下是服务器端,客户端的两个事例程序,服务器端想客户端输出Hello...System.out.println(buf.readLine()); 22 buf.close(); 23 client.close(); 24 25 } 26 27 } 在JDK中也准备了两个专门用于实现
数据传输错误在网络编程中,数据传输错误也是一种常见的异常情况。例如,如果远程服务器关闭连接或中途发生故障,可能会导致数据传输错误。...data.decode("utf-8"))except socket.error as e: print("Socket error:", e)finally: s.close()在上面的示例中,...然后,我们向服务器发送一个 HTTP 请求,接收响应并将其解码为 UTF-8 编码的字符串。如果发生 socket 错误,我们将捕获异常并输出错误信息。
网络编程中的异常处理是一项至关重要的任务。在编写网络应用程序时,需要考虑多种异常情况,如网络连接失败、超时、数据传输错误等。在 Python 中,网络编程使用 socket 模块来实现。...在本文中,我们将介绍 Python 中 socket 模块的异常处理机制,并提供一些示例。异常处理机制Python 中 socket 模块提供了一些异常类来处理不同的异常情况。...下面是一些常见的 socket 异常类:socket.error:所有 socket 相关异常的基类。socket.timeout:用于处理连接超时异常。...在编写网络应用程序时,需要在适当的位置捕获这些异常。通常,需要将所有的 socket 操作都包含在 try-catch 语句块中。...data.decode("utf-8"))except socket.error as e: print("Socket error:", e)finally: s.close()在上面的代码中,
Connection reset by peer 网络编程中某一端可能会产生Connection reset by peer的报错,这是因为收到了对端发送的RST包。...RST包是在tcp异常关闭时发出的,产生的情形很多。...syscall.Forklock 在go标准库和其他一些网络库创建socket通常会有如下的代码: syscall.ForkLock.RLock() s, err = socketFunc(family...选项作用的相同的。...这里ForkLock的作用是保证fork操作时socket的创建与设置CloseOnExec原子性。 持续更新中
连接超时在网络编程中,连接超时是一种常见的异常情况。当尝试连接到一个不可达的主机时,可能会发生连接超时异常。...Connection timed out")except socket.error as e: print("Socket error:", e)finally: s.close()在上面的代码中,
在前面的文件中,我们介绍了linux网络编程中与IP相关的知识和常用的函数总结,本文针对具体的UDP通信,来详细的介绍UDP通信的使用,包括UDP通信中的点对点通信,多播,广播等。...一、UDP通信中服务端和客户端的基本编程框架 与TCP相比较,UDP是面向无连接的通信方式,不需要connect、listen、accept等函数操作,不用维护TCP的连接、断开等状态。...3.2、组播的使用 组播在基本UDP编程框架的基础上,使用setsockopt()函数和getsockopt()函数来实现,需要设置IP层的相关参数(第二个参数为 IPPROTO_IP),其原型如下:...0-255 选项IP_MULTICAST_IF:设置组播的默认默认网络接口,会从给定的网络接口发送,另一个网络接口会忽略此数据 选项IP_ADD_MEMBERSHIP和IP_DROP_MEMBERSHIP...这样在实际的使用过程中,程序运行经常性的会遇到这样的问题: Address already in use 例如我们的服务端通过广播的方式在网络上广播了自己的存在,告知其他主机自己的IP地址信息和与自己通信的方式
一,基础概念 数据报文在网络中的点对点传输方式通常有以下三种: 单播(Unicast): 数据报文从一个发送端到一个接收端的通信方式。...组播的实现需要设置组播地址 在IPv4中组播的地址范围是:224.0.0.0到239.255.255.255。...二,组播的具体实现过程 发送端: step.01:新建一个socket套接字1用于往组播发送数据报文。 step.02:在sockaddr_in结构体中初始化组播的端口号。...IP_DROP_MEMBERSHIP:退出指定的组播。 IP_MULTICAST_IF:设置组播中发送数据报文的接口。 IP_MULTICAST_TTL:设置组播中数据报文的生存时间(TTL)。...IP_MULTICAST_LOOP:设置组播中数据报文的副本是否回传。
相关API笔记(二) Linux网络编程高级I/O函数 1. pipe pipe函数用于创建一个管道,实现进程间通信 #include //成功返回0,失败返回-1并设置errno...,具体作用如下: dup函数创建一个新的文件描述符,该新的描述符和原有文件描述符file_descriptor指向相同文件,管道或者网络连接, 并且dup返回的文件描述符总是取系统当前可用的最小整数值。...,即分散读 writev函数则将多块分散的内存数据一并写入文件描述符中,即集中写 #include ssize_t readv(int fd, const struct iovec...connfd ret = writev(connfd, iv, 2); //readv,分散读,把键盘的输入读出并放入到buf1,buf2中 ret = readv(STDIN_FILENO, iv,...in_fd: 待读出内容的文件描述符,可理解为文件流入到in_fd中,我们需要从它这里读出数据。 offset: 指定从读入文件流的哪个位置开始读,如果为空,则使用读入文件流默认的起始位置。
好在Linux内核检测到TCP紧急标志时,将通知应用程序有带外数据需要接收。内核通知应用程序带外数据到达的两种常见方式是: 1O复用产生的异常事件和SIGURG信号。...socket地址,并将其存储于address参数指定的内存中,该socket地址的长度则存储于address_len参数指向的变量中。...对这种情况,Linux给开发人员提供的解决方案是:对监听socket设置这些socket选项,那么accept返回的连接socket将自动继承这些选项。...网络信息API 利用域名获取IP地址 IP地址比域名发生变更的概率要高,所以利用IP地址编写程序并非上策。...addrinfo结构体中,ai_ protocol 成员是指具体的网络协议,其含义和socket系统调用的第三个参数相同,它通常被设置为0。ai_fags 成员可以取表中的标志的按位或。
这是因为连接socket只能由accept调用返回,而accept从listen监听队列接受的连接至少已经完成了TCP三次握手的前两个步骤(因为listen监听队列中的连接至少已进入SYN_RCVD状态...对这种情况,linux给开发人员提供的解决方案是:对监听socket设置这些socket选项,那么accept返回的连接socket将自动继承这些选项。...当TCP接收缓冲区中可读数据的总数大于其低水位标记时,I/O复用系统调用将通知应用程序可以从对应的socket上读取数据;当TCP发送缓冲区中的空闲空间(可以写入数据的空间)大于其低水位标记时,I/O复用系统调用将通知应用程序可以往对应的...此时close 系统调用立即返回,TCP模块将丢弃被关闭的socket对应的TCP发送缓冲区中残留的数据,同时给对方一个复位报文段。因此,这种情况给服务器提供了异常终止一个连接的方法。...此时close的行为取决于两个条件:(1)被关闭的socket对应的TCP发送缓冲区中是否还有残留的数据;(2)该socket是阻塞的还是非阻塞的。
之前发的在公众号上代码阅读体验不佳,所以排版后重新发布。 1. 网络编程基本概念 1.1 什么是套接字 套接字,也叫socket,是操作系统内核中的一个数据结构,它是网络中的节点进行相互通信的门户。...网络通信,说白了就是进程间的通信(同一台机器上不同进程或者不同计算机上的进程间通信)。 在网络中,每一台计算机或者路由都有一个网络地址,就是IP地址。...但是,网络地址只能确定进程所在的计算机,而一台计算机上一般都是同时运行着多个进程,所以仅凭网络地址还不能确定到底是和网络中的哪一个进程进行通信,因此套接口中还需要包括其他的信息,比如端口号和协议。...Ipv6地址),而在socket编程中使用的则是32位的网络字节序的二进制值,这就需要对这两个数值进行转换。...在linux中,最常用的是gethostbyname()和gethostbyaddr(),它们都可以实现IPv4/IPv6的地址和主机名之间的转化。
相关API笔记(一) Linux网络编程基础API 1....通用socket地址 这个比较少用 socket网络编程接口中表示socket地址的是结构体sockaddr #include struct sockaddr{...} 实际使用时(包括sockaddr_storage)都需要将其转化为通用的socket地址类型sockaddr(强制转换即可),所以的socket编程接口使用的类型都是sockaddr。...转换为网络字节序整数表示的IPv4地址,失败返回INADDR_NONE inet_aton: 完成与inet_addr相同功能,结果保存在Inp数组中。...多进程中,一个fork系统调用默认会让父进程中打开的socket文件描述符的引用数加一,因此得再父子进程中都调用close才能真正关闭一个连接。
其中12为最高字节,其先存储到内存中的低地址,然后再向更高的字节地址存储数据的其余字节。...在x86架构的CPU中,通常采用小端序,而在MIPS架构的CPU中,通常采用大端序。在网络传输中,由于不同机器之间采用的存储方式可能不同,为了保证数据的正确传输,需要对数据进行大小端转换。...BSD socket中的大小端转换支持 在网络编程中,大小端问题是非常重要的。因为不同的CPU架构可能有不同的字节序,而网络通信是跨平台的,因此需要进行字节序转换。...*)&serv_addr, sizeof(serv_addr)) == -1) { // handle error } `` 在第11行代码中,将主机字节序的端口号(使用的是PORT常量)转换成网络字节序的端口号...(使用的是htons()函数),并存储到了addr.sin_port结构体的成员变量中。
Socket编程 套接字概念 Socket本身有“插座”的意思,在Linux环境下,用于表示进程间网络通信的特殊文件类型。本质为内核借助缓冲区形成的伪文件。...区别是管道主要应用于本地进程间通信,而套接字多应用于网络进程间数据的传递。 在TCP/IP协议中,“IP地址+TCP或UDP端口号”唯一标识网络通讯中的一个进程。...网络编程接口 首先先看一下网络套接字的函数以及具体实现流程图: 网络字节序 内存中的多字节数据相对于内存地址有大端和小端之分,磁盘文件中的多字节数据相对于文件中的偏移地址也有大端小端之分。...发送主机通常将发送缓冲区中的数据按内存地址从低到高的顺序发出,接收主机把从网络上接到的字节依次保存在接收缓冲区中,也是按内存地址从低到高的顺序保存,因此,网络数据流的地址应这样规定:先发出的数据是低地址...:/usr/include/linux/in.h 文件中。
领取专属 10元无门槛券
手把手带您无忧上云