微信号:w3tech

介绍:大规模分布式系统架构介绍;大规模互联网系统架构介绍及知识分享;互联网前端架构介绍;PHP,Javascript,Erlang,C/C++等编程语言在大规模互联网系统开发中的应用实践经验技巧;

性能优化:一个全栈问题

2015-07-22 08:11 分布式系统架构知识

Ronald Bradford是一名有26年行业经验的IT专家,他撰写了Effective MySQL系列书籍并已被翻译为中文。近日,他在个人博客上发表了一篇探讨性能优化的文章。他认为,性能优化是一个全栈问题,提高Web系统的性能需要了解整个技术栈的运转和交互。他列举了一些快速提升系统性能的常用技巧,包括:

  • 使用CDN资源;

  • 压缩内容;

  • 减少请求次数(Web、缓存、数据库);

  • 异步管理;

  • 优化SQL语句;

  • 数据库服务器使用固态硬盘;

  • 更新软件版本;

  • 增加服务器;

  • 正确配置软件。

Ronald指出,性能优化需要制定详细的优化计划,确定每一部分的优化目标,并进行相应的测试验证。如果系统任何一部分未能达到预期的优化效果,那么就无法实现整个系统的性能提升。比如,一个系统的MySQL数据库饱和了,InnoDB并发事务数达到上限。在旧版本中,这是一个不可配置的参数。因此,升级是一种简单直接的优化方法。但同时,工程团队升级了PHP应用程序框架(如Slim和Twig),导致应用程序响应时间增加。结果,虽然系统负载增加了,但整体性能却未能得到提升。

因此,Ronald指出,为了实现系统整体性能的优化,需要重点从以下几个方面考虑问题:

  • 了解CPU饱和度;

  • 检测和缓解网络延迟;

  • 了解虚拟云实例的虚拟模式选项;

  • 了解网络协议栈,利用好不同的主机操作系统;

  • 模拟生产负载并不容易;

  • 性能分析,分析,再分析;

  • 工具有误导性,需要了解不同监控工具的工作原理;

  • 全栈优化是一个迭代过程;

  • 了解如何优化技术栈的每一部分;

  • 不是每项优化都能达到预期效果;

  • 了解什么时候停止优化及优先优化哪一部分。

免责声明:本号所载内容来源于互联网等公开渠道,我们对文中观点保持中立,仅供参考、交流之目的。转载的稿件版权归原作者或机构所有,如有侵权,请联系删除。

 
分布式系统架构知识 更多文章 软件架构定义 CAP理论十二年回顾:"规则"变了 谈谈微信红包海量运营--发10亿个红包难在哪里? 新浪微博技术架构 架构师必知的配置Nginx+PHP的正确方法
猜您喜欢 这里有未来“互联网+”的十大趋势,客官你看可还靠谱? Android样式的开发:layer-list篇 魔都,3年,程序员到CTO 2016十家公司前端面试小记 如何创建用户模型:问卷调查与数据分析