近三年,其实都是在做一个项目,项目是一个大型的多节点部署的项目,做了好几个版本,中间用到了很多技术和框架,

也用了一些管理工具和敏捷实践。我这里不是来说项目的,因为最近看了一些招聘信息,结合项目中用到的一些知识和

管理措施,作为一个程序员,需要去实时评估下自己当前的能力是否能跟上时代的步伐,所以,总结了下作为一个中高

Java开发人员或架构师,到底需要掌握哪些技能。

 

当然,下述所列都是自己的看法,有兴趣的参考下,没兴趣的,就当看笑话了吧。

 

 

1、对于Java基础技术体系(包括JVM、类装载机制、多线程并发、IO、网络)有一定的掌握和应用经验。

  JVM内存分配、JVM垃圾回收;

  类装载机制;

  性能优化:

  反射机制;

  多线程;

  IO/NIO; http://developer.51cto.com/art/201112/307172.htm

  网络编程;

  常用数据结构和相关算法

  

2、对面向对象的软件开发思想有清晰的认识、熟悉掌握常用的设计模式;

  设计模式:单例模式;工厂模式;代理模式;模板方法模式;责任链模式等

  

3、熟练掌握目前流行开源框架(spring/springmvc/ibatis),并且对其核心思想、实现原理有一定认知;

  开源框架:spring;

  开源框架:hibernate

  

4、熟悉Oracle、MySQL等数据库开发与设计以及缓存系统Redis或 Memcached的设计和研发;

  关系数据库:oracle

  关系数据库:PostgreSQL

  缓存系统:redis(Nosql)

  缓存系统:Memcached

  

5、熟悉底层中间件、分布式技术(包括缓存、消息系统、热部署、JMX等)

  底层中间件:

   应用服务器:Jetty(Tomcat)

   消息中间件:ActiveMQ、RabbitMQ

   事务处理中间件:

   数据访问中间件:ODBC

   工作流中间件:JBPM

  分布式技术:

                缓存系统:

             消息系统:

             Restful:

             热部署:

             JMX:

6、至少一种Java 应用服务器如tomcat

  Jetty:

  

7、精通shell编程,熟练应用awk、sed、grep、strace、tcudump、gdb等常用命令;

 
8、有大型分布式、高并发、高负载(大数据量)、高可用性系统设计开发经验

  分布式:(多节点部署)

  高并发:

  高负载(大数据量):

  高稳定:

  高可用:

  

9、对配置管理和敏捷研发模式有所了解

  配置管理工具:

   SVN:

   Github:

 
10、业务能力:

  系统升级、双机、部署、容灾、备份恢复、DFX

  

加分技术:

   脚本语言:Python

   远程调用:

   精通Internet基本协议(如TCP/IP、HTTP等)内容及相关应用

   有一定安全意识并了解常见的安全问题解决方案

   熟悉常见的一些解决方案及其原理:单点登录、分布式缓存、SOA、全文检索、消息中间件,负载均衡、连接池、

   nosql、流计算等;