同步操作将从 cpp-master/cpp-tbox 强制同步,此操作会覆盖自 Fork 仓库以来所做的任何修改,且无法恢复!!!
确定后同步将在后台操作,完成时将刷新页面,请耐心等待。
全称: C++ Treasure Box,C++百宝箱,是一个基于 Reactor 模式的服务型 开发框架 与 组件库,旨在让C++开发变得轻松。
参考项目:
参考 Node.js 的 Reactor 模式。
主线程以 Reactor 模式处理非阻塞 IO 事件,并配合 ThreadPool 执行大运算与阻塞性操作。
该模式避免了多线程模式竞态加锁的烦恼,程序稳定可靠。
使用内置的 main 框架处理了所有与业务无关的工作。您不需要关心日志怎么输出、参数怎么解析、程序怎么退出、main函数怎么写这些琐碎的事情。main框架都为您处理好了。
您只需要派生tbox::main::Module
类,填写业务代码,然后注册到框架即可。
可以与运行中的服务通过telnet进行交互,令其打印内部数据,或是执行特定的动作。这极大地降低了调试难度。
1) 有三种日志输出渠道:stdout + filelog + syslog
std::cout
输出到终端;syslog()
输出到系统日志;前缀.年月日_时分秒.进程号.log
的文件中。文件大小超过1M则另创建新的日志文件。由于写文件效率低,该输出渠道采用前后端模式。三种渠道可以启动参数中选定一个或同时多种,也可在运行时通过终端更改。
2) 根据日志等级渲染不同颜色,一目了然,内容详尽
日志内容包含了:等级、时间(精确到微秒)、线程号、模块名、函数名、正文、文件名、行号。
方便快速定位问题。
3) 灵活的日志输出过滤器,且能运行时修改
可在程序运行时针对不同的模块单独设置日志等级,如下:
参数以JSON的格式提供,可以传入任何格式的运行参数,包括:整数、小数、字串、数组、组合参数,满足几乎所有参数传入需求:
在执行时可以使用 -c your_cfg_file.json
导入JSON格式的配置文件。同时还可以使用配合 -s 'xx.yy.zz=vvv'
临时指定参数。
而JSON格式的配置文件还支持include指令,在加载时去包含其它的配置文件。
子线程委托主线程执行:
主线程委托子线程执行:
在接收到信号:SIGINT, SIGTERM, SIGQUIT, SIGPWR 时,会有序地执行退出流程,释放资源。做到干净地退出。
当程序出现各种程序异常,如:段错误、断言、总线错误、异常未捕获等,架框会捕获并在日志系统中打印完整的调用栈。面对程序崩溃,不再一脸茫然。效果如下:
库名 | 中文名 | 说明 |
---|---|---|
base | 基础库 | 含日志打印、常用工具等 |
util | 工具库 | 在业务代码中可能会用到的库 |
event | 事件库 | 实现了IO,Timer,Signal三种事件驱动,是整个框架的心脏 |
eventx | 事件扩展库 | 含 ThreadPool 线程池,WorkThread工作线程,TimerPool 定时器池等模块 |
log | 日志输出库 | 实现了终端、syslog、文件形式的日志输出 |
trace | 运行痕迹输出库 | 实现实时输出运行痕迹到文件的功能 |
network | 网络库 | 实现了串口、终端、UDP、TCP 通信模块 |
terminal | 终端库 | 类似shell的命令终端,可实现运行时与程序进行命令交互 |
main | 主框架 | 实现了完备的程序启动流程与框架,让开发者只需关心业务代码 |
run | 执行器 | 是个可执行程序,可加载多个由参数-l xxx 指定的动态库,并运行其中的Module |
mqtt | MQTT客户端库 | |
coroutine | 协程库 | 众所周知,异步框架不方便处理顺序性业务,协程弥补之 |
http | HTTP库 | 在network的基础上实现了HTTP的Server与Client模块 |
alarm | 闹钟库 | 实现了4种常用的闹钟:CRON闹钟、单次闹钟、星期循环闹钟、工作日闹钟 |
flow | 流程库 | 含多层级状态机与行为树,解决异步模式下动行流程问题 |
crypto | 加密工具库 | 实现了常用的AES、MD5运算 |
dbus | DBUS适配库 | 实现了将dbus集成到event进行非阻塞处理事务的功能 |
sudo apt update
sudo apt install build-essential
sudo apt install libgtest-dev libgmock-dev
sudo apt install libmosquitto-dev
sudo apt install libdbus-1-dev
git clone https://gitee.com/cpp-master/cpp-tbox.git
cd cpp-tbox
make 3rd-party modules RELEASE=1
完成之后,头文件与库文件都在 .staging 目录下。
当然也可以通过指定 STAGING_DIR
对头文件与库文件的生成路径进行指定。
如:
make 3rd-party modules RELEASE=1 STAGING_DIR=$HOME/.tbox
完成之后,头文件与库文件都在 $HOME/.tbox 路径下。
cmake -B build
cmake --build build
cmake --install build
通过指定CMAKE_INSTALL_PREFIX
自定义安装目录(默认安装在/usr/local):
cmake -B build -DCMAKE_INSTALL_PREFIX=$HOME/.tbox
关于如何使用 cpp-tbox 开发自己的程序,详见教程: cpp-tbox-tutorials
使用find_package
的例子:
cmake_minimum_required(VERSION 3.10)
project(tbox-find_package)
find_package(tbox COMPONENTS base util alarm event eventx)
add_executable(demo main.cpp)
target_link_libraries(demo PRIVATE tbox::tbox_base tbox::tbox_util tbox::tbox_alarm tbox::tbox_event tbox::tbox_eventx)
库名 | 依赖模块 | 必需 | 说明 | 安装方法 |
---|---|---|---|---|
libgtest-dev | 所有 | 否 | 单元测试用 | sudo apt install libgtest-dev |
libgmock-dev | 所有 | 否 | 单元测试用 | sudo apt install libgmock-dev |
libmosquitto-dev | mqtt | no | MQTT | sudo apt install libmosquitto-dev |
libdbus-1-dev | dbus | no | DBus | sudo apt install libdbus-1-dev |
你可以决定哪些模块需要构建,哪些不需要。
打开 config.mk 文件,将不需要模块对应 app_y += xxx
屏蔽即可,但要注意模块间的依赖性。
MIT,可免费商用。
如果这个项目让您的工作更轻松、下班更早了,请您给我更多的鼓励。
你可以做这些:
此处可能存在不合适展示的内容,页面不予展示。您可通过相关编辑功能自查并修改。
如您确认内容无涉及 不当用语 / 纯广告导流 / 暴力 / 低俗色情 / 侵权 / 盗版 / 虚假 / 无价值内容或违法国家有关法律法规的内容,可点击提交进行申诉,我们将尽快为您处理。