码迷,mamicode.com
首页 > Web开发 > 详细

AF_UNIX和AF_INET

时间:2018-06-08 10:39:06      阅读:255      评论:0      收藏:0      [点我收藏+]

标签:管道   获取   路径   网络   使用   family   添加   路径名   指定   

family参数代表地址家族,比较常用的为AF_INET或AF_UNIX。AF_UNIX用于同一台机器上的进程间通信,AF_INET对于IPV4协议的TCP和UDP 。

type参数代表套接字类型,SOCK_STREAM(流套接字)或者SOCK_DGRAM(数据报文套接字)。

其中AF_INET类型有关的例子非常多,但AF_UNIX的少见,所以给出一个AF_UNIX简单的例子,并通过select实现非阻塞socket。

Server端:

技术分享图片
<pre class="python" name="code">import os  
import socket  
import select  
import sys  
  
sock = socket.socket(socket.AF_UNIX, socket.SOCK_STREAM)  
path = ./tt.d  
if os.path.exists(path):  
   os.unlink(path)  
sock.bind(path)  
sock.listen(5)  
  
infds, outfds, errfds = select.select([sock,],[],[],5)  
if len(infds) != 0:  
   con,addr = sock.accept()  
   print con.recv(1024)  
   con.close()  
   sock.close()  
print 5 seconds later no data coming  
Server

 

Client端:

技术分享图片
</pre><pre class="python" name="code">import socket    
  
sock = socket.socket(socket.AF_UNIX, socket.SOCK_STREAM)    
sock.connect(./tt.d)    
sock.send(Hello Socket)    
sock.close()  
Client

 

 

1.  AF_INET域socket通信过程

技术分享图片

典型的TCP/IP四层模型的通信过程。

 

发送方、接收方依赖IP:Port来标识,即将本地的socket绑定到对应的IP端口上,发送数据时,指定对方的IP端口,经过Internet,可以根据此IP端口最终找到接收方;接收数据时,可以从数据包中获取到发送方的IP端口。

发送方通过系统调用send()将原始数据发送到操作系统内核缓冲区中。内核缓冲区从上到下依次经过TCP层、IP层、链路层的编码,分别添加对应的头部信息,经过网卡将一个数据包发送到网络中。经过网络路由到接收方的网卡。网卡通过系统中断将数据包通知到接收方的操作系统,再沿着发送方编码的反方向进行解码,即依次经过链路层、IP层、TCP层去除头部、检查校验等,最终将原始数据上报到接收方进程。

2.  AF_UNIX域socket通信过程 

典型的本地IPC,类似于管道,依赖路径名标识发送方和接收方。即发送数据时,指定接收方绑定的路径名,操作系统根据该路径名可以直接找到对应的接收方,并将原始数据直接拷贝到接收方的内核缓冲区中,并上报给接收方进程进行处理。同样的接收方可以从收到的数据包中获取到发送方的路径名,并通过此路径名向其发送数据。

 技术分享图片

3.  相同点

操作系统提供的接口socket(),bind(),connect(),accept(),send(),recv(),以及用来对其进行多路复用事件检测的select(),poll(),epoll()都是完全相同的。收发数据的过程中,上层应用感知不到底层的差别。

4.  不同点

1 建立socket传递的地址域,及bind()的地址结构稍有区别:

  socket() 分别传递不同的域AF_INET和AF_UNIX

  bind()的地址结构分别为sockaddr_in(制定IP端口)和sockaddr_un(指定路径名)

2 AF_INET需经过多个协议层的编解码,消耗系统cpu,并且数据传输需要经过网卡,受到网卡带宽的限制。AF_UNIX数据到达内核缓冲区后,由内核根据指定路径名找到接收方socket对应的内核缓冲区,直接将数据拷贝过去,不经过协议层编解码,节省系统cpu,并且不经过网卡,因此不受网卡带宽的限制。

3 AF_UNIX的传输速率远远大于AF_INET

3 AF_INET不仅可以用作本机的跨进程通信,同样的可以用于不同机器之间的通信,其就是为了在不同机器之间进行网络互联传递数据而生。而AF_UNIX则只能用于本机内进程之间的通信。 

5.  使用场景

AF_UNIX由于其对系统cpu的较少消耗,不受限于网卡带宽,及高效的传递速率,本机通信则首选AF_UNIX域。不用多说,AF_INET则用于跨机器之间的通信。

AF_UNIX和AF_INET

标签:管道   获取   路径   网络   使用   family   添加   路径名   指定   

原文地址:https://www.cnblogs.com/shangerzhong/p/9153737.html

(0)
(0)
   
举报
评论 一句话评论(0
登录后才能评论!
© 2014 mamicode.com 版权所有  联系我们:gaon5@hotmail.com
迷上了代码!