欢迎您访问程序员文章站本站旨在为大家提供分享程序员计算机编程知识!
您现在的位置是: 首页  >  IT编程

10天前我想造个*

程序员文章站 2022-07-11 09:22:59
是这样的,大概10天前,我忽然就想造个*,这个*的主要作用是收集客户端的日志,通过服务端存储到指定的持久化介质中。客户端和服务端都可以通过简单的配置实现快速接入 ......

想法出现

是这样的,大概10天前,我忽然就想造个*,这个*的主要作用是收集客户端的日志,通过服务端存储到指定的持久化介质中。客户端和服务端都可以通过简单的配置实现快速接入。然后我就画了一个图,就是下面这样的。

开局一张图,实现全靠编

10天前我想造个*

这张图很粗糙,但是足够表达了我的想法,我甚至和马桶以及kent说,能一行代码搞定的事情,不要搞复杂了,思路非常简单,就是提供一个客户端端,通过配置传输通道(redis/rabbitmq),就可以把日志提交到服务器。

使用队列的方式传输数据,是出于削峰和解耦的目的,更重要的是,一旦任意语言的客户端实现了传输协议,那么他们完全可以利用自己熟悉的语言的优势去接入 tomatolog,抱歉,我觉得这个名字还不错的。

至于服务端,通过插件式实现日志存储,如果对现有的存储介质不满意,那么可以扩展自己的持久层,只需要实现 ilogwriter 接口,然后讲开发好的库放到 plugins 中即可,服务的还提供输入、过滤、报警等必要的功能;报警功能非常重要,必须提供至少两种警报通知方式,初步定义为:sms/email.

然后就出现了下面这张图

10天前我想造个*

通过比较这两张图可以看出,系统架构内部有不少的变化,特别是服务端方便,在易用性和可扩展性方面增加了不少东西。特别重要的是,真的实现了通过一行代码将客户端引入到项目中使用的目的,通过这几天的不懈努力,我得到了下面这个通知

10天前我想造个*

结束语

今天写这篇随笔真的是心血来潮,好消息是,tomatolog 已经实现并提交到了 github,本文只是预告一下,接下来会有更详细的接入使用文档,我只能说,这也许是目前为止 .netcore 平台上最简单易用的日志工具。

大晚上的发文,正好没人看,偷偷发。