java高并发的解决方案.docxVIP

  1. 1、原创力文档(book118)网站文档一经付费(服务费),不意味着购买了该文档的版权,仅供个人/单位学习、研究之用,不得用于商业用途,未经授权,严禁复制、发行、汇编、翻译或者网络传播等,侵权必究。。
  2. 2、本站所有内容均由合作方或网友上传,本站不对文档的完整性、权威性及其观点立场正确性做任何保证或承诺!文档内容仅供研究参考,付费前请自行鉴别。如您付费,意味着您自己接受本站规则且自行承担风险,本站不退款、不进行额外附加服务;查看《如何避免下载的几个坑》。如果您已付费下载过本站文档,您可以点击 这里二次下载
  3. 3、如文档侵犯商业秘密、侵犯著作权、侵犯人身权等,请点击“版权申诉”(推荐),也可以打举报电话:400-050-0827(电话支持时间:9:00-18:30)。
  4. 4、该文档为VIP文档,如果想要下载,成为VIP会员后,下载免费。
  5. 5、成为VIP后,下载本文档将扣除1次下载权益。下载后,不支持退款、换文档。如有疑问请联系我们
  6. 6、成为VIP后,您将拥有八大权益,权益包括:VIP文档下载权益、阅读免打扰、文档格式转换、高级专利检索、专属身份标志、高级客服、多端互通、版权登记。
  7. 7、VIP文档为合作方或网友上传,每下载1次, 网站将根据用户上传文档的质量评分、类型等,对文档贡献者给予高额补贴、流量扶持。如果你也想贡献VIP文档。上传文档
查看更多
java高并发的解决方案

影片中,记录了中国桥、中国路、中国车、中国港、中国网,一个个非凡的超级工程,展示了人类历史上最大的射电望远镜FAST、全球最大的海上钻井平台“蓝鲸2号”、磁悬浮列车研发、5G技术等引领人们走向新时代的里程碑般的科研成果,介绍了中国在精准扶贫、生态文明建设、医疗保障、国家安全等各方面取得的卓越成就,展现国人追寻“中国梦”途中不畏艰险、开拓进取的精神形象。   观影过程中,所有人都聚精会神,影片中的每一个情节和画面都让党员们感到无比的震撼,民族自豪感也油然而生。观影结束后,大家深受感动,都觉得“作为一个中国人,我自豪我骄傲!”纷纷表示在今后的工作中要撸起袖子加油干,助力祖国和谐社会的发展! 影片中,记录了中国桥、中国路、中国车、中国港、中国网,一个个非凡的超级工程,展示了人类历史上最大的射电望远镜FAST、全球最大的海上钻井平台“蓝鲸2号”、磁悬浮列车研发、5G技术等引领人们走向新时代的里程碑般的科研成果,介绍了中国在精准扶贫、生态文明建设、医疗保障、国家安全等各方面取得的卓越成就,展现国人追寻“中国梦”途中不畏艰险、开拓进取的精神形象。   观影过程中,所有人都聚精会神,影片中的每一个情节和画面都让党员们感到无比的震撼,民族自豪感也油然而生。观影结束后,大家深受感动,都觉得“作为一个中国人,我自豪我骄傲!”纷纷表示在今后的工作中要撸起袖子加油干,助力祖国和谐社会的发展! java高并发的解决方案   对于我们开发的网站,如果网站的访问量非常大的话,那么我们就需要考虑相关的并发访问问题了。而并发问题是绝大部分的程序员头疼的问题!下面是本人分享的,欢迎大家阅读!   【java高并发的解决方案】  一般来说MySQL是最常用的,可能最初是一个mysql主机,当数据增加到100万以上,那么,MySQL的效能急剧下降。常用的优化措施是M-S(主-从)方式进行同步复制,将查询和操作和分别在不同的服务器上进行操作。我推荐的是M-M-Slaves方式,2个主Mysql,多个Slaves,需要注意的是,虽然有2个Master,但是同时只有1个是Active,我们可以在一定时候切换。之所以用2个M??是保证M不会又成为系统的SPOF。   Slaves可以进一步负载均衡,可以结合LVS,从而将select操作适当的平衡到不同的slaves上。   以上架构可以抗衡到一定量的负载,但是随着用户进一步增加,你的用户表数据超过1千万,这时那个M变成了SPOF。你不能任意扩充Slaves,否则复制同步的开销将直线上升,怎么办?我的方法是表分区,从业务层面上进行分区。最简单的,以用户数据为例。根据一定的切分方式,比如id,切分到不同的数据库集群去。   全局数据库用于meta数据的查询。缺点是每次查询,会增加一次,比如你要查一个用户nightsailer,你首先要到全局数据库群找到nightsailer对应的cluster id,然后再到指定的cluster找到nightsailer的实际数据。每个cluster可以用m-m方式,或者m-m-slaves方式。这是一个可以扩展的结构,随着负载的增加,你可以简单的增加新的mysql cluster进去。   网站HTML静态化解决方案   当一个Servlet资源请求到达WEB服务器之后我们会填充指定的JSP页面来响应请求:   HTTP请求---Web服务器---Servlet--业务逻辑处理--访问数据--填充JSP--响应请求   HTML静态化之后:   HTTP请求---Web服务器---Servlet--HTML--响应请求   缓存、负载均衡、存储、队列   1.缓存是另一个大问题,我一般用memcached来做缓存集群,一般来说部署10台左右就差不多(10g内存池)。需要注意一点,千万不能用使用   swap,最好关闭linux的swap。   2.负载均衡/加速。可能上面说缓存的时候,有人第一想的是页面静态化,所谓的静态html,我认为这是常识,不属于要点了。页面的静态化随之带来的是静态服务的负载均衡和加速。我认为Lighttped+Squid是最好的方式了。   LVS lighttped====squid(s) ====lighttpd   上面是我经常用的。注意,我没有用apache,除非特定的需求,否则我不部署apache,因为我一般用php-fastcgi配合lighttpd,性能比apache+mod_php要强很多。   squid的使用可以解决文件的同步等等问题,但是需要注意,你要很好的监控缓存的命中率,尽可能的提高的90%以上。   squid和lighttped也有很多的话题要讨论,这里不赘述。   3.存储。也是一个大问题,一种是小文件的存储,比如图片这类。另一种是

文档评论(0)

2017meng + 关注
实名认证
文档贡献者

该用户很懒,什么也没介绍

1亿VIP精品文档

相关文档