首页
学习
活动
专区
工具
TVP
发布
精选内容/技术社群/优惠产品,尽在小程序
立即前往

协议栈——创建套接

condensed-night-purple 前面几篇文章讲解的是应用程序使用Socket间接通知协议栈进行的连接,通信阶段,那么从现在开始讲解协议栈和网卡驱动的故事 回顾上篇文章,我们从第一阶段创建套接...套接 协议栈的内部会有一块记录通信对方的ip端口,通信状态,使用这块内存的应用pid的内存空间等,这个内存空间就是套接存储的内容,这些内容叫做控制信息 协议栈需要根据套接所存储的控制信息进行下一步的操作...ip地址);后面代表使用的端口号(根据套接生成的一个数字) foreignaddress:和loacladdress一样的格式,两者都是建立连接后才会显示数字的默认是0 state是这个套接的连接状态...pid:使用这个套接的应用程序,由于一个应用程序会有很多个网络请求因此也有多个套接 应用程序通过socket向协议栈发起创建套接的请求时,协议栈会创建出一块内存并写入这个套接创建完成的初始化状态...,并将代表这个套接的描述符返回给应用程序。

62110

nginx创建和监听套接分析

nginx监听套接创建是根据配置文件的内容来创建的,在nginx.conf文件中有多少个地址就需要创建多少个监听套接。 本文不针对源码逐一注解分析,只是说明套接创建监听流程。...函数,这个函数负责将创建的监听套接进行套接选项的设置(比如非阻塞、接受发送的缓冲区、绑定、监听处理)。...2.nginx创建套接是在哪里呢?...这个函数根据每一个IP地址:port这种配置创建一个监听套接,这个函数还有一个很重要的任务,就是将监听套接的回调函数设置为ngx_http_init_connection函数,记住这是监听套接上的回调...在cycle内创建一个连接池,创建一个读事件池,创建一个写事件的池,然后创建for循环遍历cycle中的所有ngx_listening_t的结构体,对每一个ngx_listening_t结构体,也就是每一个监听套接

85750
您找到你想要的搜索结果了吗?
是的
没有找到

套接

套接最早是UC Berkeley为BSD操作系统设计的。现在POSIX标准化了套接。在Linux和Unix下的套接是一致的。...套接是通信端点的一种抽象。在Linux下socket是文件的一种。也就是说可以使用read和write函数去处理套接。...在Linux下创建一个原始套接的时候,需要拥有超级用户权限,用来防止恶意程序。 在Linux下,我们使用函数socket来创建一个套接,这和Python所提供的方法并没有什么区别。...这在同一域和套接类型的时候是有用的,可以指定选择某一个特定的协议。 socket函数返回一个套接描述符,本质上是一个文件描述符。...一般而言,除了lseek不能用来操作套接以外,其余的文件操作函数都是可以的。

1.2K00

20.8 OpenSSL 套接SSL传输文件

