`
longgangbai
  • 浏览: 7273716 次
  • 性别: Icon_minigender_1
  • 来自: 上海
社区版块
存档分类
最新评论

【转】小规模低性能低流量网站设计原则

 
阅读更多

到处都是什么大规模啊,高流量啊,高性能之类的网站架构设计,这类文章一是满足人们好奇心,但看过之后也就看过了,实际收益可能并不大;另外一个副作用是容易让人心潮澎湃,没学走先学跑,在很多条件仍不具备的情况下,过度设计、过度扩展(高德纳大爷也说过,"过早优化是万恶之源"),所以,这里反弹琵琶,讨论一下小规模低性能低流量的网站该如何搞法。

如果站点起步阶段可能就是一台机器(或是一台虚拟机,比如 JobsDigg.com ),这个时候,去关注什么数据拆分啊,负载均衡啊,都是没影子的事情。很多大站点的经验绝不能照搬,辩证的参考才是硬道理。

拥抱熟知的技术

动手构建站点的时候,不要到处去问别人该用什么,什么熟悉用什么,如果用自己不擅长的技术手段来写网站,等你写完,黄花菜可能都凉了。所以,有现成的软件组件可用,就不要自己重新发明轮子。人家说 Python 牛,但自己只懂 PHP ,那就 PHP 好了,如果熟悉 .net ?,那也不错。用烂技术不是丢人的事情,把好技术用烂才丢人。

架构层次清晰化

起步的阶段应该清楚的确定下来架构的层次。如果都搅和在一起,业务一旦扩增开来,如果原有的一堆东西拆不开就是非常痛苦的事情。

Web Server <--> (AppServer)<-->Cache(eg. Memcached)<-->DB

层次清晰化的一个体现是(以 LAMP 架构为例):即使只有一台机器,也应该起个 Memcached 的实例,效果的确非常好--一般人儿我不告诉他...不要把什么都压到 DB 上,DB 一旦 I/O 压力走到磁盘上,问题要暴露出来是很快的。没错,DB 本身也会利用自己的 Cache,但 DB 的Cache 和 Memcached 设计出发点毕竟不一样。

数据冗余? 有必要

很多人并不是数据库设计专家,如果应用要自己设计表结构什么的,基本都是临时抱佛脚,但三个范式很多人倒是记得牢,这是大多数小型 Web 站点遇到的一个头疼事儿,一个小小的应用搞了几十个表... 忘掉范式这个玩意儿! 记住,尽可能的冗余数据,你在数据层陷入的时间越多,你在产品上投入的就会越少。用户更关心的是产品的设计。

前端优化很重要

因为流量低,访客可能也不多,这时候值得注意的是页面不要太大,多数流量低的站点吃亏就在于一个页面动辄几兆(我前两天看到一个Startup的首页有4M之大,可谓惊人),用户看个页面半分钟都打不开,你说咋发展? 先把基本的条件满足,再去研究前端优化

功能增加要谨慎

不是有个 80/20 原则么? 把最重要的精力放在最能给你带来商业价值的地方。有些花里胡哨的功能带来很大的开销,反而收效甚微。记住,小站点,最有价值的是业务模式,而不是你的技术有多牛。技术是为业务服务的,不要炫技。

有些网站不停的添加功能,恰恰是把这些新功能变成了压死自己的稻草。

从开始考虑性能

这一点是可选的,但也重要。设计应用的时候在开始就应考虑 Profile 这件事情。一套应用能否在后期进行有效优化和扩展,很大的程度限制在是否有比较合适的 Profile 机制上。需要补充的是,对性能的考虑必然要把有关的历史数据考虑进来。另请参见网站运维之道的容量规划以及其它小帖子。

好架构不是设计出来的

这是最后要补充的一点。好的架构和最初的设计有关系,但最重要的是发展中的演化:

发展-->发现问题-->反馈-->解决问题(执行力)--> 改进->进化到下一阶段--新问题出现(循环)

有些站点到了某个阶段停足不前,可能卡在执行力这个地方,来自用户的反馈意见上来了之后,没有驱动力去做改进。最后也是死猪不怕开水烫了。最怕听到的就是"业务不允许"的托词,试想如果不改进业务都没了,那业务还允许么? 其实就是一层心理障碍。

这篇文章有浓重的山寨风格,所以,你不要太认真。如果在用短、平、快的方式构建某些山寨网站的话,可参考其中对你有益的点,不赞同的地方可以直接忽视掉,就没必要费力留言进行争论了。

分享到:
评论

相关推荐

    论文研究 - 对转小型冷却风扇的性能和内部流量

    为了满足需求,一些高压大流量冷却风扇采用了对转转子。 通过实验装置研究了40 mm见方的对流小型冷却风扇的性能曲线,并通过数值分析阐明了其内部流动状况。 前转子的风扇静压极低,后转子的静压显着增加。 由于...

    DB2数据库设计和最高性能原则

    DB2数据库设计和最高性能原则

    大规模网站性能优化方法-高性能网站性能优化

    大规模网站性能优化方法-高性能网站性能优化

    微小流量电磁先导阀性能测试液压控制系统设计

    设计一套微小流量电磁先导阀综合性能试验装置液压控制系统,实现对微小流量电磁先导阀单独进行液压测试,解决以往该阀必须与主阀组合测试的技术难题。可按照国家标准GB25974.3-2010《煤矿用液压支架第3部分:液压控制...

    大规模高性能分布式存储系统设计与实现

    大规模高性能分布式存储系统设计与实现

    应用于低性能单片机的拼音输入法设计与实现.pdf

    应用于低性能单片机的拼音输入法设计与实现.pdf

    抗震概念设计及抗震性能化设计

    性能化设计不神秘,大到整个工程,小到结构构件, 都有性能化设计的问题,我们的楼梯安全岛的概念及其设计原则就是抗震性能化设计。 为什么要进行抗震性能化设计 抗震性能化设计与抗震概念设计的关系 如何做好抗震...

    大流量Web系统的性能优化实践

    这是阿里工程师在某个技术会议所做的专题演讲的ppt文档,主要讲解阿里在面对大容量请求时的一些经验。感觉比较空泛,需具备一些实际经验者比较容易理解掌握,谨慎下载。

    网络性能监控与流量统计系统

    用vb编写的网络性能监控与流量统计系统,含有完整源码,能够正常运行,希望对大家有所帮助

    EMI 设计原则及电磁兼容设计原则

    EMI设计原则及电磁兼容设计原则有助于在电路板设计时候的抗干扰性能

    数据库索引设计原则.

    数据库索引设计原则是 Oracle 数据库管理系统中的一项重要技术,旨在提高数据库的查询效率和性能。以下是数据库索引设计原则的详细解释。 一、基本原则 数据库索引设计原则的基本原则是确保数据库的查询效率和性能...

    设计可扩展的接口原则

    实现拥抱变化的方式很多,设计大师们为我们总结出23种设计模式,但是在项目实践中有效地使用设计模式是个难题,因此大部分业务设计很难采用它们来实现,我们在项目中尽量采用这六大设计原则,经常使用这些原则来检验...

    一种低开销高性能的RISC-V处理器设计.pdf

    一种低开销高性能的RISC-V处理器设计 本文提出了一种低开销、高性能、顺序取指、乱序执行的RISC V处理器架构,旨在满足嵌入式应用设备对性能、功耗和灵活性的需求。RISC V处理器架构具有简洁性、一致性、可扩展性和...

    热隔离式MEMS气体流量传感器的设计及标定

    设计了一种数字输出热隔离式MEMS气体质量流量传感器,芯片加热电阻与测温电阻完全热隔离,流量值采用UART串口输出.分析了恒温差电路、上下游测温电路、HX711模数转换电路及STC 15W408AS单片机电路的设计.针对制造中...

    本科毕业论文---基于单片机的道路车流量计设计.doc

    它具有高性能、低功耗、多种外设接口等特点,能够实时处理地磁传感器的数据,并控制道路车流量计的计数。 五、PL2303 串口在道路车流量计设计中的应用 PL2303 串口是道路车流量计设计中的通信接口。它能够实时传输...

    基于MSP430单片机的气体涡轮流量计设计

    本着小型化、智能化的原则,设计中采用TI公司的高性能、微功耗MSP430F147 单片机作为控制核心,实现了气体流量的实时补偿,提高了仪表的测量精度。在外围器件选型和软件编制过程中进行低功耗设计,极大地降低了仪表...

    NetScout网络流量分析与性能管理方案介绍.doc

    NetScout 的网络流量分析和性能管理解决方案遵循以下设计原则: * 可扩展性 * 高性能 * 高可靠性 * 灵活性 * 安全性 2.3 系统组成 NetScout 的网络流量分析和性能管理解决方案由以下几个部分组成: * 系统架构 *...

Global site tag (gtag.js) - Google Analytics