专栏名称: 高效运维
高效运维公众号由萧田国及朋友们维护,经常发布各种广为传播的优秀原创技术文章,关注运维转型,陪伴您的运维职业生涯,一起愉快滴发展。
目录
相关文章推荐
运维  ·  阿里云核心域名被劫持 ·  6 小时前  
51好读  ›  专栏  ›  高效运维

​Web 服务器性能与站点访问性能优化(好文推荐)

高效运维  · 公众号  · 运维  · 2017-10-13 07:10

正文

请到「今天看啥」查看全文


反映到我们进行性能优化,可以入手的角度就有:

  1. 增加带宽,包括服务器和客户端两边的 Internet 连接带宽;

  2. 加快动态内容的处理性能;

  3. 尽可能多地使用静态内容,这样 Web 服务器就可以无需请求应用服务器,直接将 Web 内容发给浏览器端,这里可以入手的方案又有:

  • 动态内容缓存

  • 动态内容静态化

  • 多台服务器负载均衡同时处理大量的并发访问;

  • 提升服务器磁盘访问性能,也即通常所说的 I/O 性能;

  • 减少网页中的 HTTP 请求数;

  • 更换更好性能的 Web 服务器;

  • 合理部署服务器,在离客户端更近的地方部署服务器,已经证明可以明显地提升访问性能。

  • 性能优化实践

    经过前面小节的简要分析,我相信你对优化 Web 服务器有一定的思路了,你可以从硬件层面、软件层面、Web 代码三个层面去优化。

    下面我们结合一个具体的实例来实践一回,本文所举例是一个小型的 Web 站点,部分数据系假设,如有类同,纯属巧合,仅起抛砖引玉之用。在实际工作中,如果碰到大站点,你可以参考此处的分析,修改优化方案。

    1. 站点简介

    一个社区论坛站点,采用 Discuz! 论坛程序构建,该程序采用主流的 PHP + MySQL 组成。

    网站目前有近 5 万注册用户,绝大多数是国内的用户,活跃用户数在一半左右,每天平均 PV 在 15~20 万,独立访问 IP 数在 8000 左右。

    2. Web 服务器性能优化需求

    网站现部署在国外的服务器,租用虚拟主机来运营,因为访问量比较大,所以经常会收到虚拟主机服务商的流量很大的通知,要求控制下访问量。

    另外,虚拟主机的服务器在美国,没有在国内租用虚拟主机的原因是国内网站在备案方面非常繁琐,在网站一开始运营时数据量和访问量都比较小,所以对性能要求不高,数据量小,所以服务器在查询处理数据时速度比较快,也让人感觉访问速度不慢,现在随着数据量和访问量的不断上升,访问速度已明显下降,到了需要改善访问性能的时候了。

    基于目前该社区网站的情况,提出的优化需求是,国内访问速度需要提升一倍,目前首页加载时间需要 40 秒左右,希望优化后能在 20 秒以内将首页加载完成。

    另外提出网站数据能够每天自动备份一次,备份数据保留一个月的,以便随时恢复。

    上述两点需求,其中第一条才是性能优化需求,第二条是额外的需求了。

    3. 性能优化方案

    根据其网站的现状和优化需求,结合自己的经验,加上谷歌的搜索,同时与网站主不断确认沟通,最终得到以下性能优化方案:

    由虚拟主机部署改为独立服务器部署

    虚拟主机受限比较多,无法自己自定义配置 Web 服务器,无法配置 PHP 动态缓存,而且独立服务器可以独享内存、处理器资源,不再受虚拟主机商对每个虚拟主机用户的内存和处理器资源占用限制。处理器资源和内存资源,对接受更多并发访问有直接性能提升效果。

    独立服务器,我们选用 Linode 2048 型号,2G 内存,4 核处理器(Linode 所有 VPS 都是四核处理器),80G 硬盘空间,800G 网络流量。

    由 Windows 操作系统改为 Linux 操作系统

    网站使用的是 PHP + MySQL 程序,PHP 在 Windows 下的性能,受限于 IIS 需要通过 ISAPI 形式调用 PHP,所以性能不如 Linux 下 Apache 直接通过 PHP 模块解释 PHP,更不如 Nginx 与 PHP-FPM 的性能,既然使用了独立服务器,操作系统也可以自己确定,Linux 系统我们选用了熟悉的 Ubuntu Linux Server 10.04(一年前还没有 12.04),^-^。

    Web 服务器采用 Nginx,而不使用 Apache

    选用 Nginx 而不用 Apache 的原因非常直接和干脆,因为站点里有很多静态的附件文件,在处理静态内容上,Nginx 性能是 Apache 的差不多 10 倍。







    请到「今天看啥」查看全文