高并发处理方案

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

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

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

相关推荐

  • php位运算符的说明

    说明:作为了解的东西,就是对位进行操作,位说的是二进制的每个“位”,二进制共有32位。 位:由1和0构成 &:按位与 1 & 1 =>>>1 1 & 0 =>>>0 0 & 1 =>>>0 0 & 0 =&…

    2017年12月8日
    0227
  • PHP的浮点类型float, double, real

    浮点类型float, double, real有两种写法: $v1 = 1.234;   //带小数点,,就是浮点类型 $v2 = 1.234E3; //含义是:1.234乘以10的3次方,即1234,带E的形式就是浮点数 $v3 = 1234E3;//结果值是1234000,但也是一…

    2018年3月14日 PHP自学教程
    0609
  • PHP程序员的信号处理

    写给PHP程序员的信号处理教程什么是信号信号就是事件发生时,对进程的一种通知机制(也叫软件中断)。当一个进程收到信号后,内核会暂停该进程正在执行的代码,并跳转到对应的信号处理函数中,如果处理函数不中断,…

    2022年6月27日 PHP自学教程
    0130
  • PHP实现MongoDB数据库异地容灾的方法。

    随着互联网应用规模的不断扩大,服务器数量的增加,数据的安全性和可靠性越来越受到重视。而异地容灾是一种重要的手段,可以避免单点故障导致的数据丢失和应用中断。本文将介绍如何使用PHP实现MongoDB数据库异地容…

    2023年5月21日
    03
  • 关于php去掉数组中的空值。

    在PHP中,我们可以使用`array_keys()`函数获取数组的所有键,然后使用`array_diff()`函数移除指定的键,以下是一个简单的例子: <?php $array = array("a" => "apple", "b" =&…

    2024年6月19日
    02
  • 说说wamp怎么打开。

    WampServer是一个用于Windows操作系统的Web开发环境,它集成了Apache、MySQL和PHP等常用的Web开发工具,在WampServer中开启GD库,可以让我们使用PHP进行图像处理和生成动态图像,下面是开启GD库的步骤: 1. 确保你…

    2024年6月28日
    02
  • PHP直播功能开发的几个关键技术点。

    最近几年,直播行业蓬勃发展,直播平台成为了人们不可或缺的一部分,而PHP作为一种常用的Web开发语言,也被广泛应用于直播平台的开发中。本文将重点探讨PHP直播功能开发的几个关键技术点。一、音视频采集与处理直播…

    2023年5月23日
    02
  • PHP中的RPC。

    近年来,随着互联网技术的迅猛发展,分布式系统逐渐成为了互联网应用领域中不可缺少的部分。而分布式系统中的RPC技术则是实现不同进程、不同机器之间通讯的重要手段之一。其中,PHP中的RPC技术也逐渐成为了各大互联…

    2023年5月30日
    04

联系我们

QQ:951076433

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