到处都是什么大规模啊,高流量啊,高性能之类的网站架构设计,这类文章一是满足人们好奇心,但看过之后也就看过了,实际收益可能并不大;另外一个副作用是容易让人心潮澎湃,没学走先学跑,在很多条件仍不具备的情况下,过度设计、过度扩展(高德纳大爷也说过,"过早优化是万恶之源"),所以,这里反弹琵琶,讨论一下小规模、低性能、低流量的网站该如何搞法。如果站点起步阶段可能就是一台机器(或是一台虚拟机,比如 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就差不多这样了)
* 差的业务模式(产品) + 差的技术 = 自己浪费资源
分享到:
相关推荐
高压大流量小型冷却风扇用于数据中心的服务器,由于服务器发热量的增加,强烈要求提高其性能。 为了满足需求,一些高压大流量冷却风扇采用了对转转子。 通过实验装置研究了40 mm见方的对流小型冷却风扇的性能曲线,...
本着小型化、智能化的原则,设计中采用TI公司的高性能、微功耗MSP430F147 单片机作为控制核心,实现了气体流量的实时补偿,提高了仪表的测量精度。在外围器件选型和软件编制过程中进行低功耗设计,极大地降低了仪表...
MySQL性能调优与架构设计MySQL性能调优与架构设计MySQL性能调优与架构设计MySQL性能调优与架构设计MySQL性能调优与架构设计MySQL性能调优与架构设计MySQL性能调优与架构设计MySQL性能调优与架构设计
6. 模型试验与性能测试:在初步设计完成后,进行模型试验验证其水力性能,包括流量、扬程、效率等参数,并根据测试结果进行优化调整。实际应用中还需要进行全性能曲线的测定,确保泵在各种工况下的工作性能。 7. ...
本文介绍了如何设计一个5阶LC低通滤波器,并通过仿真和实测来验证其性能。 在设计LC低通滤波器时,首先需要确定截止频率,即信号能够有效通过的最高频率。本例中的截止频率设置为2.5GHz,目的是为了抑制信号中的二...
标题提到的“内部包含低噪声放大器电路设计所需的atf54143模型”,指的是ATF54143这款高性能的硅锗(SiGe)双极型晶体管,常用于射频前端的LNA设计。ATF54143以其低噪声系数、高增益和宽工作频率范围而受到工程师们...
5. 民用建筑室外消火栓设计流量的确定:民用建筑室外消火栓设计流量的确定是指根据建筑的用途、规模和其他因素来确定消防给水系统的设计流量。 6. 单座建筑界定原则示意:单座建筑界定原则示意是指根据建筑的规模和...
【说明】写明网络设计原则、技术要求、产品选型、拓扑结构、基本部件与配件、传输介质、接口情况、通信协议、约束条件、结构化综合布线方案等。 画出网络结构图。图中应标出各类服务器与客户机、网管机、路由器、...
在IT领域,网络流量监测是一项重要的任务,它可以帮助开发者、系统管理员和网络安全专家了解网络活动,检测潜在的问题,如带宽滥用、攻击或性能瓶颈。本文将深入探讨使用C#进行网络流量监控的相关知识点。 首先,C#...
大规模C++程序设计是一项复杂且具有挑战性的任务,它要求程序员不仅要有扎实的逻辑设计能力,还要对物理设计概念有深入的理解。本书《大规模C++程序设计》为软件开发人员提供了这方面的权威知识,尤其专注于C++编程...
负载均衡技术是现代网络架构中用于提高网站性能和可靠性的关键技术之一。通过分散单个服务器的请求负载,负载均衡能够优化资源使用、最大化吞吐量、减少响应时间,并确保重要的应用不会因为过载而崩溃。在本文中,...
《计算机组织与体系结构-性能设计答案(全)第七版》是针对计算机科学教育领域的一份重要参考资料,它详尽地解答了计算机组织与体系结构课程中的习题,旨在帮助学习者深入理解计算机硬件和软件如何协同工作以实现...
这个源代码可以帮助开发者理解和实现网络流量的实时监控,这对于网络性能优化、带宽管理、网络安全以及应用性能分析等场景非常有用。 在开发这样的系统时,通常会涉及以下关键知识点: 1. **套接字编程**:网络...
本期项目设计方案是对项目的详细设计,包括建设目标、规模与内容、标准规范建设内容、信息资源规划和数据库设计、应用支撑系统设计、应用系统设计、数据处理和存储系统设计、终端系统及接口设计、网络系统设计、安全...
设计遵循模块化、低耦合、高内聚的原则,以实现系统的易理解、易扩展和易维护。 2.2.2 可扩展性与可维护性 系统设计应具备良好的可扩展性,允许添加新功能或升级现有功能,同时考虑代码和架构的可维护性,便于未来...
总结来说,基于ADS的低噪声放大器设计涉及到多个关键步骤,包括电路设计、参数优化、仿真验证以及性能评估。这个实例不仅展示了如何利用ADS工具进行LNA设计,同时也提供了一个实际的电路案例,为学习和研究LNA设计...
在嵌入式系统的设计和开发中,使用了32位的ARM处理器和嵌入式Linux操作系统,构建了高性能的嵌入式系统开发平台,从而提高了电磁流量计的性能和功能。 在本资源摘要信息中,我们讨论了电磁流量计的设计和实现,包括...
3. 高性能低成本:系统设计要点之三是高性能低成本,通过使用EC降低流量、数据智能路由、ReadWrite应用场景等机制,提高系统的性能和降低成本。 应用场景 1. 三中心容灾效果:系统可以应用于三中心容灾效果,提供...