浅谈SegmentFault对网站架构的改进与优化

所属分类: 网站运营 / 网站优化 阅读数: 53
收藏 0 赞 0 分享

系统架构的大大加强
SF以前的系统架构是什么样子呢?回答是没有什么架构,因为所有的服务都放在一台服务器上,这个答案可能让很多用户大跌眼镜。

是的,受制于创办之初的资金限制,SegmentFault的网站只有一台服务器。在后期访问量逐渐增大的情况下,这台服务器状况不断,如果有一天它突然挂掉,那恢复它可就费事了。

云主机助力

对于SF这样的初创企业,自己建立数据中心显然是性价比极低的选择,但是系统架构的限制又逼迫SegmentFault不得不做出改变。幸好现在已经进入了云时代,大量的基础设施问题可以交给更专业的服务商解决。经过一系列权衡,SegmentFault最终选择了青云作为SegmentFault的云主机提供商。

4 * web服务器(其中一台备用)
1 * db服务器(得力于ssd和缓存的使用,目前一台db是可以满足需求的)
1 * 搜索服务器
1 * 缓存服务器
1 * 后台服务服务器
一般工作的就是这8台服务器

更加颗粒化的系统划分

这一点在web服务器系统的设计上尤为突出,它是所有服务器中压力最大的,因此机器数量也是最多。但是每台服务器的配置却是最小的 单核1G 的实例。

这种颗粒化的划分,有以下几个好处

节约成本,如果SegmentFault一次性配置一台多核大内存的服务器,成本是很高的,而且大部分情况下性能是有浪费的。
增加可靠性,一台机器挂掉的可能性远大于多台机器同时挂掉
方便水平扩展,你可能已经注意到我设计了一台备用服务器,它平时就是挂在负载均衡节点上的,只是不需要开机(如果不开机是不会计费的),当遇到突然增加的访问量时,SegmentFault可以实时启动这台服务器,从而瞬间减轻其它节点的压力。而访问量降低后,SegmentFault又可以关掉它,降低使用成本。
2016111101923468.png (536×250)

比如上面这张图就是一次典型的流量冲击处理,在11点左右网站的访问量陡增,前端web的负载全部到顶,根据它的增长曲线,SegmentFault判断这是一次恶意抓取。需要SegmentFault在程序上做防护的同时在这期间不影响用户访问,因此SegmentFault将第四台备用服务器的配置临时调整到 4核2G,并在12点左右上线,系统负载马上恢复到了正常水平

改变代码上线模式

通常的上线流程就是直接把可发布的代码通过rsync之类的同步到线上机器。

在新版的SF中SegmentFault根据PHP的特点改变了这一模式,SegmentFault将代码打包成phar发布到服务器,每上线一次就重新打一个包,并将其文件名命名为版本号,比如14.9.5.195755.1718937340.phar。打包发布有如下好处:

方便管理,只有一个文件,而且传输比以前的同步模式更加快速,并且可以避免当某些文件没有同步完用户就来访问的错误
可以回滚,回滚非常方便,在配置文件里将需要加载的包版本号改成你需要回滚的版本即可,可以快速完成灾难恢复
更加好地依赖云服务

除了SegmentFault的云主机,SegmentFault还使用了如下云服务

Amazon SES,群发邮件价格便宜量又足
Mailgun,目前SegmentFault的主力邮件发送服务,大家的通知提醒服务都是通过它
SendCloud,备份邮件发送服务,主要用来发一些mailgun无法收到的邮件,比如QQ Mail等等
又拍云,所有的静态文件,包括用户头像和上传图片的存储
NewRelic,程序性能监测

更多精彩内容其他人还在看

百度喜欢这样的网站!

SEO的主要工作其实也就是两方面,一个是站内优化,一个是站外推广。做好这两点,也就真正实现了用户体验度高、对搜索引擎友好的目标,那么相信你的站点也能够获得一个很不错的稳定排名。今天就详细讲述一下站内的优化我们具体应该怎么做。
收藏 0 赞 0 分享

Google算法更新 “鸽子”算法离搜索目标越近排位越高

从 2012 年的“企鹅”开始,谷歌喜欢用一种鸟类来冠名自己的的搜索引擎算法更新。最近更新的“鸽子”算法种它是根据搜索者的地理位置信息重新调整网页的排名。离你搜索的位置越近他的排名就越高
收藏 0 赞 0 分享

不需要增加大量原创内容也能够实现网站排名的上升的技巧分析

很多人每天都会投入数个小时在编写各种网站内容方面,这导致了网站的其他运营出现了严重的时间瓶颈,久而久之会逐渐形成厌烦情绪,最终实现了网站的自杀式断更,于是很多网友都在探讨,能否有一种不需要增加大量原创内容也能够实现网站排名的上升呢
收藏 0 赞 0 分享

网站推广经验实战:百度搜索推广之实操分享

其实百度推广和之前接触过的直通车非常类似,都属于按点击付费的推广方式,下面我们分享了一个实际例子关于百度搜索推广之实操,需要的朋友可以参考下
收藏 0 赞 0 分享

浅谈:网站百度权重的平衡之策

在百度否认权值存在后,现在百度权重又以强势之姿进入了人们视线,原因在于现在很多新站出现了明明上线不到两个月而测试出的数据居然高于很多经营数年的老网站,那么到底是什么决定了网站的百度权重呢?请看下文
收藏 0 赞 0 分享

网站优化实例教程 解读网站搜索引擎和快照的一些问题

有很多人都分不清快照和搜索引擎到底有什么关系?下文我们分别介绍了快照和搜索引擎的定义,同时用实例分析快照和搜索引擎对于网站优化有哪些帮助,需要的朋友可以参考下
收藏 0 赞 0 分享

百度竞价怎么做 ?百度竞价流量环节总结篇

百度竞价怎么做 ?百度竞价的核心是流量,流量就是通过关键词的点击进入到我们推广的着陆页面,今天我们来讨论百度竞价流量阶段的一些问题,需要的朋友可以参考下
收藏 0 赞 0 分享

突破百度外链封锁 将外链打入百度文库、经验的方法分析

在百度旗下的产品如百度知道、文库、空间和经验里面留下自己的外链效果很好,但是现在百度管理的很严格,想留外链不容易啊,下面就来重点讨论一下在百度文库上打入外链的方法
收藏 0 赞 0 分享

内容营销 你知道什么样的内容更轻易获得快速传布吗?

 不论是说什么营销,不论是小站长之间的讨论,还是大集团老总的现身说法,都少不内容营销这个东西。那为什么有些内容疯狂传布,分享爆棚,而有些内容仅仅昙花一现却不能掀起波澜?什么样的内容才会被快速传布呢
收藏 0 赞 0 分享

流量为王是SEO思维的毒药

自从有了微博微信,搜索引擎好像没有那么受宠了,也使SEO也变得更加黯淡无光了。圈子里流传着这样的恐怖气息:没前途了,没饭吃了,SEO要死翘翘了。
收藏 0 赞 0 分享
查看更多