`
hepx
  • 浏览: 151805 次
  • 性别: Icon_minigender_1
  • 来自: 深圳
社区版块
存档分类
最新评论

【转载】百万级访问网站前期的技术准备(上)

    博客分类:
  • web
阅读更多

 

开了自己域名的博客,第一篇就得来个重磅一点的才对得起这4美金的域名。作为一个技术从业者十年,逛了十年发现有些知识东一榔头西一棒槌的得满世界看个遍才整理出个头绪,那咱就系统点的从头一步一步的说,一个从日几千访问的小小网站,到日访问一两百万的小网站,怎么才能让它平滑的度过这个阶段,别在技术上出现先天不足,写给一些技术人员,也写给不懂技术的创业者。

对互联网有了解的人都有自己的想法,有人就把想法付诸实现,做个网站然后开始运营。其实从纯网站技术上来说,因为开源模式的发展,现在建一个小网站已经很简单也很便宜。当访问量到达一定数量级的时候成本就开始飙升了,问题也开始显现了。因为带宽的增加、硬件的扩展、人员的扩张所带来的成本提高是显而易见的,而还有相当大的一部分成本是因为代码重构、架构重构,甚至底层开发语言更换引起的,最惨的就是数据丢失,辛辛苦苦好几年,一夜回到创业前。

减少成本就是增加利润。很多事情,我们在一开始就可以避免,先打好基础,往后可以省很多精力,少操很多心。

假设你是一个参与创业的技术人员,当前一穷二白,什么都要自己做,自己出钱,初期几十万的资金,做一个应用不是特别复杂的网站,那么就要注意以下几点:

一、开发语言

一般来说,技术人员(程序员)创业都是根据自己技术背景选择自己最熟悉的语言,不过考虑到不可能永远是您一个人写程序,这点还得仔细想想。无论用什么语言,最终代码质量是看管理,所以我们还是从纯语言层面来说实际一点。现在流行的javaphp.netpythonruby都有自己的优劣,python和ruby,现在人员还是相对难招一些,性能优化也会费些力气,.net平台买不起windows server。java、php用的还是最多。对于初期,应用几乎都是靠前端支撑的网站来说,php的优势稍大一些,入门简单、设计模式简单、写起来快、性能足够等,不过不注重设计模式也是它的劣势,容易变得松散,隐藏bug稍多、难以维护。java的优势在于整套管理流程已经有很多成熟工具来辅助,强类型也能避免一些弱智BUG,大多数JAVA程序员比较注重设计模式,别管实不实际,代码格式看起来还是不错的。这也是个劣势,初学者可能太注重模式而很难解决实际需求。

前端不只是html、css这类。整个负责跟用户交互的部分都是前端,包括处理程序。这类程序还是建议用php,主要原因就是开发迅速、从业人员广泛。至于后端例如行为分析、银行接口、异步消息处理等,随便用什么程序,那个只能是根据不同业务需求来选择不同语言了。

二、代码版本管理

如果开发人员之间的网络速度差不多,就SVN;比较分散例如跨国,就hg。大多数人还是svn的.

假设选了svn,那么有几点考虑。一是采用什么树结构。初期可能只有一条主干,往后就需要建立分支,例如一条开发分支,一条上线分支,再往后,可能要每个小组一个分支。建议一开始人少时选择两条分支,开发和线上,每个功能本地测试无误后提交到开发分支,最后统一测试,可以上线时合并到上线分支。如果喜欢把svn当做移动硬盘用,写一点就commit一次也无所谓,就是合并的时候头大一些,这些人可以自己建个分支甚至建立个本地代码仓库,随便往自己的分支提交,测试完毕后再提交到开发分支上。

部署,可以手工部署也可以自动部署。手工部署相对简单,一般是直接在服务器上svn update,或者找个新目录svn checkout,再把web root给ln -s过去。应用越复杂,部署越复杂,没有什么统一标准,只要别再用ftp上传那种形式就好,一是上传时文件引用不一致错误率增加,二是很容易出现开发人员的版本跟线上版本不一致,导致本来想改个错字结果变成回滚的杯具。如果有多台服务器还是建议自动部署,更换代码的机器从当前服务池中临时撤出,更新完毕后再重新加入。

不管项目多小,养成使用版本管理的好习惯,最起码还可以当做你的备份,我的http://zhiyi.us 虽然就是一个wordpress,可还是svn了,只改动一两句css那也是劳动成果。

三、服务器硬件

别羡慕大客户和有钱人,看看机房散户区,一台服务器孤独的支撑的网站数不清。如果资金稍微充足,建议至少三台的标准配置,分别用作web处理、数据库、备份。web服务器至少要8G内存,双sata raid1,如果经济稍微宽松,或静态文件或图片多,则15k sas raid1+0。数据库至少16G内存,15k sas raid 1+0。备份服务器最好跟数据库服务器同等配置。硬件可以自己买品牌的底板,也就是机箱配主板和硬盘盒,CPU内存硬盘都自己配,也可以上整套品牌,也可以兼容机。三台机器,市场行情6、7万也就配齐了。

web服务器可以既跑程序又当内存缓存,数据库服务器则只跑主数据库(假如是MySQL的话),备份服务器干的活就相对多一些,web配置、缓存配置、数据库配置都要跟前两台一致,这样WEB和数据库任意一台出问题,把备份服务器换个ip就切换上去了。备份策略,可以drbd,可以rsync,或者其他的很多很多的开源备份方案可选择。rsync最简单,放cron里自己跑就行。备份和切换,建议多做测试,选最安全最适合业务的,并且尽可能异地备份。

四、机房

三种机房尽量不要选:联通访问特别慢的电信机房、电信访问特别慢的联通机房、电信联通访问特别慢的移动或铁通机房。那网通机房呢?亲,网通联通N久以前合并改叫联通了。多多寻找,实地参观,多多测试,多方打探,北京、上海、广州等各个主节点城市,还是有很多优质机房的,找个网络质量好,管理严格的机房,特别是管理要严格,千万别网站无法访问了,打个电话过去才知道别人维护时把你网线碰掉了,这比DOS都头疼。自己扯了几根光纤就称为机房的,看您抗风险程度和心理素质了。机房可以说是非常重要,直接关系到网站访问速度,网站访问速度直接关系到用户体验,我可以FQ看风景,但买个网游vpn才能打开你这个还不怎么知名的网站就有难度了。或许您网站的ajax很出色,可是document怎么也不ready,一些代码永远绝缘于用户。

五、架构

初期架构一般比较简单,web负载均衡+数据库主从+缓存+分布式存储+队列。大方向上也确实就这几样东西,细节上也无数文章都重复过了,按照将来会有N多WEB,N多主从关系,N多缓存,N多xxx设计就行,基本方案都是现成的,只是您比其他人厉害之处就在于设计上考虑到缓存失效时的雪崩效应、主从同步的数据一致性和时间差、队列的稳定性和失败后的重试策略、文件存储的效率和备份方式等等意外情况。缓存总有一天会失效,数据库复制总有一天会断掉,队列总有一天会写不进去,电源总有一天会烧坏。根据墨菲定律,如果不考虑这些,网站早晚会成为茶几。

六、服务器软件

Linux、nginx、php、mysql,几乎是标配,我们除了看名字,还得选版本。Linux发行版众多,只要没特殊要求,就选个用的人最多的,社区最活跃的,配置最方便的,软件包最全最新的,例如debianubuntu。至于RHEL之类的嘛,你用只能在RHEL上才能运行的软件么?剩下的nginx、php、mysql、activemq、其他的等等,除非你改过这些软件或你的程序真的不兼容新版本,否则尽量版本越新越好,版本新,意味着新特性增多、BUG减少、性能增加。总有些道听途说的人跟你说老的版本稳定。所谓稳定,是相对于特殊业务来说的,而就一个php写的网站,大多数人都没改过任何服务器软件源代码,绝大多数情况是能平稳的升级到新版本的。类似于jdk5到jdk6,python2到python3这类变动比较大的升级还是比较少见的。看看ChangeLog,看看升级说明,结合自己情况评估一下,越早升级越好,别人家都用php6写程序了这边还php4的逛游呢。优秀的开源程序升级还是很负责任的,看好文档,别怕。

以上这六点准备完毕,现在我们有了运行环境,有了基本架构骨架,有了备份和切换方案,应该开始着手设计开发方面的事情了。开发方面的事情无数,下一篇会先说一些重点。

转载:http://zhiyi.us/internet/thinking-twice-before-building-your-site-one.html

分享到:
评论

相关推荐

    三级信息技术模拟软件

    总的来说,这款"三级信息技术模拟软件"是一个面向信息技术学习者,特别是准备参加信息技术等级考试三级的考生的免费工具。它提供了模拟考试的环境,帮助用户通过实践来巩固理论知识,提高解题能力,且无需注册和付费...

    100101综放工作面安装转载机、支架等安全技术措施.doc

    《100101综放工作面安装转载机、支架等安全技术措施》文档主要阐述了在100101综放工作面进行设备安装的安全操作流程和技术要点,旨在确保大型设备如转载机、破碎机、支架、机组等在运输、下放和安装过程中的安全。...

    综采工作面更换转载机链条安全技术方法.doc

    综上所述,这份“综采工作面更换转载机链条安全技术方法”详尽地规定了从前期准备到实际操作再到后期清理的全过程,旨在确保作业的安全性和效率,遵循了严格的煤矿安全操作规程,是保障煤矿生产安全的重要文件。

    关于更换转载皮带安全技术措施.docx

    【关于更换转载皮带安全技术措施】 更换转载皮带是一项重要的技术性工作,尤其是在煤炭运输系统中,确保皮带的安全运行对于生产效率和工人的安全至关重要。本文将详细阐述更换钢丝绳皮带的安全技术措施,包括人员...

    工作面更换转载机头减速箱安全技术措施.docx

    【工作面更换转载机头减速箱安全技术措施】 在煤矿开采过程中,机械设备的维护与安全是至关重要的。本文主要讨论的是401工作面更换转载机头减速箱的安全技术措施,旨在确保作业过程中的安全性和效率。以下是详细的...

    综采工作面更换转载机链环安全技术措施.docx

    【综采工作面更换转载机链环安全技术措施】 在煤矿综合机械化开采(综采)过程中,转载机是连接采煤机与运输系统的关键设备,用于将开采下来的煤炭传输到后续的输送系统。由于长时间使用,转载机的链环可能会出现...

    计算机三级网络技术题库 百度云 亲身使用三级合格

    有教学视频和题库,零...版权声明:本文为CSDN博主「CYJ_CYJ」的原创文章,遵循 CC 4.0 BY-SA 版权协议,转载请附上原文出处链接及本声明。 原文链接:https://blog.csdn.net/qq_39154376/article/details/104586424

    桥式起重机的智能转载系统设计技术研究.pdf

    在转载过程中,系统首先利用电气控制系统控制起重机的大车运动,驱动安装在桥式起重机主梁上的激光测距扫描仪对转载场地进行地形扫描。工控机对扫描数据进行分析处理,建立空间环境模型,并基于此模型规划出一条能够...

    掘进机用带式转载机的设计

    掘进机用带式转载机的设计是一个涉及到煤矿开采和物料搬运的重要技术领域。在这一领域中,带式转载机的高效、稳定运行对于提高煤矿的开采效率具有重要意义。本文将对掘进机用带式转载机的设计进行详细解析,包括其...

    转载机检修工安全技术操作规程.doc

    【转载机检修工安全技术操作规程】 ...综上,转载机检修工的安全技术操作规程旨在保障人员安全、提高检修效率,并确保设备正常运行。检修工需严格遵守规程,确保每一步操作都符合安全标准,以预防可能的事故。

    安装转载机安全技术措施.doc

    【安装转载机安全技术措施】 本安全技术措施旨在确保在150101综采面运输顺槽中安装764/160转载机和PLM100破碎机的安全施工。以下是对该措施的详细说明: 1. 施工前准备: - 确保所有必要的材料和工具准备就绪且...

    安装转载机安全技术措施(1).doc

    【安装转载机安全技术措施】 在煤矿作业中,安装转载机是一项重要的工程,涉及到矿井生产的安全和效率。本文详细阐述了在150101综采面运输顺槽安装764/160转载机和PLM100破碎机的安全技术措施。 一、施工准备 在...

    工作面更换转载机链条及机头机尾链轮安全技术措施.docx

    本文详细介绍了在12上311工作面更换DBT公司400KW转载机的链条及机头机尾链轮的安全技术措施。这是一项预防性检修任务,旨在确保设备的正常运行,避免因磨损导致的安全隐患。 **一、概况** 工作面的转载机链条直径φ...

    转载软件开发专业技术名词的解释.pdf

    转载软件开发专业技术名词的解释.pdf

    转载机自动控制煤流装置

    兖州矿业(集团)公司济宁二号煤矿在面对桥式转载机和顺槽带式输送机搭接问题时,采取了积极的技术改造措施。具体来说,他们针对转载机机头卸载部分进行了重新设计和改造,最终研制出了转载机自动控制煤流装置。这一...

    [转载]Delphi使用OpenGL技术制作屏保程序

    [转载]Delphi使用OpenGL技术制作屏保程序

    带式输送机中间转载装置设计研究

    带式输送机中间转载装置设计研究的知识点涵盖了设计的背景、具体研究内容、设计研究过程中的关键技术和提出的设计方案,以及其对行业解决类似问题的指导意义。 首先,带式输送机中间转载问题是指在带式输送机运行...

    转载点密闭触控自动喷雾降尘技术应用研究

    针对新桥煤矿2107综采工作面回风顺槽转载点产生的高浓度粉尘,分析了转载点粉尘产生来源及产生特点,提出采用密闭触控自动喷雾降尘技术对其进行治理,介绍了密闭触控自动喷雾降尘系统组成及运作原理。降尘系统在该地点...

Global site tag (gtag.js) - Google Analytics