近三年,其实都是在做一个项目,项目是一个大型的多节点部署的项目,做了好几个版本,中间用到了很多技术和框架, 也用了一些管理工具和敏捷实践。我这里不是来说项目的,因为最近看了一些招聘信息,结合项目中用到的一些知识和 管理措施,作为一个程序员,需要去实时评估下自己当前的能力是否能跟上时代的步伐,所以,总结了下作为一个中高
当然,下述所列都是自己的看法,有兴趣的参考下,没兴趣的,就当看笑话了吧。
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等常用命令; 分布式:(多节点部署) 高并发: 高负载(大数据量): 高稳定: 高可用:
9、对配置管理和敏捷研发模式有所了解 配置管理工具: SVN: Github: 系统升级、双机、部署、容灾、备份恢复、DFX
加分技术: 脚本语言:Python 远程调用: 精通Internet基本协议(如TCP/IP、HTTP等)内容及相关应用 有一定安全意识并了解常见的安全问题解决方案 熟悉常见的一些解决方案及其原理:单点登录、分布式缓存、SOA、全文检索、消息中间件,负载均衡、连接池、 nosql、流计算等; 原文地址:http://blog.csdn.net/gokeibi/article/details/40958303 |
|