有了上面的基础那么传输文件的实现就变得简单了,在传输时通常我们需要打开文件,并每次读入1024个字节的数据包,通过SSL加密传输即可,此处的文件传输功能在原生套接章节中也进行过详细讲解,此处我们还是使用原来的密钥对...服务端代码部分,此处我们只需要实现一个DownloadFile函数,该函数接收一个SSL套接,与保存文件路径即可,其他部分同上。...= NULL) { DWORD length = 0; DWORD total_length = 0; // 循环接收字节数据,每次接收1024节 while ((length...= -1) { printf("客户端地址: %s --> 端口: %d --> 套接: %d \n", inet_ntoa(their_addr.sin_addr), ntohs(their_addr.sin_port...,传入socket套接字句柄,需要发送的文件路径void UploadFile(SSL* ptr, const char* FilePath){ int FileSize = GetFileSize(

16240

20.8 OpenSSL 套接SSL传输文件

有了上面的基础那么传输文件的实现就变得简单了,在传输时通常我们需要打开文件,并每次读入1024个字节的数据包,通过SSL加密传输即可,此处的文件传输功能在原生套接章节中也进行过详细讲解,此处我们还是使用原来的密钥对...服务端代码部分,此处我们只需要实现一个DownloadFile函数,该函数接收一个SSL套接,与保存文件路径即可,其他部分同上。...= NULL) { DWORD length = 0; DWORD total_length = 0; // 循环接收字节数据,每次接收1024节 while (...= -1) { printf("客户端地址: %s --> 端口: %d --> 套接: %d \n", inet_ntoa(their_addr.sin_addr), ntohs...,传入socket套接字句柄,需要发送的文件路径 void UploadFile(SSL* ptr, const char* FilePath) { int FileSize = GetFileSize

23251

Socket(套接

但是如果此套接已经断开(比如一方断网了),那发送数据和接收数据的时候就一定会有问题。**可是如何判断这个套接是否还可以使用呢?这个就需要在系统中创建心跳机制。...** 1.对套接编程的理解,它的协议是如何的? socket通常称为“套接”,用于描述IP地址和端口,是一个通信链的句柄。应用程序通过套接向网络发出请求或应答网络请求。...(1)服务器监听:是服务器端套接并不定位具体的客户端套接,而是处于等待连接的状态,实时监控网络状态。...(2)客户端请求:客户端的套接必须首先描述它要连接的服务器的套接,指出服务器端套接的地址和端口号,然后就向服务器端套接提出连接请求。...(3)连接确认:是指当服务器端套接监听到或者说接收到客户端套接的连接请求,它就响应客户端套接的请求,建立一个新的线程,把服务器端套接的描述发给客户端,一旦客户端确认了此描述,连接就建立好了。

1.2K10

Socket编程基础-套接创建和使用

创建套接创建套接的基本步骤如下:导入socket模块在Python中,需要先导入socket模块才能使用套接。...import socket创建套接使用socket.socket()函数可以创建套接。...该函数接受两个参数,第一个参数指定地址族(IPv4或IPv6),第二个参数指定套接类型(流套接或数据报套接)。...# 创建一个IPv4的流套接sock = socket.socket(socket.AF_INET, socket.SOCK_STREAM)绑定套接如果要在服务器端使用套接,则需要将套接绑定到一个地址和端口上...# 将套接设置为监听状态,最大连接数为5sock.listen(5)使用套接使用套接可以实现不同主机之间或同一主机内进程之间的通信。下面将介绍如何使用套接进行通信。

66450

Python套接

套接:通信的端点 套接 有两种类型的套接:基于文件的和面向网络的。 IPC:进程间通信。...Python只支持AF_UNIX(基于文件)、AF_NETLINK(使用标准的BSD套接接口进行用户级别和内核级别代码之间的IPC)、AF_TIPC(透明的进程间通信)、AF_INET(基于网络)家族...为了创建UDP套接,必须使用SOCK_DGRAM(即datagram)作为套接类型。因为这些套接也使用因特网协议来搜寻网络中的主机,所以这个系统也称作UDP/IP。...Python中的网络编程 Socket详细介绍 TCP服务器端工作流程 创建服务器端套接A 将套接A与地址B使用bind函数绑定 使用listen函数使服务器开始监听 使用accept函数返回新的套接对象...C及其地址 使用C的recv函数接受发送到服务器端的数据 使用C的send函数发送数据 每次接收到一个新的连接就会在服务器端创建一个新的套接来负责与该连接进行信息的交换 TCP客户端工作流程 创建套接

1.5K20

套接Socket编程

问题是你如何创建子公司,又怎么将项目交给子公司? Linux使用fork创建子进程,基于父进程完全拷贝一个子进程。...accept创建的已连接Socket也是一个文件描述符,同样也会被子进程获得。...创建进程相当于成立新公司,购买新办公家具 创建线程,就相当于在同一个公司成立项目组。一个项目做完了,那这个项目组就可以解散,组成另外的项目组,办公家具还可复用。...一台机器无法创建很多进程或者线程。 C10K,一台机器要维护1万个连接,就要创建1万个进程或线程吗,那操作系统无法承受。如果维持1亿用户在线需要10万台服务器,成本也太高了。...其中epoll_create创建一个epoll对象,也是一个文件,也对应一个文件描述符,同样也对应着打开文件列表中的一项。

1.2K10

套接随笔1

在服务器端,socket()返回的套接用于监听(listen)和接受(accept)客户端的连接请求。这个套接不能用于与客户端之间发送和接收数据。...accept()接受一个客户端的连接请求,并返回一个新的套接。所谓“新的”就是说这个套接与socket()返回的用于监听和接受客户端的连接请求的套接不是同一个套接。...与本次接受的客户端的通信是通过在这个新的套接上发送和接收数据来完成的。...再次调用accept()可以接受下一个客户端的连接请求,并再次返回一个新的套接(与socket()返回的套接、之前accept()返回的套接都不同的新的套接)。...那么在服务器端就一共有4个套接:第1个是socket()返回的、用于监听的套接;其余3个是分别调用3次accept()返回的不同的套接

52120

IPC|网络套接

为了访问由UDP提供的服务,你需要像以前一样使用套接和close系统调用,但你需要用两个 数据报专用的系统调用sendto 和 recvfrom来代替原来使用在套接上的read和write调用 套接网络...套接是通信端点的抽象,与应用程序要使用文件描述符访问文件一样,访问套接也需要套接描述符。...#include int socket(int domain, int type, int protocol); 返回值:若成功则返回文件套接)描述符,如果出错则返回 -1...在AF_INET 通信域中套接类型SOCK_STREAAM 的默认协议时TCP(传输控制协议) 在AF_INET 通信域中套接类型SOCK_DGRAM的默认协议时UDP(用户数据报协议) SOCK_RAW...这是因为传输协议(TCP和UDP)被绕过了 当创建一个原始套接时需要超级用户权限,用以防止恶意程序绕过内建安全机制来创建报文。

1K30

Python与套接

s.getsockname() 当前套接的地址 s.getsockopt() 返回指定套接的参数 s.setsockopt() 设置指定套接的参数 s.close() 关闭套接 面向锁的套接方法...s.setblocking() 设置套接的阻塞与非阻塞模式 s.settimeout() 设置阻塞套接操作的超时时间 s.gettimeout() 得到阻塞套接操作的超时时间 面向文件套接的函数...s.fileno() 套接文件描述符 s.makefile() 创建一个与该套接相关的文件 第一版,单个客户端与服务端通信 服务端 import socket phone = socket.socket...然后回复消息时也要带着你收到的这个客户端的地址,发送回去,最后关闭连接, 一次交互结束 服务端 import socket udp_sk = socket.socket(type=socket.SOCK_DGRAM) #创建一个服务器的套接...这些I/O缓冲区特性可整理如下: I/O缓冲区在每个TCP套接中单独存在; I/O缓冲区在创建套接时自动生成; 即使关闭套接也会继续传送输出缓冲区中遗留的数据; 关闭套接将丢失输入缓冲区中的数据

2.3K30

套接Socket编程

问题是你如何创建子公司,又怎么将项目交给子公司? Linux使用fork创建子进程,基于父进程完全拷贝一个子进程。...,因而父进程刚才因为accept创建的已连接Socket也是一个文件描述符,同样也会被子进程获得。...创建进程相当于成立新公司,购买新办公家具 创建线程,就相当于在同一个公司成立项目组。一个项目做完了,那这个项目组就可以解散,组成另外的项目组,办公家具还可复用。...一台机器无法创建很多进程或者线程。 C10K,一台机器要维护1万个连接,就要创建1万个进程或线程吗,那操作系统无法承受。如果维持1亿用户在线需要10万台服务器,成本也太高了。...其中epoll_create创建一个epoll对象,也是一个文件,也对应一个文件描述符,同样也对应着打开文件列表中的一项。

1.3K10

Socket - 套接编程

目录 Socket - 套接编程 Socket 通信流程图 Socket模块 socket()方法 部分参数 bind()方法 listen()方法 accept()方法 accept()函数返回值:...Socket - 套接编程 只要涉及到远程数据交互必须要操作OSI七层模型,那么每层都需要相应的程序去操作,现在就需要一个模块去操作,直接实现; Socket是处于应用层和传输层之间的抽象层,Socket...AF_INET6:TCP/IP协议,使用IPV6,基于网络传输 类型分类(type) SOCK_STREAM:TCP协议(默认采用,流式协议) SOCK_DGRAM:UDP协议 SOCK_RAW:原始套接...proto参数是协议标志,默认为0,原始套接需要指定值 部分源码 bind()方法 绑定函数的作用就是为调用socket()函数产生的套接分配一个本地协议地址,建立地址与套接的对于关系...# 接收数据 data = client.recv(1024) print(data) # 关闭套接 client.close() ---- 简易通信循环 光发一条消息不够过瘾是吧,如何通信循环

99410
领券