在阿里巴巴内部,各种各样的项目数不胜数,那么他们是怎样去完成每个项目的呢,阿里巴巴又是在使用哪些牛逼的技术呢?
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程序员最重要的技能之一,也是最难掌握的一种技能。它要求编程者对计算机最底层的运作原理有深刻的理解,同时要求编程者逻辑清晰、思维缜密,这样才能写出高效、安全、可靠的多线程并发程序。
性能优化
性能一直是让程序员比较头疼的问题。当系统架构变得复杂而庞大之后,性能方面就会下降,特别是阿里巴巴这样的一线互联网公司最为注重,因此想进入阿里,性能优化一定是要去深入学习与理解的一环。(注意:自己的简历上一定不要写精通xxxx,要不然面试官会怼死你。)