爆赞,java后端开发路线。

前言 我们说 Kafka 是一个消息队列,其实更加确切的说:是 Broker 这个核心部件。为何这么说?你会发现我们可以通过控制台、 Java 代码、 C++ 代码、甚至是 Socket 向 Broker 写入消息,只要我们遵从了 Kafka 写入消息的协议,就可以将消息发送到 Kafka 队列中。

用专业一点的话术来说,Kafka 定义了一个应用层的网络协议,只要我们基于传输层构造出符合这个协议的数据,就是合法的 Kafka 消息。

所以说我们写入 Kafka 消息的只是一个生产者的客户端,他的形式多种多样,有 Java ,Python,C++ 等多种实现,那么我们每次发消息难道还需要自己去实现这套发送消息的协议么?显然 Kafka 官方已经考虑到这个问题了,为了给我们提供 开箱即用 的消息队列,官方已经帮我们写好了各种语言的优质生产者实现,例如我们今天要讨论的 Java 版本的实现。

第1大技能:程序设计和开发 数据结构和算法:常用数据结构,排序,检索等

面向对象编程、设计模式,掌握建模语言和建模工具:UML、MVC编程思想

高质量编码能力:重用性,低耦合,可扩展性,高性能,可维护性,安全性高

集成开发,版本控制,构建等工具:eclipse, svn, maven 等

脚本语言:Perl,PHP, Ruby, Python, Groovy等

第2大技能:Java开发 Java语言基础:异常处理,泛型,reflection,annotation; Java基本类库:io, util

Java高级特性和类库:class loader,bytecode,nio, juc 等

Java多线程编程

Java网络与服务器编程, TCP/IP协议

开源产品和技术

JVM原理和调优

第3大技能:Web开发 DNS,HTTP, Cookie, Mail,FTP, Proxy等协议

Java Servlet API, Velocity/JSP等模板引擎

主流Web开发框架:Spring Framework,WebX,Struts等

Web服务器部署和配置:Apache,Tomcat,JBoss,Jetty等

客户端代码编写:HTML/CSS/JS

Web开发调试工具:Firebug等

第4大技能:数据库开发

  1. 数据库设计原则
  2. 数据库SQL和NOSQL的选型
  3. 常见的:mysql和oracle的掌握
  4. 常用的nosql的掌握:Redis、Memchache、MongoDb。
  5. 常见的数据库性能优化方案等

第5大技能:java开发框架与工具

  1. 常用的开发系统:spring、redis、memcached、activeMQ等的掌握
  2. 常用的web服务器:tomcat 、jboss等
  3. 构建工具:maven等
  4. 第6大技能:分布式架构设计与经验 分层的应用框架设计思想:SOA,事件驱动等 分布式系统原理:CAP,最终一致性,幂等操作等 大型网络应用结构:消息中间件,缓存,负载均衡,集群技术,数据同步 高可用,可容灾分布式系统设计能力 大容量数据存储和检索系统设计能力:数据库分区,NoSQL,搜索引擎等 以上就是阿里P8架构师的技能,以上技能的要求重点都是精通
  5. 0-1年:夯实基础 1.Java基础(Java异常分类及处理+Java反射+Java注解+Java内部类+Java泛型+Java序列化+Java复制) 2.并发编程(线程池+生命周期+锁+阻塞队列+CAS等) 3.JVM基础(线程+JVM内存区域+JVM运行时内存+垃圾回收与算法+GC+IO/NIO+类加载) 4.设计模式(23种设计模式) 5.SQL基础与优化 6.HTTP/TCP协议 7.算法与数据结构
  6. Java算法(二分查找+排序算法+回溯算法等)
  7. 一致性算法(Paxos+Zab+Raft+NWR+Gossip+一致性Hash)
  8. 8.Redis 1-3年:合格的程序员 1.JVM基础调优 2.常见框架源码(Spring+SpringMVC+Mybatis) 3.消息中间件(MQ+Kafka) 4.微服务 5.Netty 4-5年:提升技术广度与深度 1.性能调优 2.微服务 3.分布式场景问题 4.项目实战
  9. 高仿小米商城项目
  10. Alibaba订单管理系统项目
    API监控系统

当然除了以上的必备技能,最重要的就是面试了,以下是总结出来最全架构师题目,包含:Java基础-中级-高级、开源框架、性能调优、微服务、分布式架构、数据库、高并发、数据结构与算法、网络等。

经验分享 程序员 微信小程序 职场和发展