Skip to content
This repository has been archived by the owner on May 31, 2023. It is now read-only.

Latest commit

 

History

History
67 lines (34 loc) · 1.46 KB

README.md

File metadata and controls

67 lines (34 loc) · 1.46 KB

Simple Tbus

模仿tbus写的简易跨进程/网络间通信中间件 实现思想见doc/实习述职

complie

create_channel_tool

cmake --build "/path/to/build/dir" --target create_channels

tbusd

cmake --build "/path/to/build/dir" --target tbusd_run

receive_api

cmake --build "/path/to/build/dir" --target api_channel_receive

receive_api

cmake --build "/path/to/build/dir" --target api_channel_send

run

建立 0.0.0.1 -> 0.0.0.2 容量为409600的通道

.\create_channels simple_tbus_test 40960 simple_channel_test 409600 0.0.0.1 0.0.0.2

打开tbusd

.\tbusd_run

打开接收进程0.0.0.2

./api_channel_receive 0.0.0.2

打开发送进程0.0.0.1 向0.0.0.2 发送 “hello!world”

./api_channel_send 0.0.0.1 0.0.0.2 hello!world'

note

由于api_channel_receive1秒收一次消息,api_channel_send3秒发一次消息,所以会出现很多check faild: fail to resv请不要意外

依赖

boost 1.6以上版本

各个文件内容

SimpleTbusAPI tbus 的API封装

SimpleTbusd tbusd的实现,

SimpleTbusdConn tbusd的实现,几乎所有通信逻辑都在这个文件,包括tbusd与本地进程、tbusd与tbusd的通信逻辑

SimpleTbusCtl 创建全局通道表的实现

SimpleChannel 基于共享内存的单消费者单生产者无锁循环的实现

todo

脚本功能完善

第一次写 asio 代码写得太丑(尤其是asyn_write, asyn_read不允许连续调用,需要不停在回调函数中嵌套)