353 stars Java项目,Java初学者必看,austin介绍 【第一话】

我还记得我以前大leader曾经在一次会议上说过:现在你们能做到这么多事情,很大原因是有公司这一整套环境。假如你离开了公司,你能搭建出来并且完美运行吗?

我站在我当时所维护的系统角度来想了下,认为确实比较难。

当时我维护的是触达系统(简单理解就是给用户发消息的),听着功能很简单,但实际上里边用到的技术栈还是蛮多的:RPC调用、分布式配置中心、Redis、Flink、MySQL、SSM开发环境、MQ、规则引擎、ELK日志、分布式定时任务调度、Hive、Elasticsearch等等

基本是把主流的Java后端技术栈用了个遍(:

有的人可能就会有疑问了;你核心的功能这么简单(就发个消息),在生产环境下你是真的用上了上面所讲的技术栈吗?你不会是写博客就在这里吹牛逼吧?我不信。

其实是真的用了这么多,且每个技术栈都有存在的必要性:

  • RPC调用:例如,营销消息需要依赖DMP(用户画像系统)数据,需要调用DMP的接口。微信类消息需要accessToken,需要调用用户服务相关接口等等,这些依赖都需要远程调用(远程调用在代码侧比较优雅的就是RPC调用了)

  • 分布式配置中心:灵活配置各类信息,这种技术框架就是YYDS。例如:可以把限流的值写在分布式配置中心,那限流的速率就可以灵活改动了。

  • Redis:高性能内存读写,可以用来去重过滤或者统计数据。例如:使用Redis做去重功能(有TTL时间非常适合消息下发业务)

  • Flink:实时流处理平台,可以用来清洗埋点的消息(所谓埋点的消息实际上就是消息链路数据信息,在消息下发过程中记录关键链路信息)

  • MySQL:存储需要事务支撑数据或者变动较少的元信息存储。例如:小程序模板的元信息就可以存储在MySQL

  • MQ:系统解耦、异步和削峰的好助手(接收埋点信息或提高响应接口速度)。例如:大量的日志数据可以先扔到Kafka

  • 规则引擎:结合分布式配置中心可做到常见需求无须系统发布即可实现。例如:把短信接入的逻辑写在规则引擎中,新的短信接入无须发布系统

  • ELK日志框架:排查处理问题好帮手。例如:在关键的地方打上log,不再登陆每一台机器上看日志,直接通过关键字搜索

  • 分布式定时任务调度:集群环境下定时更新数据以及触发任务。例如:营销消息会根据时间定时发送,在集群环境下使用定时任务调度框架指派某一台机器触发

  • Hive:离线数据存储,助数据仓库得到触达平台数据

  • Elasticsearch:触达后台页面按内容/标题匹配查询数据

可以看到列出的技术栈,每项技术都是可以深入地去研究(有一定规模的公司里,上面提到的每一项技术都会有专门的开发人员去迭代和维护)。

除了列出来的后端技术栈,一个比较成熟的项目,还有很多的细节,包括但不限于:监控告警、自动化集成部署(发布)、负载均衡(Nginx)这种运维侧的东西。

这些东西光靠一个人确实是很难做得比较完整的(:

03、血赚


入行以来,我一直充满都着好奇心。想知道某些业务场景是怎么玩的,某些技术是怎么玩的,自己所负责的东西哪里存在缺陷,有什么地方可以改善的,跟别人家公司同类的系统相比是怎么样的,还能怎么继续提升。

但由于公司相关的内容是不能随意公开的,所以很多时候就是"闭关锁国"自己造着玩。(至于系统好不好,自我感觉是良好的。跟别人有多大的差距,我也不知道)

现在看我的公众号有小白,也有很多大公司的大佬。

假设我有不错的经验分享时,小白看完之后能够借鉴我的经验进而提升自己,我感觉我写的东西就很值了。

当我的代码实现或思想已经是落后时,如果能有大佬帮我指出,我进而学习并调整,我这又是一波血赚。

04、项目内容


我以前做的是广告和触达系统的,对别的项目就不太了解了。我还是学生的时候,网上很火的是商城项目(不过现在好像也很火)。

以前还没工作的时候我不懂为什么网上这么多做商城的项目,现在工作了以后,我就更不懂了。

互联网业务其实非常多,电商只是其中一个业务

以前有幸担任面试官,面过一些实习生,好多简历上也是写的商城。对于这类项目,我问起项目或技术细节,几乎都表达得不怎么样(商城这类项目,很多功能在真实开发场景业务,感谢商城这些系统对于初学者而言,还是有些晦涩)

(:像秒杀什么的,据我了解,在生产环境下也远没想象中那么复杂。

这次从零开始写项目,我想还是以【触达系统】为主,这玩意比较好理解,并且几乎每家公司都会有这类的系统(如果没有,那就该换一家有的)

05、文章更新


项目不会很快地就迭代成型,我是打算以博客的形式来一直迭代更新,这个过程能聊的东西还是很多的,有的内容可能我也不太确定,也会发出来一起讨论讨论,比如说:

  • 在构建项目的时候,我会讲讲为什么用Maven,为什么用SpringBoot

  • 在写业务代码的时候,我会讲讲为什么我是自己喜欢写单表结构,而不join或者各种子查询

  • 为什么这个场景要用分布式配置中心,为什么要用规则引擎,能带来什么好处

想法有很多,自己也有很多不熟悉(我所讲的未必是对的,但是经过交流和深入学习之后,我还能把我的思考过程再梳理一遍发出来),我觉得在这个过程,对于小白新人来说,都会有所收获。

其实很多细节我也还没考虑好,比如前端对我来说就是件比较头疼的事(不过这两个月我预估都不会碰)

我发现还蛮多人挺在意我前端使用什么技术,到时候怎么写。

说实话,我也不知道。我前端在大学的时候搞过HTML+CSS+JavaScript+jQuery+Ajax+BootStrap,作为后台页面大概能用的效果。

我毕业听得比较多的都是Vue+Angular+React了,还有Node.js的环境等等,这些我一个都没学过(我目前也提不起兴趣去学)

前端这块还有很多细节敲定,到时候再说吧。说不定到时候或许可能大概有大佬可以支持下呢?不过很可能还是我自己来写,毕竟我自己能做到的事情,也没必要麻烦别人。

所以,今天先更新下austin的介绍以及Q4对austin项目的安排吧,后续等我这个Q的安排做完了,我就继续补充第零篇

站在我的角度,我认为:austin项目的业务很简单,可玩性很足,能用到的技术栈也很丰富,比较适合初学者

后面在写的时候,我会穿插些我认为项目的亮点,我的目标是:该项目会成为Java小白简历上的一个项目(不再是清一色的商城项目)

06、项目介绍


austin项目核心功能:发送消息

项目出现意义:只要公司内有发送消息的需求,都应该要有类似austin的项目,对各类消息进行统一发送处理。这有利于对功能的收拢,以及提高业务需求开发的效率

07、项目流程图


austin项目核心流程austin-api接收到发送消息请求,直接将请求进MQaustin-handler消费MQ消息后由各类消息的Handler进行发送处理

最后

自我介绍一下,小编13年上海交大毕业,曾经在小公司待过,也去过华为、OPPO等大厂,18年进入阿里一直到现在。

深知大多数Java工程师,想要提升技能,往往是自己摸索成长,自己不成体系的自学效果低效漫长且无助。

因此收集整理了一份《2024年Java开发全套学习资料》,初衷也很简单,就是希望能够帮助到想自学提升又不知道该从何学起的朋友,同时减轻大家的负担。

既有适合小白学习的零基础资料,也有适合3年以上经验的小伙伴深入学习提升的进阶课程,基本涵盖了95%以上Java开发知识点,不论你是刚入门Java开发的新手,还是希望在技术上不断提升的资深开发者,这些资料都将为你打开新的学习之门!

如果你觉得这些内容对你有帮助,需要这份全套学习资料的朋友可以戳我获取!!

由于文件比较大,这里只是将部分目录截图出来,每个节点里面都包含大厂面经、学习笔记、源码讲义、实战项目、讲解视频,并且会持续更新!
5%以上Java开发知识点,不论你是刚入门Java开发的新手,还是希望在技术上不断提升的资深开发者,这些资料都将为你打开新的学习之门!**

如果你觉得这些内容对你有帮助,需要这份全套学习资料的朋友可以戳我获取!!

由于文件比较大,这里只是将部分目录截图出来,每个节点里面都包含大厂面经、学习笔记、源码讲义、实战项目、讲解视频,并且会持续更新!

  • 10
    点赞
  • 18
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值