Hyperf 下使用阿里云日志 SLS
- 在学习hyperf框架过程中,日志处理这一块思考了很长时间,项目有大小复杂度不同,日志的处理也就需要多一些方案。在完成了filelog、dblog后,第三方日志系统也是需要接入的。因为一直用阿里云日志sls,所以对官方的sdk进行修改,适配在hyperf使用。
- 这也是第一次写composer包,边学边写,将官方sdk查阅一遍一遍,最终完成了(不过目前只实现了putlogs日志存储功能),后续会继续完善
- 比较心酸的就是,阿里官方的文档、与sdk的代码实现居然不一样,导致遇到了数据编码解码问题,浪费了不少时间(编写过程中并不是直接copy)。
- 能力有限,基础薄弱,官方sdk有些代码也没有深究为啥意义是啥能否修改,直接照用。例如:Protobuf、LogGroupList、LogGroup等
- 看完文章是否可以点个赞!!!!
问题
阿里云文档https://help.aliyun.com/document_detail/29026.html?spm=a2c4g.11186623.2.8.a66874316mHoR3 ,有问题的地方框选了
sdk代码
由上可见,sdk与官方文档给出的不一样的三个地方,请求地址
,压缩类型
,是否shard
,压缩类型要用sdk的否则出错,其余两个由于没测试目前还不知道要用文档还是sdk的。
一 安装
https://packagist.org/packages/yoctometre/...
composer require yoctometre/aliyun-sls
二 使用
- 生成配置文件
php bin/hyperf.php vendor:publish yoctometre/aliyun-sls
- putlog到阿里云sls
use Hyperf\Di\Annotation\Inject; use Ym\AliyunSls\ClientInterface; /** * @Inject * @var ClientInterface */ protected $sls; // 注意不能有空置,如果有空值可以处理为0,否则无法压缩数据产生致命错误。 $logData = ['k1'=>v1,'k2'=>v2,……]; $this->sls->putLogs($logData);
结语
- 第一次写copomser包
- 第一次写博文(以前总看)
- 希望以后成为自己的常态
本作品采用《CC 协议》,转载必须注明作者和本文链接
本帖由系统于 3年前 自动加精
推荐文章: