使用阿里云发布分布式网站,开发时候应该注意什么?
虽然之前写过关于负载均衡的文章,但是似乎大家都对负载均衡这个标题很陌生。今天就换个角度,从分布式网站发布角度说一下
首先,网站发布一定离不开服务器,就是阿里云的云服务器ECS。最近发现,老用户也有机会购买特价服务器,参考阿里云天猫旗舰店。分布式网站架构,在开发环节需要处理号几个地方,才能更轻松的扩展:
-
1,数据库单独运行
这个最简单,相信只要用到了数据库的网站,大部分都是已经可以轻松实现网站和数据库分离的模式。之所以强调这点,就是因为,网站真的到了访问量大了,需要由单机发布改为分布式发布时候。首先就是要把数据库单独出来,使用单独一台ECS或者使用专门的RDS运行。
关于使用ECS自行搭建数据库,要说的无非就是,数据库文件一定要放在SSD硬盘上。因为云硬盘本质都是虚拟硬盘,读写指标iops会损失的很严重。当然业务量大了之后,我更建议选购RDS,RDS阿里云专门的数据库服务产品,mysql,sqlserver等多款分支,说实话,用惯了ECS自建可能会感觉这个产品挺贵的。但是实际上RDS已经针对硬盘读写,高可用,轻松拓展读写分离等提供了巨大的便利。因此大部分分布式网站都是选用了RDS等产品。
-
2,session存储
大部分网站都是有登录需求或者其他session存储需求的。其实真正服务某一个用户的服务器只有一个,然而分布式网站是在负载均衡的规则下转发到后台服务器,如果负载均衡没有开启回话保持功能,那么很有可能用户登录后,其他访问很有可能到达不同的后端服务器处理,而实现不同服务器同样能支持服务的办法就是,session得共享起来。这样就做到了让用户不需要反复登录。
session共享有多重方法,一种是什么都不用做,session存储在收到请求的那台ECS本地,这种情况就需要负载均衡开启“会话保持”功能。这么做可以实现大部分分布式发布需求,但是如果有使用session统计在线量的时候就会发现只统计到某台ECS登录的用户量。
还有一种session共享的办法是使用单独的服务存储session,例如专门拿出来一台ECS做session服务。这里也有人跟倾向于单独用一个redis服务共享存储session,也是非常好的办法。
-
3,用户上传的文件
很多网站存在用户上传的情况,但是分布式发布后,显然用户上传的时候传入了服务器A,等以后下载的时候使用的是服务器B,这时候如果没做共享,显然用户下载的文件会报错404,因为服务器B路径下显然没有用户传到A服务器里的文件。
解决办法很简单,就是讲所有的上传文件,传入到服务器之后,都转存到“共享文件服务器”,这个共享文件服务器,可以考虑自己搭建,但我建议的是使用阿里云提供的“对象存储OSS”服务。这样用户所有的下载,都走的时候OSS的访问地址,就不会报错404了。而且OSS是个独立的服务,下载文件使用的是OSS的流量,不占用发布网站的ECS的带宽。这就可以做到1M服务器带宽撑起峰值几十人甚至上百人的并发的原因。如果文件较多,另外建议将OSS搭配CDN使用
-
4,网站的日志文件
很多网站开发时候都是留有日志功能的,这些日志,就不再适合继续使用网站目录下某个路径存储了。原因跟上一条一样:文件存储在单台服务器里,要拿到全部日志文件需要每台服务器去获取一遍,显然不合适!
解决办法跟上一条很相似:使用共享文件服务器存储日志。这里需要注意避免日志文件重名,常见的年月日明明,在这里就会冲突,因为多台服务器都会产生相同文件名称的日志。但是我在这里,更建议大家把需要收集的日志文件,直接放入数据库RDS中。这样获取日志就不用每台服务器去汇总了。直接从数据库查出来就好。
-
5,发布网站文件一致
发布文件一致,就是为了保证更好的扩展。将来服务器压力太大,只需要直接从现有服务器环境拷贝一份即可。甚至搭配阿里云的“弹性伸缩ESS服务”。可以根据设置好的伸缩规则,自动按照某个服务器模板增加或者减少WEB服务器数量,实现弹性扩容。
综上所述,一个功能较全的分布式网站发布在阿里云,公共需要这么几个服务:ECS多台,SLB一台,RDS一台,Redis或有,ESS或有。
通过ECS+SLB+RDS+Redis+ESS的搭配,就可以轻松应对更多的访问量了。
附录:阿里云相关产品的帮助文档:
原文地址: https://www.opengps.cn/Blog/View.aspx?id=238 文章的更新编辑依此链接为准。欢迎关注源站原创文章!
低调大师中文资讯倾力打造互联网数据资讯、行业资源、电子商务、移动互联网、网络营销平台。
持续更新报道IT业界、互联网、市场资讯、驱动更新,是最及时权威的产业资讯及硬件资讯报道平台。
转载内容版权归作者及来源网站所有,本站原创内容转载请注明来源。
- 上一篇
一对一视频聊天app开发过程中关于数据存储的问题
在一对一视频聊天app开发过程中,通常会遇到各方各面的问题,比如延时、卡顿等技术性问题等等。而其中的数据存储问题也是比较令人头疼的,如果数据定期访问那么数据存储的成本反而更高。为了避免拥挤可以借助云端数据存储的方式,协助开发者解决这些成本窘境。1.什么是云存储?云存储是一种云计算模型,可通过云计算提供商(将数据存储作为服务进行管理和运营)在 Internet 上存储数据。该模型按需适时提供容量和成本,无需您自行购买和管理数据存储基础设施。可实现敏捷性、全球规模和持久性,以及“随时随地”访问数据。 2.云存储该如何运作?云存储购买自第三方云供应商,这些云存储供应商管理着容量、安全性和持久性,以使您的应用程序从世界各地都能访问数据。应用程序通过传统存储协议或直接通过 API 访问云存储。许多供应商都提供各种补充服务,旨在帮助大规模收集、管理、保护和分析数据。(1数据存储和使用层次当设计一个应用并将其和数据关联,需要考虑创建的存储层次,同时内存数据的高速缓存也许在云端看起来比较麻烦,但是通过大部分内存元素访问,可以减少数据访问率,从而减少成本。(2本地存储服务支持尽管本地资源和云之间的块或者...
- 下一篇
阿里云服务器企业该如何选择
今天来说下企业如何选择阿里云服务器的配置。 企业和个人最大的区别就是企业面向的用户众多,对访问速度和数据安全性要求非常高。试想下你的网站三天两头被黑客攻击,网站被黑了,数据没了,这样的网站怎么能吸引到用户呢。 对于个人站长,用户基数不是非常大,我认识的很多站长基本都是购买一台高配的ecs后,所有的东西都往ecs上安装,比如数据库,缓存服务等。这样做的缺陷是web服务和数据库存储没有进行分离。企业站点一般来说可以分为api和数据存储,api是面向外网用户的,为用户提供数据服务和展现ui。数据库则存储用户的重要数据,将存储和服务分开部署可以有效减小单台服务器的压力,第二则是数据安全更有保障。 所以对于企业站点来说,首先需要将api和数据库存储进行分开部署,以便分摊压力。在企业的前期,可能访问量很小,这时候所有的数据只需要直接访问数据库就可以了。随着访问量的增长,那么对于服务器的性能要求便会非常高,一般企业的场景是:读多于写。所以这时候可能需要引入额外的缓存服务器。 那么对于api和数据库的存储配置我们该如何选择呢?首先也是付费方式和地域选择: 在这里我们同样选择包年包月的付费方式,地域选择...
相关文章
文章评论
共有0条评论来说两句吧...