网络编程(七)

UNIX域套接字(本地间进程间通信的技术)(S文件)

socket同样也可以用于本地通信(类似:管道,共享内存,消息队列,信号。。。)
效率:共享内存 > UNIX域套接字 > 消息队列 > 管道。。。。
UNIX域套接字不会出现丢包现象,非常安全可靠的!
创建套接字时使用本地协议PF_UNIX(或PF_LOCAL)。
分为流式套接字和用户数据报套接字
和其他进程间通信方式相比使用方便、效率更高
常用于前后台进程通信

在这里插入图片描述
在这里插入图片描述

基于TCP传输

TCP方式创建的unix域套接字通信,类似于无名管道,实现双向通信只需要一个文件(用于两个不相关进程或前后台进程)
在bind阶段才创建s文件

在这里插入图片描述
服务端server:

  1. socket(PF_UNIX,SOCK_STREAM)
  2. bind(struct sockaddr_un)
  3. lisen
  4. accept
  5. IO

在这里插入图片描述
客户端client:

  • socket(PF_UNIX,SOCK_STREAM)
  • connect
  • IO
    在这里插入图片描述
    在这里插入图片描述

基于UDP传输

udp方式的unix域套接字通信,类似于有名管道,实现双向通信需要两个文件

unlink(“hello”); 删除已经存在的套接字文件
服务端(server):创建的aaa套接字文件只是用来收数据,使用客户端创建的bbb文件来发数据

  • socket
  • bind
  • IO

在这里插入图片描述
客户端(client):创建的bbb套接字文件只是用来收数据,使用服务端创建的aaa套接字文件来发数据

  • socket
  • bind
  • IO
    在这里插入图片描述
    在这里插入图片描述
    注意:
    当使用socket()创建通信的套接字时:
    1、传入:AF_INET,客户端可以自己不主动绑定IP和端口,那是系统自己会去bind()
    2、传入:AF_UNIX/AF_LOCAL,客户端这边必须主动bind()它的通信文件addr.sun_path的内容以及addr.sun_family,以此告知服务器,它的通信文件位于本地上的哪一个地方,以后通信就使用该文件来进行数据交互!!!服务器也是一样的,需要bind()!!!
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值