`
xiaolin0199
  • 浏览: 576980 次
  • 性别: 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 机制上。需要补充的是,对性能的考虑必然要把有关的历史数据考虑进来。另请参见网站运维之道的容量规划以及其它小帖子。
好架构不是设计出来的

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

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

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

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

--EOF--

* 好的业务模式(产品) + 很好的技术 = 大赚钱
* 好的业务模式(产品) + 能用的技术 = 也赚钱
* 差的业务模式(产品) + 好的技术 = 赚吆喝(现在的SNS就差不多这样了)
* 差的业务模式(产品) + 差的技术 = 自己浪费资源

分享到:
评论

相关推荐

    QCon 2009 beijing全球企业开发大会ppt:12.Hadoop取舍之间--高性能、高流量和多数据中心互联网应用架构设计

    #### 高性能、高流量系统架构设计基本原则 在演讲中,Diane Yu和王迪首先介绍了构建高性能、高流量系统时应遵循的一些基本原则: - **设计时考虑失败**:软件不可能完全无bug,硬件也无法做到绝对可靠,因此设计之...

    低功耗设计.pdf

    自半个世纪前数字计算机的问世,IT行业见证了前所未有的性能与性价比提升,其中低功耗设计逐渐成为与性能优化同等重要的议题,尤其在电池驱动的便携式设备市场,如智能手机、笔记本电脑等领域,其重要性更为凸显。...

    MySQL性能调优与架构设计(pdf高清)

    MySQL性能调优与架构设计MySQL性能调优与架构设计MySQL性能调优与架构设计MySQL性能调优与架构设计MySQL性能调优与架构设计MySQL性能调优与架构设计MySQL性能调优与架构设计MySQL性能调优与架构设计

    低比转速离心泵设计方法.rar

    低比转速意味着泵在较低的转速下可以提供较高的扬程,适用于需要大扬程、小流量的工况,如深井抽水、高楼供水等。 离心泵的工作原理基于牛顿第二定律和伯努利方程。当泵内的叶轮旋转时,会通过离心力将流体推出,...

    低比速离心泵水力设计进展.rar

    6. 模型试验与性能测试:在初步设计完成后,进行模型试验验证其水力性能,包括流量、扬程、效率等参数,并根据测试结果进行优化调整。实际应用中还需要进行全性能曲线的测定,确保泵在各种工况下的工作性能。 7. ...

    计算机组成与体系结构(性能设计)答案完整版-第八版

    ### 计算机组成与体系结构(性能设计)答案完整版-第八版 #### 知识点概述 根据所提供的文件信息,“计算机组成与体系结构(性能设计)答案完整版-第八版”是一本针对计算机科学专业学生的学习资料,旨在帮助读者...

    c# 网络流量监测源码

    在IT领域,网络流量监测是一项重要的任务,它可以帮助开发者、系统管理员和网络安全专家了解网络活动,检测潜在的问题,如带宽滥用、攻击或性能瓶颈。本文将深入探讨使用C#进行网络流量监控的相关知识点。 首先,C#...

    网络流量监控 源码

    网络流量监控是网络管理中的重要组成部分,它可以帮助用户了解网络数据传输的情况,识别可能存在的问题,如带宽滥用、网络拥塞或者潜在的安全威胁。在本文中,我们将深入探讨网络流量监控的原理、MFC(Microsoft ...

    基于ADS的低噪声放大器设计实例(内含电路图和仿真结果图形)

    总结来说,基于ADS的低噪声放大器设计涉及到多个关键步骤,包括电路设计、参数优化、仿真验证以及性能评估。这个实例不仅展示了如何利用ADS工具进行LNA设计,同时也提供了一个实际的电路案例,为学习和研究LNA设计...

    ads2008射频电路设计与仿真实例05

    5.1.3 低噪声放大器的设计方法 5.2 LNA设计实例 5.2.1 下载并安装晶体管的库文件 5.2.2 直流分析DCTracing 5.2.3 偏置电路的设计 5.2.4 稳定性分析 5.2.5 噪声系数圆和输入匹配 5.2.6 最大增益的输出匹配 5.2.7 匹配...

    大学个人网页设计作业

    网页设计是计算机科学领域中的一个重要组成部分,特别是在当今数字化时代,网页设计能力对于个人和企业来说都是非常有价值的技能。在这个“大学个人网页设计作业”中,我们可以深入探讨一些关键的知识点,这些知识点...

    系统架构设计师教程.pdf

    系统架构设计对于确保系统的可扩展性、可维护性、性能和安全性至关重要。 #### 二、系统架构师的角色与职责 系统架构师负责设计和规划系统的整体结构,并确保系统满足业务需求和技术要求。主要职责包括但不限于: ...

    B2C网站详细设计书

    《B2C网站详细设计书》是一份深入探讨B2C电子商务网站构建的专业文档,它为开发者和设计师提供了丰富的指导和灵感。B2C(Business-to-Consumer)网站是商家直接面向消费者销售商品或服务的在线平台,其设计与功能...

    2005-2009软件设计师历年真题

     • 系统总体结构设计(总体布局、设计原则、模块结构设计、数据存储设计、系统配置方案)  • 系统详细设计(代码设计、数据库设计、用户界面设计、处理过程设计)  • 系统设计说明书  3.4 系统实施知识  • ...

    现代直流伺服控制技术及其系统设计

    在PWM系统工程设计中的问题包括功率转换电路供电电源设计、PWM开关频率的选择、电枢回路附加电感的设计原则、浪涌电流和电压抑制等。设计时需考虑这些问题,以确保系统的稳定和可靠。 PWM系统电磁兼容性设计是确保...

    数字秒表--EDA课程设计完整版(设计报告+仿真文件+硬件实现)

    而ASIC则适用于大规模生产,能提供更高的性能和更低的功耗。 在“相应截图”中,可以看到设计的仿真结果和实物运行状况,这些图像资料直观地展示了设计的成功与否,以及秒表运行的稳定性和准确性。这些图片通常会...

    切线泵与离心泵的结构和性能比较分析.rar

    在性能方面,离心泵通常提供较大的流量和扬程范围,适用于大规模的流体传输。其效率高,运行稳定,适用于连续工作场合。然而,离心泵对于流体的粘度和含固量有一定的限制,当流体性质变化较大时,可能需要调整或更换...

    计算机网络课程设计:学生公寓组网

    "计算机网络课程设计:学生公寓组网" ...整个系统的设计遵循高性能、关键业务服务质量保证、信息点可控性、先进性、可靠稳定性、安全性等原则,旨在提供一个高性能、可靠、安全的网络服务,满足学生宿舍的网络需求。

    Android网络流量监听器源代码

    7. **UI展示**: 数据的可视化是用户感知网络流量的重要途径,可以设计图表、进度条等形式展示上传、下载的速度和总量。 8. **事件触发机制**: 除了被动监听广播,还可以通过主动触发,比如在应用启动、关闭或者特定...

Global site tag (gtag.js) - Google Analytics