TarsPHP
TARSPHP作为TARS在PHP语言的解决方案, 设计的时候主要考虑如下三个方面:
- 功能完善: 对标现有C++、JAVA、NodeJS体系功能
- 灵活: 论灵活, 谁与PHP争锋?
- 轻量: 用最轻量的设计, 点到即止, 即插即用
- 高效: 插上SWOOLE协程的翅膀, 不得不飞
功能完善
TARSPHP主要实现了如下功能模块:
- TARS-CLIENT
- TARS-SERVER
- TARS-EXT扩展
- TARS2PHP工具
从宏观上来讲, 使用TARSPHP你可以做这些事:
- 启动一个HTTP服务, QPS达到万级
- 启动一个二进制协议的TCP服务, QPS达到十几万级
- 启动一个定时服务, 其中可以统一管理一定数量的定时服务(与worker数量相等)
- 启动一个Websocket服务, 与浏览器进行ws协议的交互
- 调用其他支持TARS协议的服务(不限语言)
从细分模块上来讲, 你可以:
- 向TARS的本地和远程目录写日志
- 向TARS监控上报调用监控以获得图表展示
- 将TARS服务打包发布
- 拉取TARS平台的配置
- 拉取其他服务的地址
- 解析TARS平台的配置文件
灵活
从灵活性上来讲, TARSPHP做了很多优化。 以TARS-CLIENT为例, 它的使用者既可以是后台系统, 比如Laravel。 也可以是SWOOLE同步的客户端, 更可以是SWOOLE协程的客户端。 这三种情况, 兼顾了不同的应用场景, 使用者是需要按需配置即可。
除此之外, TARS-LOG模块, 既支持本地的日志, 也支持远程的日志, 使用者也可以灵活的选择。
轻量
为了最大程度的提高性能, 并支持其他现有成熟框架的扩展, 我们并没有实现非常繁重的框架逻辑。而只是给出了实现的guideline, 让开发者可以自行根据自己的情况进行定制。
比如现有社区中, 基于TARSPHP, 已有如下扩展的案例:
后续我们也会尝试接入更多的框架, 从而更好的服务开发者。
高效
在性能方面, TARSPHP也一直在追求极致:
- 使用SWOOLE作为服务容器
- 使用PHP扩展进行二进制流的打包和解包
- 对服务端的路由配置进行预热, 减少路由时间
- 对寻址信息进行本地缓存, 降低耗时
- 对日志写入、监控上报、服务保活上报进行异步化处理,绝不阻塞