网站首页 > 教程分享 正文
由于各个进程之间独享一块用户地址空间,一般而言这块独立的用户地址空间不能互相访问,所以进程之间想要通信必须通过内核空间(每个进程共享)。
进程间的通信方式主要有以下几种:
- 管道
- 消息队列
- 共享内存
- 信号量
- 信号
- Socket
信号
Linux操作系统中,为了响应各种各样的事件,提供了很多信号,可以通过kill -l命令来查看所有的信号。
- 运行在Shell终端的进程,我们可以通过某些键盘的组合键给进程发送信号。
- 运行在后台的进程,我们可以通过kill命令的方式给进程发送信号,但需要提前知道进程的PID
Socket
前面的进程间通信都仅限于同一台主机,如果需要跨网络上的不同主机上的进程之间进行通信,就需要通过Socket(Socket也可以在同一台主机上通信)。
int socket(int domain, int type, int protocal)
- domain:指定协议族,AF_INET表示IPV4,AF_INET6表示IPV6、AF_LOCAL/AF_UNIX表示用于本机
- type:SOCK_STREAM表示字节流(TCP),SOCK_DGRAM表示数据报(UDP)、SOCK_RAM表示原始套接字
- protocal:废弃
基于TCP的Socket通信
- 服务端和客户端初始化Socket,得到文件描述符
- 服务端调用bind,绑定IP地址和端口
- 服务端调用listen,进行监听
- 服务端调用accept,等待客户端连接
- 客户端调用connect,向服务端的IP地址和端口发起请求
- 服务端accpet,返回用于传输的socket文件描述符
- 客户端调用write写入数据,服务端调用read读取数据
- 客户端断开连接时会调用close,服务端在read数据的时候会读取到EOF,待处理完数据后,服务端会调用close,表示连接关闭
监听和传输数据的SOCKET是两个SOCKET,连接成功建立以后,双方通过read和write来读写进程。
基于UDP的Socket通信
UDP是无连接的,因此不需要三次握手,不需要调用listen和connect,但是UDP的交互仍然需要bind IP地址和端口。
每次通信调用sendto和recvfrom时都需要传入目标主机的IP地址和端口。
本地Socket通信
本地Socket支持字节流和数据报两种格式:
- 对于本地字节流,socket类型为AF_LOCAL和SOCK_STREAM
- 对于本地数据报,socket类型为AF_LOCAL和SOCK_DGRAM
本地socket不像跨网络主机通信需要绑定IP和端口,而是绑定本地一个文件
猜你喜欢
- 2024-12-25 MySQL数据查询太多会OOM吗? mysql为什么数据量多查询就慢
- 2024-12-25 一次Dubbo拥堵的分析 dubbo遇到的问题
- 2024-12-25 Java程序员使用JSSE实现SSL/TLS安全套接字
- 2024-12-25 阿瑟Java (44):HTTP、TCP/IP、Socket 的关联
- 2024-12-25 基于socket API之上的跨平台MQTT客户端源码分享
- 2024-12-25 Java编程-高并发情况下接口性能优化实践-提升吞吐量TPS
- 2024-12-25 解决QTcpSocket发送数据成功,但接收端接收不全的问
- 2024-12-25 在线客服(IM)系统源码分享 在线客服源码下载
- 2024-12-25 深入剖析阻塞式socket的timeout socket connect 阻塞
- 2024-12-25 推荐一个Java编写的长连接服务Netty-SocketIO
你 发表评论:
欢迎- 最近发表
-
- 免费10年VPS-serv00服务器,注册与自动化保号
- Consul微服务注册中心使用指南
- 谷歌云代理商:注册谷歌云服务器需要准备哪些资料?
- steam账号注册不了/注册失败?好用的解决方法看这里
- 微服务架构中的服务注册与发现有哪些?Zookeeper、Eu
- # 从浅入深 学习 SpringCloud 微服务架构(三)注册中心 Eureka(1)
- 一文深入理解AP架构Nacos注册原理
- 群晖NAS本地搭建NVIDIA v-GPU License Server 授权许可服务器的教程
- IDEA 2024解决We could not validate your license XX
- 保障数据完整性:深入解析Oracle数据库的主键和外键约束
- 标签列表
-
- css导航条 (66)
- sqlinsert (63)
- js提交表单 (60)
- param (62)
- parentelement (65)
- jquery分享 (62)
- check约束 (64)
- curl_init (68)
- sql if语句 (69)
- import (66)
- chmod文件夹 (71)
- clearinterval (71)
- pythonrange (62)
- 数组长度 (61)
- javafx (59)
- 全局消息钩子 (64)
- sort排序 (62)
- jdbc (69)
- php网页源码 (59)
- assert h (69)
- httpclientjar (60)
- postgresql conf (59)
- winform开发 (59)
- mysql数字类型 (71)
- drawimage (61)
本文暂时没有评论,来添加一个吧(●'◡'●)