首页
学习
活动
专区
圈层
工具
发布

UNIX域协议(命名套接字)

这里主要介绍命名UNIX域套接字 1.什么是UNIX域套接字 Unix域协议并不是一个实际的协议族,而是在单个主机上执行客户/服务通信的一种方式。是进程间通信(IPC)的一种方式。...它提供了两类套接字:字节流套接字(有点像TCP)和数据报套接字(有点像UDP) UNIX域数据报服务是可靠的,不会丢失消息,也不会传递出错。...2.UNIX域协议特点 1)UNIX域套接字域TCP套接字相比,在同一台主机的传输速度前者是后者的两倍。...UNIX域套接字仅仅复制数据,并不执行协议处理,不需要添加或删除网络报头,无需计算校验和,不产生顺序号,也不需要发送确认报文 2)UNIX域套接字可以在同一台主机上各进程之间传递文件描述符 3)UNIX...比如把上面的目录改成/tmp/test_socket 3)UNIX域流式套接字connect发现监听队列满时,会立刻返回一个ECONNREFUSED,这和TCP不同,如果监听队列满了,会忽略到来的SYN

3.4K100

UNIX域协议(无名套接字)

关于什么是UNIX域套接字可以参考:https://cloud.tencent.com/developer/article/1018893 这里主要介绍非命名的UNIX域套接字的用法。...功能:创建一个全双工的流管道 参数: domain:协议家族,为AF_LOCAL或AF_UNIX type:套接字类型。可以是SOCK_STREAM或者SOCK_DGRAM。...为0 sv:返回套接字对,这个是输出参数。返回的两个描述符都是可读可写的。 返回值:成功返回0,失败返回-1....注意:由于创建的每个套接字都是没有名字的,这就意味着无关进程不能使用它们。 2.一个简单的例子: 父进程给子进程发送一个数据给子进程,子进程收到数据后最数据进行加一操作,再发回给父进程。...2)普通的TCP UDP套接字是不能传递文件描述符的

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

    linux网络编程之socket(十五):UNIX域套接字编程和socketpair 函数

    UNIX域套接字与TCP套接字相比较,在同一台主机的传输速度前者是后者的两倍。这是因为,IPC机制本质上是可靠的通讯,而网络协议是为不可靠的通讯设计的。... domain socket与TCP套接字相比较,在同一台主机的传输速度前者是后者的两倍。...三、UNIX域套接字编程注意点 1、bind成功将会创建一个文件,权限为0777 & ~umask 2、sun_path最好用一个绝对路径 3、UNIX域协议支持流式套接口与报式套接口 4、UNIX...域流式套接字connect发现监听队列满时,会立刻返回一个ECONNREFUSED,这和TCP不同,如果监听队列满,会忽略到来的SYN,这导致对方重传SYN。...protocol: 协议类型 sv: 返回套接字对 返回值:成功返回0;失败返回-1 实际上socketpair 函数跟pipe 函数是类似的,也只能在同个主机上具有亲缘关系的进程间通信,但

    4.3K00

    linux网络编程之socket(十一):套接字IO超时设置方法和用select实现超时

    accept  * fd: 套接字  * addr: 输出参数,返回对方地址  * wait_seconds: 等待超时秒数,如果为0表示正常模式  * 成功(未超时)返回已连接套接字,失败返回-1,超时返回... - 带超时的connect  * fd: 套接字  * addr: 输出参数,返回对方地址  * wait_seconds: 等待超时秒数,如果为0表示正常模式  * 成功(未超时)返回0,失败返回-...4、connect_timeout :在调用connect前需要使用fcntl 函数将套接字标志设置为非阻塞,如果网络环境很好,则connect立即返回0,不进入if 大括号执行;如果网络环境拥塞,则connect...此后调用select与前面3个函数类似,但这里关注的是可写事件,因为一旦连接建立,套接字就可写。...退出之前还需重新将套接字设置为阻塞。

    7K01

    由 JVM Attach API 看跨进程通信中的信号和 Unix 域套接字

    这篇会结合跨进程通信中的信号和 Unix 域套接字来看 JVM Attach API 的实现原理, 你将获得下面这些相关的知识 信号是什么 如何写一个不能被“轻易”杀死的程序 Unix 域套接字的用法...Unix 域套接字是什么?...Unix 域套接字更加高效,Unix 套接字不用进行协议处理,不需要计算序列号,也不需要发送确认报文,只需要复制数据即可 Unix 域套接字是可靠的,不会丢失报文,普通套接字是为不可靠通信设计的 Unix...域套接字的代码可以非常简单的修改转为普通套接字 域套接字代码示例 下面是一个简单的 C 实现的域套接字的例子。...代码结构如下: . ├── client.c └── server.c server.c 充当 Unix 域套接字服务器,启动后会在当前目录生成一个名为 tmp.sock 的 Unix 域套接字文件

    1.4K20

    linux网络编程之socket(十六):通过UNIX域套接字传递描述符和 sendmsgrecvmsg 函数

    在前面我们介绍了UNIX域套接字编程,更重要的一点是UNIX域套接字可以在同一台主机上各进程之间传递文件描述符。...1、msg_name :即对等方的地址指针,不关心时设为NULL即可; 2、msg_namelen:地址长度,不关心时设置为0即可; 3、msg_iov:是结构体iovec 的指针。   ...域协议才能在进程间传递文件描述符,如果想要在没有亲缘关系的进程间      * 传递,则不能用socketpair函数,要用socket()函数 */     if (socketpair(PF_UNIX...最后提醒一点,只有unix域协议才能在本机进程间传递文件描述符,如果想要在没有亲缘关系的进程间传递,则不能用socketpair函数,要用socket()函 数 才行。...实际上这里通过sendmsg来传递fd,父进程才算是真正打开 了文件,也就是父进程的fd 也指向了file结构体,此file 结构体内的引用计数为2。

    3.3K00

    socket的连接超时 与 读取写入超时

    对于Internet域套接字(AF_INET)(如TCP和UDP),remote_socket参数的目标部分应包含主机名或IP地址,后跟冒号和端口号。...对于Unix域套接字,目标部分应指向文件系统上的套接字文件。 注意:默认情况下,流将以阻塞模式打开。您可以使用stream_set_blocking($stream,1)将其切换到非阻塞模式。...在非阻塞模式下,调用 fgets() 总是会立即返回;而在阻塞模式下,将会一直等到从资源流里面获取到数据才能返回。 2.errno 如果连接失败,将设置为系统级错误号。...3.errstr 如果连接失败,将设置为系统级错误消息。 4.timeout connect()系统调用应该超时之前的秒数。...注意: 要设置通过套接字读取/写入数据的超时,请使用stream_set_timeout(),因为仅在连接套接字时才应用超时。 5.flags 位掩码字段,可以设置为连接标志的任意组合。

    5.8K30

    python编程之网络基础

    一 套接字简介 1 套接字是一种具有通讯端点概念的计算机网络数据结构,网络化的应用程序在开始任何通讯之前都必须要建立套接字。...套接字有两种,分别是基于文件型的和基于网络型的 Unix 套接字是第一个套接字家族,其“家族名”为AF_UNIX(在POSIX1.g标准中也叫AF_LOCAL),表示“地址家族:Unix”,包括python...在内的大多数流行平台上都是用术语“地址家族”及其缩写“AF”而老一点的系统中,地址家族被称为“域”或“协议家族”,并使用缩写“PF”而不是“AF” 由于两个进程都运行在同一台机器上,而且这些套接字是基于文件的...s.settimeout(timeout) 设置套接字操作的超时期,timeout是一个浮点数,单位是秒。值为None表示没有超时期。...一般,超时期应该在刚创建套接字时设置,因为它们可能用于连接的操作(如connect()) s.gettimeout() 返回当前超时期的值,单位是秒,如果没有设置超时期,则返回None。

    90620

    socket实现TCPIP通信

    可以将套接字看作不同主机间的进程进行双间通信的端点,它构成了单个主机内及整个网络间的编程界面。套接字存在于通信域中,通信域是为了处理一般的线程通过套接字通信而引进的一种抽象概念。...套接字通常和同一个域中的套接字交换数据(数据交换也可能穿越域的界限,但这时一定要执行某种解释程序),各种进程使用这个相同的域互相之间用Internet协议簇来进行通信 1.2.2 socket工作流程...AF_UNIX 或者 AF_INET type: 套接字类型可以根据是面向连接的还是非连接分为SOCK_STREAM或SOCK_DGRAM protocol: 一般不填默认为0 2.2 Socket...s.settimeout(timeout) 设置套接字操作的超时期,timeout是一个浮点数,单位是秒。值为None表示没有超时期。...一般,超时期应该在刚创建套接字时设置,因为它们可能用于连接的操作(如connect()) s.gettimeout() 返回当前超时期的值,单位是秒,如果没有设置超时期,则返回None。

    2.6K20

    【Linux网络#2】: Socket 编程

    它适用于多种网络通信方式,如 IPv4、IPv6,以及 UNIX 域套接字(用于本地进程间通信)。...实际上在网络上通信的时候套接字种类是比较多的,下面是常见的三种: unix 域间套接字编程--同一个机器内 原始套接字编程--网络工具 网络套接字编程--用户间的网络通信 设计者想将网络接口统一抽象化...--参数的类型必须是统一的,底层是一种多态的设计 运用场景: 网络套接字:运用于网络跨主机之间通信+本地通信 unix域间套接字: 本地通信 我们现在在使用网络编程通信时是应用层调传输层的接口,而原始套接字...AF_UNIX:本地通信(UNIX 域套接字)。 通过这种设计,Socket API 可以通过统一的函数接口,处理不同类型的地址格式。...参数: domain:协议域,如 AF_INET(IPv4)、AF_INET6(IPv6)、AF_LOCAL(Unix域套接字)。

    30110

    Python 网络编程

    就是为了联通多方然后进行通信用的,即把数据从一方传递给另外一方,为了让在不同的电脑上运行的软件,之间能够互相传递数据,就需要借助网络的功能。...在1台电脑上可以通过进程号 PID 来唯一标识一个进程,但是在网络中这是行不通的。...socket.settimeout(timeout) 设置套接字操作的超时期,timeout是一个浮点数,单位是秒。值为None表示没有超时期。...一般,超时期应该在刚创建套接字时设置,因为它们可能用于连接的操作(如connect()) socket.gettimeout() 返回当前超时期的值,单位是秒,如果没有设置超时期,则返回None。...socket.makefile() 创建一个与该套接字相关连的文件 套接字对象方法,除了 makefile(),其他都与套接字专用的 Unix 系统调用相对应。

    1.3K10

    sock基础编程介绍

    为了建立通信通道,网络通信的每个端点拥有一个套接字对象极为重要。 套接字为BSD UNIX系统核心的一部分,而且他们也被许多其他类似UNIX的操作系统包括Linux所采纳。...许多非BSD UNIX系统(如ms-dos,windows,os/2,mac os及大部分主机环境)都以库形式提供对套接字的支持。 三种最流行的套接字类型是:stream,datagram和raw。...socket=socket.socket(familly,type) family的值可以是AF_UNIX(Unix域,用于同一台机器上的进程间通讯),也可以是AF_INET(对于IPV4协议的TCP...AF_INET家族包括Internet地址,AF_UNIX家族用于同一台机器上的进程间通信。...如果更改client.py的sock.send('1')为其它值在终端会打印”please go out!“,更改time.sleep(2)为大于5的数值, 服务器将会超时。

    1.4K10

    通过select 和状态EINPROGRESS 实现socket 连接超时判断

    调用connect连接一般的超时时间是75s, 但是在程序中我们一般不希望等这么长时间采取采取动作。...可以在调用connect之前设置套接字非阻塞,然后调用connect,此时connect会立刻返回, 如果连接成功则直接返回0(成功), 如果没有连接成功,也会立即返回并且会设置errno为EINPROCESS...,这并不是一个致命错误,仅仅是告知你已经在连接了,你只要判断是它就继续执行后面的逻辑就行了,比如select.通过select设置超时来达到为connect设定超时的目的....SO_RCVTIMEO和SO_SNDTIMEO套接口选项可以给套接口的读和写,来设置超时时间, 一、在unix网络编程中,说是他们只能用于读和写,而像 accept和connect都不能用他们来设置...可是我在阅读内核源码的过程中看到,在linux中,accept和connect可以分别用 SO_RCVTIMEO和SO_SNDTIMEO套接口来设置超时,这里他们的超时时间也就是sock的sk_rcvtimeo

    1.3K40

    深入剖析Linux网络设计中网络IO的重要角色

    例如,在尝试将UNIX域数据报套接字连接到流套接字时,可能会发生此错误。 ETIMEDOUT 尝试连接时超时。服务器可能太忙,无法接受新连接。...注意,对于IP套接字,当服务器上启用Syncookie时,超时可能很长。...当流套接字对等端执行有序关闭时,返回值将为0;不同域(例如UNIX和Internet域)中的数据报套接字允许零长度数据报,当接收到这样的数据报时,返回值为0;如果从流套接字接收的请求字节数为0,则也可以返回值...recv的错误码: 错误码 含义 EAGAIN,EWOULDBLOCK 套接字标记为非阻塞,接收操作要求阻塞,或者设置了接收超时,并且在接收数据之前超时。...EDESTADDRREQ 套接字不是连接模式,并且未设置对等地址。 EFAULT 为参数指定了无效的用户空间地址。 EINTR 在传输任何数据之前发生的信号。 EINVAL 传递的参数无效。

    64020

    unix环境高级编程(下)-高级IO和进程间通信篇

    高级进程间通信 高级进程间通信提供一种可以在进程间传递文件描述符的机制,包括STREAMS管道和unix域套接字 一. 高级IO 1....网络进程间通信:套接字 1. 套接字描述符 套接字是通信端点的抽象,是用文件描述符实现的 创建套接字描述符: ? domain:套接字域 ? type:套接字类型 ?...但是sendto允许在勿连接到套接字上指定一个目标地址 4.2 recv ?...套接字选项 5.1 套接字选项包括 通用选项,工作在所有套接字类型上 在套接字层次管理的选项,但是依赖底层协议的支持 特定与某种协议的选项,为某个协议独有 5.2 设置套接字的函数 ? 6....UNIX域套接字 用于在同一台机器上运行的进程之间通讯

    1.8K42

    C++中的socket编程常用接口

    常见的值包括: AF_INET:IPv4协议 AF_INET6:IPv6协议 AF_UNIX(或 AF_LOCAL):本地通信(同一台机器上的进程间通信) type(套接字类型):指定套接字的类型。...五、connect() connect() 函数在客户端编程中起着关键作用。它用于将客户端的套接字连接到服务器的地址和端口。...它通常用于从服务器或客户端接收数据,可以在服务器端和客户端的通信中使用。 recv() 的使用 recv() 函数通常在已经建立连接的套接字上使用,用于从对端接收数据。...十、setsockopt() setsockopt() 函数用于设置套接字选项。它可以控制套接字的行为,如允许端口复用、设置超时时间、控制数据包的发送和接收缓冲区大小等。...十一、fcntl fcntl 函数在 Unix 系统中用于对文件描述符进行各种控制操作,包括设置非阻塞模式、获取和设置文件描述符标志等。在网络编程中,它通常用于设置套接字的非阻塞模式。

    51010

    Unix域协议学习小结

    Unix域协议 概述 Unix域协议不是一个真正意义上的协议族,只是一个利用socket api在单个主机上进行进程间通信的方法。...根据《Unix网络编程卷1》,选择Unix域套接字有以下三点理由: 尽管使用的API类似于网络套接字,但是所有的通信几乎都是发生在操作系统内核层面,往往比在同一个主机上使用TCP通信快一倍 Unix域套接字可以在同一主机的不同进程间传递描述符...Unix域套接字可以把客户的凭证(用户ID以及组ID)提供给服务器,从而能够提供额外的安全检查措施 使用方式 Unix域套接字对比网络套接字,在适用方式上主要有以下几点不同: 1、地址 Unix域套接字使用...网络套接字地址则是IP+Port,Unix域套接字地址是一个socket类型的文件在文件系统中的路径,这个socket文件由bind调用创建。...Connect系统调用中指定的路径名必须是一个当前绑定在某个打开的Unix域套接字上的路径名,而且套接字类型(字节流或数据报)必须要一致,以下三种条件都会出错: 路径名已存在确不是套接字(通过ls -l

    2.2K20

    python socket编程

    socket本质上就是在2台网络互通的电脑之间,架设一个通道,两台电脑通过这个通道来实现数据的互相传递。...:socket(family,type[,protocal])使用给定的套接族,套接字类型,协议编号(默认为0)来创建套接字 socket.AF_UNIX:用于同一台机器上的进程通信(即本机通信) socket.AF_INET...s.getsockopt(level, optname[, buflen]):返回套接字选项的值 s.settimeout(timeout):设置套接字操作的超时时间,timeout是一个浮点数,单位是秒...一般超时期应在刚创建套接字时设置,因为他们可能用于连接的操作,如s.connect() s.gettimeout():返回当前超时值,单位是秒,如果没有设置超时则返回None s.fileno():返回套接字的文件描述...s.setblocking(flag):如果flag为0,则将套接字设置为非阻塞模式,否则将套接字设置为阻塞模式(默认值)。

    1.3K111
    领券