高并发处理方案

时常看到高并发的问题,但高并发其实是最不需要考虑的东西。为何,他虚无缥缈,很少有网站真的需要这些东西,而且其中很多技术,其实你已经在用了。有这个意识就够了,不需要时刻盯着这个问题。只有很少的网站真的能达到高并发。

简单做一个归纳,从低成本、高性能和高扩张性的角度来说有如下处理方案:

1、HTML静态化

2、图片服务器分离

3、数据库集群和库表散列

4、缓存

5、镜像

6、负载均衡;一个典型的使用负载均衡的策略就是,在软件或者硬件四层交换的基础上搭建squid集群,这种思路在很多大型网站包括搜索引擎上被采用,这样的架构低成本、高性能还有很强的扩张性,随时往架构里面增减节点都非常容易。

下面也是一个牛人所做的总结,跟上面部分相同。

高并发时,性能瓶颈及当前常用的应对措施

1.数据库瓶颈。Mysql并发链接100

2.apache 并发链接1500

3.程序执行效率

1.有数据库瓶颈时,当前处理方案无外乎 主从,集群。增加cache(memcached).

如:手机之家新系统介绍及架构分享(http://www.slideshare.net/Fenng/ss-1218991?from=ss_embed)

就是在cache层做优化

又拍网架构(http://www.bopor.com/?p=652)

是以增加数据库,分表分库的方法解决。

Sina增加了mq(消息队列)来分发数据。

还有风站用了key-value的数据库。其实这可以理解成一个持久化的缓存。

2.apache瓶颈。

增加服务器。负载均衡。如sina的F5

由于进程数的限制。会把一些基本不变的代码挪出来放到单独的服务器。如css/js/图片。

国内成功的案例是tom的cdn

又如nginx的横空出世和squid的反向代理都是基于这个原因出来的。

3.php的执行效率。原因有多个。

1).本身的效率低。

解决的成功案例是Zend Optimizer 和 facebooke的hiphop

Taobao是把php代码编译成模块解决效率问题。

2). 数据库查询效率问题。如可能有order by ,group by 等Sql数据问题。

这个其实应该归结到数据库设计问题。

解决的办法是建立正确的索引。增加memcache.。

对like表 用专用的sphinx.和lucence 等搜索服务。

程序员都应该会用explain对sql语句作分析。

本文来自投稿,不代表重蔚自留地立场,如若转载,请注明出处https://www.cwhello.com/3866.html

如有侵犯您的合法权益请发邮件951076433@qq.com联系删除

(0)
重蔚的头像重蔚管理团队
上一篇 2017年11月25日 09:56
下一篇 2017年11月27日 13:28

相关推荐

  • PHP8中的数组函数:array_intersect_assoc()的多种操作示例。

    PHP语言作为一种广泛应用于Web开发和服务器端脚本编程的语言,其强大的数组函数支持是其优秀性能的重要组成部分之一。在PHP8中,新的数组函数array_intersect_assoc()被引入,它在操作关联数组时具有更高效的性能和…

    2023年5月21日
    00
  • PHP入门指南:PHP和Shell。

    PHP入门指南:PHP和Shell随着互联网的发展,PHP语言逐渐成为开源社区中最受欢迎的服务器端脚本语言之一。它结合了C、Java和Perl等编程语言的特点,具有简洁、高效、易于学习等特点,被广泛应用于网站开发、应用程序…

    2023年5月23日
    00
  • PHP中使用Redis实现分布式锁升级版。

    随着Web应用的发展,分布式架构已经成为了越来越多应用的标配。但是,在分布式架构中,如何保证多个应用同时访问同一资源的互斥性,保证数据的一致性,就成为了每个开发人员需要面对的问题。分布式锁就是一种保证互…

    2023年5月21日
    03
  • 使用PHP和MySQL进行数据备份的最佳实践。

    随着企业信息化水平的不断提高,数据备份已经成为了每个企业必须重视的问题。在备份数据的过程中,使用PHP和MySQL进行数据备份已经成为了备受推崇的最佳实践。PHP是一种开源服务器端脚本语言,其拥有简单易学、灵活…

    2023年5月28日
    01
  • 如何在PHP中实现社交网站。

    随着互联网的普及和社交化趋势的加强,社交网站成为了人们日常生活中不可或缺的一部分。在这个领域中,PHP是最流行的开发语言之一。本文将介绍如何使用PHP来实现一个基本的社交网站。1.设计数据库架构在开始编写代…

    2023年5月22日
    01
  • 通过php对微信动态传递参数的操作

    上篇文章https://www.cwhello.com/4585.html我们说到获取到微信分享这个动作。如果我们想动态传递参数怎么办?也就是说当页面信息wx.config配置好后我们突然又想重新赋值给$title等变量信息怎么办? 我们可以这样讲…

    2018年3月9日
    0218
  • PHP微信分享功能开发(附代码)

    有时候当一个项目或工程需要微信端分享之后做一系列事件那么我们就需要获取到微信分享这个动作,也就是说我们已经知道了当前这个东西已经被分享了 ,那么走微信默认的分享显然是不行的我们需要自己动手来配置微信分…

    2018年3月9日
    0245
  • 关于php 返回。

    在Web开发中,PHP是一种广泛使用的服务器端脚本语言,用于处理动态内容和与数据库交互,HTML是一种标记语言,用于创建网页的结构,在许多情况下,我们需要将PHP生成的数据格式化为HTML,以便在网页上显示,本教程将…

    2024年6月24日
    01

联系我们

QQ:951076433

在线咨询:点击这里给我发消息邮件:951076433@qq.com工作时间:周一至周五,9:30-18:30,节假日休息