socket多线程 ok
netty底层nio,aio ok
高并发 ok
heh ok
事务控制多库多表操作 ok
spring cloud
soa ignore
jvm调优 ok
类加载机制 ok
gc机制 ok
支付流程和注意点
spring的加载机制 ok
tomcat加载机制 ignore
做过的项目 important
线程调度;多线程相关:多线程并发用到那哪些?线程数据共享;synchronize 用法,原理 ?死锁的原因,现场写了一下;(重点)
首先要了解高并发的的瓶颈在哪里?
1、可能是服务器网络带宽不够
增加网络带宽,添加CDN
2.可能web线程连接数不够
负载均衡,前置代理服务器Nginx,静态资源分离到另外一个服务器
3.可能数据库连接查询上不去。
优化数据库查询语句,explain之后,找出耗时多的点,添加索引。
数据库查询优化,读写分离,分表等等
4.使用缓存,比较固定长时间少更新的solr,短期的也可以用redis,memcache
最后复制一些在高并发下面需要常常需要处理的内容:
统计的功能尽量做缓存,或按每天一统计或定时统计相关报表,避免需要时进行统计的功能。
能使用静态页面的地方尽量使用,减少容器的解析(尽量将动态内容生成静态html来显示)。
解决以上问题后,使用服务器集群来解决单台的瓶颈问题。