有人私信我说,除了要掌握的20%以外还要掌握些什么知识才能游刃有余。下面说说我接触(使用)过、的东西吧。
java以分布式应用丰富的生态闻名,在分布式系统中逃不过CAP的抉择。早早了解一些分布式一致性协议paxos、raft等。学习zookeeper的原理和使用场景(metadata、分布式锁、leaderEletion... etc)
RPC框架在SOA架构中起着重要的作用,好好探究终是有好处的,在这里推荐阿里巴巴的dubbo框架,同时会netty、mina等网络库
Hadoop系列 Storm Spark 等离线\实时计算框架
ElasticSearch\SolrCloud 分布式搜索 ELK 日志相关的东西对这些比较敏感,当然在更多的场景使用ES也是有很多
消息队列 kafka\MetaQ RabbitMQ 缓存 Redis/memcached .容器tomcat/jetty web服务器NGINX/OpenResty
然后就是各种基础知识,编程语言、网络方面、数据库、数据结构和算法。不要觉得任何一项都精通了,敢说精通的能有几个。
掌握技能也就是需要时间成本和学习成本,要成为一个好的程序员不要怕学习,有学历能力需要新技术才能跟得上,想当年才学的时候struts2比springmvc高出一截,不过现在也基本没人用啦。
Java程序员一定要学好重点的技术,如下面这些
并发包:理解 ConcurrentHashMap原理,线程池,异步并发,锁。
集合类,线程类。
http请求
json,xml读写。
常用api。
前端模块javascript、css,熟悉一个前端框架。
常用框架、常见的设计模式、面向对象。
加薪必备知识点
掌握Java编程语言,包含io/nio/socket/multi threads/collection/concurrency等功能的使用;
熟练掌握jvm(sun hotspot和ibm j9)内存模型、gc垃圾回收调优等技能;
精通JVM,JMM,MVC架构,熟练使用struts2。
熟练使用spring、struts、ibatis构建应用系统。
熟练使用Servlet,jsp,freemark等前端技术。
熟练使用axis搭建基于SOAP协议的WebService服务接口。
熟练使用MAVEN构建项目工程。
熟练使用tomcat等web服务。
熟练使用mysql等关系型数据库,熟悉mysql集群搭建
熟练使用redis等NOSQL技术。
熟悉tcp、http协议。
熟悉nginx、haproxy等配置。
熟悉javascript、ajax等技术。
熟悉主流分布式文件系统FastDFS等。
熟悉JMS,可熟练使用ActiveMQ。
底层计算机理解内存管理/数据挖掘系统
可靠性和可用性如何理解
jsp和sever lap对比
数据库到界面,字符集转化
基栈
jvm优化cup高的时候如果分析和监控
java curb突出细节问题
分布式缓存文档如何分流
迁移数据库垂直分割
高并发如何处理前端高并发应用层
LB设计load balance
负载均衡
防网络攻击
数据日志事件监控后通知
数据库事务实现的底层机制
字符串空格输入的网络攻击
Quartz框架的底层原理
数据库同步中不通过数据库引擎直接读日志等方式同步数据
针对上面的内容,我精心整理了一份【Java进阶核心技术知识点】,助力成长进阶。本架构专题合集由原BAT资深架构师依据过往项目实践经验,耗时巨长、精心创作。内容非常广泛,读者老哥们可以参考一下。
JVM
Spring原理
微服务
Netty与Rpc
设计模式
数据结构与算法
由于篇幅限制,只能展示部分截图出来,需要获取这份【Java进阶核心技术知识点】的读者老哥们可以私信【学习】二字获取