当初 Austin 的文档我感觉还是比拟全的,但到了看代码的时候,可能有的同学就不晓得应该怎么看,有想晓得模块之间的调用链路,有想一点一点把细节给全看了。这时候就很可能在我的项目里犯迷糊了,绕不出不来了。
Java 开源我的项目音讯推送平台🔥推送下发【邮件】【短信】【微信服务号】【微信小程序】【企业微信】【钉钉】等音讯类型。
- https://gitee.com/zhongfucheng/austin/
- https://github.com/ZhongFuCheng3y/austin
我工作了几年,也接手过很多新的业务,这里聊聊我的教训。
1、在看代码之前,先整体意识下以后的零碎,到底是干什么的。由几个模块组成,上下游的关系是怎么样的。
这个对于 Austin 来说就很简略啦,就发送音讯。外围就是由接入层 ->MQ-> 生产逻辑层给组成,另外提供一个后盾治理以及一个流解决模块
工程模块 | 作用 |
---|---|
austin-common | 我的项目公共包:存储着我的项目公共常量 / 枚举 /Bean |
austin-support | 我的项目工具包:对接中间件 / 组件 |
austin-cron | 定时工作模块:对 xxl-job 封装和我的项目定时工作逻辑 |
austin-web | 后盾治理模块:提供接口给前端调用 |
austin-service-api | 音讯接入层接口定义模块:只有接口和必要的入参依赖 |
austin-service-api-impl | 音讯接入层具体实现模块:实在解决申请 |
austin-handler | 音讯解决逻辑层:生产 MQ 下发音讯 |
austin-stream | 实时处理模块:利用 flink 实时处理下发链路数据 |
austin-data-house | 数据仓库模块:生产 MQ 数据写入 hive |
2、理解了以后零碎之后,这时候把代码给下载到本地,看看有没有方法在本地运行,或者在测试环境中近程 debug。这一步就是为了能让本人实在体验下性能,试着追下整体逻辑(不必细看)。
这块 Austin 也好办,因为在本地就能够起来,发消息本地也是失常发送的。就从接入层的发送接口开始,一步一步的 bug,办法我这边根本都会有正文,有“难懂”的代码应该都有文档通知你过后我是怎么设计的。
这时候不必去看很细的内容,比方某个字段是怎么拼接的,比方我做去重性能的时候 key 是什么,value 是什么。反正先大体把每一个办法给过一遍,晓得会有这些解决,最初就发送了一条音讯。
3、整体逻辑过完了当前,再次回到架构图或者性能图,看看是不是又了解些了。这时候就应该不会感到形象,应该曾经又进一步明确了零碎的整体性能了,甚至理解到了写代码的人的格调。
4、持续 debug!看细节!摸索为什么要这样设计代码,如果是你写有没有更好的写法,或者现有这写法有没有值得吐槽的。
这时候就得看一些你纳闷的细节性能是怎么实现的,比方之前可能不晓得去重在 redis 是怎么实现的,这时候就看看 key 是什么,value 是什么。可能不晓得数据隔离是怎么实现的,原来当初用的是 SpringBoot Kafka 新版本提供的个性(在创立 kafka 容器前就能够动静去更改 groupId)。比方为什么我要在这一步打上日志,看看发送音讯时,打印的日志是哪些,这条日志打下来是干什么的。
接触一个新的我的项目,永远都是:先看 纲要 -> 再看细节,有 debug 条件是最好的,配合日志看看解决链路。
如果想学 Java 我的项目的 ,强烈推荐 我的我的项目 音讯推送平台 Austin(8K stars),能够用作 毕业设计 ,能够用作 校招 ,能够看看 生产环境是怎么推送音讯 的。音讯推送平台🔥推送下发【邮件】【短信】【微信服务号】【微信小程序】【企业微信】【钉钉】等音讯类型。
- https://gitee.com/zhongfucheng/austin/
- https://github.com/ZhongFuCheng3y/austin
最近有在不同的中央看到了我的开源我的项目 austin,每次都能让我 窃喜一番 。以至于给我感觉 很有戏,或者能成为网红我的项目。
austin 音讯推送平台从零开写更新了一年多,Gitee 4.9k+stars,GitHub 4k+ stars,能达到这成绩,一方面是我 手不释卷地经营 ,另一方面是有不少看过这个我的项目的小伙伴在 默默地帮我举荐。
我素来没有跟别的博主被动举荐过我的我的项目,让他们帮忙宣传宣传。这个是能够做到的,但我没去这样做。
austin 目前跟谷粒商城 / 瑞吉外卖 / 淘淘商城这种 Java 网红我的项目在知名度上还没法比,还远着。当初应该还不会有面试官看完简历晓得是 austin,也应该不会被提到:你们项目组挺大啊。
austin 跟商城 / 外卖这种我的项目不一样的是:只有有点规模的公司,都会有音讯推送平台这种零碎,不会受到公司具体业务的影响。
至于有很多人会提到 这零碎能不能写在简历上,它离生产环境的我的项目还有多远,是不是只是一个学习我的项目。
1,这零碎能写在简历上,我两年前写的就是它,能用作面试,也通过了面试。我这也有股东在校招通过它拿了大厂的 offer 的。
2,不要感觉生产环境的我的项目有多牛逼,这我的项目是能上生产环境的,也曾经有人在线上部署了 。我置信必定不止一个,我看 Git 的 fork 记录也有其余公司的, 要是你也部署了,还劳烦在 Git 填一下。
3,这零碎 适宜学习,次要是它的业务不简单,但可玩性还是挺高的(看我列举了一堆的技术栈就晓得了)
如果想学 Java 我的项目的 ,强烈推荐 我的我的项目 音讯推送平台 Austin(8K stars),能够用作 毕业设计 ,能够用作 校招 ,能够看看 生产环境是怎么推送音讯 的。音讯推送平台🔥推送下发【邮件】【短信】【微信服务号】【微信小程序】【企业微信】【钉钉】等音讯类型。
- https://gitee.com/zhongfucheng/austin/
- https://github.com/ZhongFuCheng3y/austin