导语:服务器的构成包括处理器、硬盘、内存、系统总线等,和通用的计算机架构类似,但是由于需要提供高可靠的服务,因此在处理能力、稳定性、可靠性、安全性、可扩展性、可管理性等方面要求较高。那么,我们可以怎么选择好的服务器
怎么选择好的服务器你需要从不同的角度来决定选择一台什么样的服务器,找到满足技术需要、业务发展和成本控制之间的最佳平衡点,为了做到这一点,绝对还是需要一点智慧。51IDC将在下面为大家介绍一些易于理解,尽可能全面的建议,并帮助你做出决定。
先不要急于决定需要怎样的CPU,几个硬盘,几个G内存,需要多少兆带宽这样的问题,那些是我们最后需要得到的答案。在这之前,先一起梳理几个问题。在下面,我们列出了一些“多少”或“什么样”的问题,拿起你的笔或在Windows记事本里新建一个文件,尝试根据下面四个问题来评估自己的需求:
1服务器运行什么应用
2需要支持多少用户访问
3需要多大空间来存储数据
4我的业务有多重要
1:服务器运行什么应用这是首先需要考虑的问题,在这里你要根据服务器的应用类型,也就是用途,来决定服务器的性能、容量和可靠性需求。我们按照前端服务器+应用程序服务器+数据服务器的常见基础架构来讨论:
11Web前端:正常情况下,我们认为大多数Web前端服务器(Front-end)对服务器的要求不大,例如静态Web服务器、动态Web服务器、服务器等等,因为在现有的技术框架中,我们有很多方案可以解决前端服务器的性能扩展和可靠性问题,例如LVS、Nginx反向代理、硬件负载均衡(F5,A10,Radware)等。甚至在很多访问量不高(几百个用户同时在线)的应用中,51IDC的经典酷睿服务器就可以满足需求。
12应用服务器:由于承担了计算和功能实现,我们需要为基于Web架构的应用程序服务器(Application Server)选择足够快的服务器,另外应用程序服务器可能需要用大量的内存,尤其是基于Windows基础架构的Ruby,Python,Java服务器。这一类服务器至少需要使用单路至强的配置。对于可靠性的问题,如果你的架构中只有一台应用服务器,那肯定需要这台服务器足够可靠,RAID绝对是不能忽视的选项。但如果有两台或更多的应用服务器,并设计了负载均衡机制,具有冗余功能,那我们则不必将每台服务器武装到底。
13特殊的应用:除了作为Web架构中的应用程序服务器之外,如果你的服务器是用来处理流媒体视频编码、服务器虚拟化、媒体服务器(Asterisk之类),或者作为游戏服务器(逻辑、地图、聊天)运行,则同样对CPU和内存需求比较高,我们至少要考虑单路至强的服务器。其中服务器虚拟化对存储的可靠性的要求都非常高,因为一个篮子里有十几个鸡蛋,篮子一定要足够牢靠才是。
14公共服务:我们指的是邮件服务器、文件服务器、DNS服务器、域控服务器这类服务器。通常情况我们会部署两台DNS服务器作为互相备份,域控主服务器也会拥有一台备份服务器(专用的或非专用的),所以对于可靠性,无需达到苛刻的地步。至于邮件服务器,至少需要具备足够的硬件可靠性和容量大小,这主要是为了对邮件数据负责,因为很多用户没有保存和归档邮件数据的习惯,当他们重装系统后,总会依赖重新下载服务器上的数据。至于性能问题,我们认为需要评估用户数量才能决定。
15数据库:我们最后讨论的应用,也是要求最高,最重要的服务器。无论你使用的是MySQL、SQLServer还是Oralce,一般情况下,我们认为它需要足够快的CPU,足够大的内存,足够稳定可靠的硬件。单路至强CPU/4GB内存/Raid1绝对是入门配置。关于准确的配置我们需要再讨论业务需求后才能作决定。
2:服务器需要支持多少用户访问服务器肯定是为了提供某种服务,而使用这些服务的用户同样是我们必须考虑的因素,有几个具体的问题你需要做出评估:有多少注册用户正常情况下有多少用户会同时在线访问每天同时在线访问的最高峰值大概是多少这些问题,对我们决定采用什么样的CPU,多大的内存有着至关重要的影响。51IDC建议你的技术人员和业务部门坐在一起来讨论这几个问题,最后甚至需要按照特定的技术模型和算法,将这些数字转化为一些更具体的技术数字,例如并发多少个连接(很多时候,用户数与连接数不是一个概念)。同时,你还要对未来的用户增长做一个尽可能准确的预测和规划,你的服务器需要支持越来越多的用户。
3:需要多大空间来存储数据我们需要从两个角度来计算这个问题,一个角度是有哪些类别的数据,包括: *** 作系统本身占用的空间、安装应用程序所需要的空间、应用程序所产生的数据、数据库、日志文件、邮件数据等等,如果是Web20类的网站,你还要计算每个用户的存储空间;另一个角度是从时间轴来考虑,这些数据每天都在增长,你至少要为未来1年(我们建议2~3年)的数据增长做个准确的测算,这可能仍然需要你的软件开发人员和业务人员一起提供足够的信息。最后你仍然需要为计算出来的数字结果乘15左右的系数,方便维护的时候做各种数据备份和文件转移 *** 作。
4我的业务有多重要:你需要根据自身的业务领域,来遵循一些要求,我们在下面举几个简单的例子,帮助你理解这些服务器对可靠性、数据完整性等方面的要求:
41如果你的服务器用来运行一个WordPress博客,与朋友们分享观点。那么我相信,一台酷睿服务器,1G内存外加一块160GB的硬盘就足够了。就算服务器出现了一点硬件故障,导致几个小时甚至一两天不能提供访问,生活会照常继续,天也不会塌下来。
42如果你的服务器用来作为测试平台,那么就不会如生产环境那样,对可靠性有极高的要求,你所需要的可能只是做好例行的数据备份,服务器宕机后,能有个人在今天把问题解决掉就OK了
43如果你是一个电子商务公司,服务器正在运行电子商务网站平台,那么请一定要像重视女朋友一样重视服务器,当硬件发生故障而导致宕机,你需要对以下危言耸听的后果做好心理准备:投诉电话被打爆、顾客大量流失、顾客要求退款、市场推广费用打水漂、员工无事可干,公司运营陷入瘫痪、数据丢失(这是最痛苦最灾难的结果,我们经历了太多这样的案例,它甚至会导致一个公司就此消亡)在这里,我们其实只需要简单讨论你的业务对服务器硬件可靠性的要求。换言之,如果你觉得业务不能承担硬盘损坏带来的停机或数据丢失风险,那么一定要选择一个合适的Raid卡,对于冗余电源问题,道理一样。(全面解决这个问题,不单考虑单个服务器的硬件,还需要结合系统架构的规划设计和运维管理来分析,这部分我们将单独撰写文章来讨论。)
在完成以上问题后,我们接下来就可以决定这些具体选项:
选择什么CPU
回忆一下上面”服务器运行什么应用“和“需要支持多少用户访问”两个问题的答案,这将帮助我们来选择合适的CPU。毫无疑问,CPU的主频越高,其性能也更高;两个CPU要比一个CPU来得更爽,至强肯定比酷睿更生猛。但我们究竟需要选择怎样的CPU我们在这里为你提供一些常见情况下的建议:
(1)如果你的业务刚刚起步,预算不是很充足,建议你选择一款经典酷睿服务器,毕竟51IDC的E5300服务器最便宜只需要450块钱一个月。而且,以后你可以根据业务发展情况,随时升级到更高配置的服务器。
(2)如果你需要在一台服务器同时运行多种应用服务,例如Net+Exchange+SQLServer,那么一个单路至强(例如X3330)或新一代酷睿I3/I7(双核四线程)将是最佳的选择。虽然从技术角度,这不是一个好主意,但至少能够帮你节约一大笔成本。
(3)如果你的服务器运行SQLServer、MySQL或者Oracle,而且目前有几百个用户同时在线,未来还会不断增长,那么你至少应该选择安装一个E5504(或更高主频)的至强服务器。当半年后负载越来越大的时候,可以选择增加一个CPU。
(4)如果你需要一台游戏服务器,那么我们建议你选择一台单路或双路的至强服务器。需要注意的是,使用双路CPU需要应用程序的支持,如果应用程序本身没有对双路CPU进行代码优化,就不会带来性能的显著提升,而且将造成投资的极大浪费。
需要多大的内存
同样,”服务器运行什么应用“和“需要支持多少用户访问”两个问题的答案,也将帮助我们来选择合适的内存容量。相比于CPU,我们更认为内存(RAM)是影响性能的最关键因素。因为在相当多正在运行的服务器中,我们发现CPU利用率一般都在10%~30%之间,甚至更低。但我们发现由于内存容量不够而导致服务器运行缓慢的案例比比皆是,如果服务器不能分配足够的内存给应用程序,应用程序就需要通过缓慢的硬盘接口来交换读写数据,这将导致网站慢的令人无法接受。内存大小主要取决于服务器的用户数量,当然也和应用软件对内存的最低需求和内存管理机制有关系,所以,最好由你的程序员或软件开发商给你最佳的内存配置建议。我们同样在下面给出了一些常见应用环境下的内存配置建议:
(1)无论是Windows下的`IIS还是Linux下的Apache,一般情况下Web前端服务器不需要配置特别高的内存,尤其是在集群架构中,1GB-2GB就已足够。只有当几千个并发用户,并运行动态脚本的时候,我们才会考虑使用4GB或更高的内存。
(2)对于运行Tomcat、Resin、WebLogic、Websphere或Net这样的应用服务器,2GB内存应该是基准配置。更准确数字需要根据用户数量和技术架构来确定。
(3)数据库服务器的内存由数据库实例的数量、表大小、索引、用户数来决定,一般建议配置4GB以上的内存,我们甚至在很多的客户案例中使用了24GB到48GB的内存。
(4)诸如Imail、Notes、Exchange这样的邮件服务器对内存的要求也并不高,1GB-2GB就可以满足了。
(5)对于一台文件服务器,1GB内存可能就足够了。
(6)还有一些特殊的服务器,我们需要为之配置尽可能高的内存容量,包括Squid,Varnish这样的缓存服务器,和Memcached Server。事实上,上面的数字已经足够慷慨,由于内存技术的不断进化和价格不断降低,我们才得以近乎奢侈的讨论4G、8G、16GB这些曾经不可想象的内存容量。早在2000年的时候,我面对的大多数服务器都是256MB、512MB内存,1GB已经算是高配,而那时同样也需要满足大量用户的访问。所以,除了花钱购买内存来满足应用程序的贪婪之外,系统优化和内存管理仍然是我们需要重视的问题。需要怎样的硬盘存储系统硬盘存储系统的选择和配置是整个服务器系统里最为复杂的一部分,我们需要考虑硬盘的数量、容量、接口类型、转速、缓存大小,以及是否需要Raid卡,Raid卡的型号和Raid级别等问题。甚至在一些高可靠性高性能的应用环境中,我们还需要考虑使用怎样的外部存储系统(SAN、NAS或DAS)。
网卡的问题:
如果你的基础架构是多服务器环境,而且服务器之间有大量的数据交换,那么我们建议你为每台服务器配置两个或更多的网卡,一个用来对外提供服务,另一个用来做内部数据交换。如果你对安全的要求特别高,我们甚至可以单独安装一个用于系统管理和日常维护的网卡。至于网卡端口的速率问题,这主要取决于你对带宽流量的评估。大多数情况下,百兆网卡足够用来对外提供服务,而内部数据交换建议使用千兆网卡。但话说回来,除了经典酷睿服务器之外,我们现在很难找到百兆接口的服务器主板了。还有一种情况需要注意,如果你选择51IDC的数据备份服务(Managed Backup Service),则需要一块单独的网卡连接到专有的数据备份网络中,进行每天的数据备份,这会带来几个好处:不会占用宝贵的外网带宽、保证数据传输的安全、提供快速的数据备份速度。我们非常希望这篇文章能够帮助你为服务器选择合适的硬件配置,如果你阅读后发现有不正确的地方,请在评论中指出来,我们会及时更新并感谢你的热情指正。
服务器的各运行指标最高的是吞吐量。吞吐量是固定时间间隔内,处理完毕的事务个数,通常是1秒内处理完毕的请求个数。
峰值吞吐量是一段时间内吞吐量的最大值,是用来评估系统容量的重要指标之一。
从服务器的档次来看,服务器大致分为入门级服务器、工作组级服务器、部门级服务器、企业级服务器
从应用层次来看的话,大致分为快速处理型、海量存储型和低价稳定型
比如门户型网站、网络游戏、大型论坛、电子商务等这类网站就要求处理速度快应选择快速处理型这种服务器
视频网站、大型新闻网站等要求数据储存量大,访问频繁的要求,像企业网站,普通个人网站等要求对存储要求不高,但对安全性和稳定性却是必须要考虑的因素,选择那一类型的服务器就需要结合网站的属性和预算以及各方面因素来加以考虑了,再对服务器的各项参数加以对比和分析
从硬件配置来看, *** 作系统、数据库、Web服务器、Web应用软件等的选择问题,要根据网站类型、网站规模、资金预算及站长经验众多因素从站长预备的方案中选出适宜的产品,还有服务器的中央处理器、内存、芯片组、I/O总线、I/O设备、电源、机箱和相关软件,这些应该是站长选择服务器所要关注的指标
二、服务器的性能稳定性站长们在日常的网站维护中,可不希望自己购买或者租凭的服务器出现问题,因为服务器属于比较复杂和高负荷运载的机器,服务器的维修通常要比处理一个网站的N多问题困难得多,一点小毛病就会带来一系列的问题,服务器的维护都是以预防为主的,当一出现问题,所造成用户的损失也是不可估量的
稳定型强的服务器对站长们是至关重要的,在选择服务器时,站长还要考虑的是页面脚本是否需要更改,应用服务器是否需要更新
大多数的服务器主要是为一种 *** 作系统进行优化和处理的,有的服务器只能运行在一种 *** 作系统上,所以站长们选择服务器时,还需要和 *** 作系统结合起来考虑
而且一般的品牌服务器都有专门属于自己的一套服务器系统软件,这就要考虑这套软件所支持的标准、应用(包括数据库应用)和安全协议等
其次是要考虑服务器的并发用户数的支持能力,也就是指服务器在同一时刻可以允许的用户连接数
诸如响应能力这个参数与服务器所能支持的并发用户数相关,响应速度越快,单位时间内就可以支持越多的访问量,用户点击的响应速度就越快
三、服务器的安全性选择服务器,安全因素也是站长朋友们必须要考虑的因素,安全系统方面是指服务器维护人员否能7X24小时进行全方位的机房监控
它主要要考虑两个方面:一是保护服务器机密信息;二是要防止黑客的攻击
四、服务器的技术服务服务器的良好服务也是作为服务器的最高宗旨,从服务器商的服务管理体系是否规范,技术实力是否到位,问题处理是否及时,产品使用说明讲解是否详细,IDC服务商的管理运营能力是否以从用户的角度出发,其次看IDC商是不是正规公司,是否拥有这方面的资深认证可以帮助站长朋友们免费备案,还要看IDC服务商背后是否有强大的资源支持等等
如果出了问题,不能得到服务商及时可靠的技术支持,将很可能影响到网站的正常运营
五、服务器的应用指标以Web服务器为例,如果站长的Web站点网页主要是ASP动态类型的,就不适宜选择Apache服务器系统,因为它对ASP不支持,同样,如果站长的数据库系统是SQL,也不适宜选择Apache,同样是因为它不支持
六、服务器的内存性能一款高内存的服务器,往往可以储存海量的信息和具备站长网站日常大量的会话和互动需求,如果条件允许,站长们尽量选择内存稍大点易扩展的服务器,对于日后网站的升级更新,访问量增大等提供支持
另外是在选择服务器的时候选择有内存纠错校验技术的内存,一台服务器要稳定的运行,要保证运行计算过程中少出现错误,因此,服务器的内存纠错技术也是重要的
对于服务器的内存,站长很注重他们参数,如带宽、内存总线速度、等待周期、CAS的延迟时间等参数
但对于服务器而言,站长应考虑的是内存的制作工艺,服务器内存一般都采用8层PCB板,完美的电源层和布线层完全体现着稳定性的差距;以及内存的封装技术,它不仅能够给内存带来体积的理想性、容量的扩展性,更重要的是解决了散热、可靠性和密度的问题
服务器常用性能指标如下:吞吐量 固定时间间隔内的处理完毕事务个数。通常是1秒内处理完毕的请求个数,单位:事务/秒(tps)。
响应时间一次事务的处理时间。通常指从一个请求发出,到服务器进行处理后返回,再到接收完毕应答数据的时间间隔,单位:毫秒。
CPU占用率1-CPU空闲率,表示CPU被使用情况,反映了系统资源利用情况。我们以Windows服务器、Linux服务器和IBM AIX服务器为例,分别说明如下:
Windows监控功能:
1、管理Windows的可用性和性能
2、监控性能统计数据,如CPU利用率、内存利用率、磁盘利用率和应答时间
3、监控Windows系统中运行的进程
4、如果Windows系统或该系统中任何指定的属性出现问题,将基于所配置的阈值生成通知和告警;基于配置自动执行 *** 作
5、能即刻呈现性能图表和报表;并基于可用性、健康状况和连接时间分别显示报表
6、提供历史的和当前的Windows性能指标,以便了解特定时间段内的性能状态
7、监控整体的CPU利用情况,并显示哪些进程正在消耗多少CPU资源
8、监控内存使用情况并检测内存消耗大户
Linux监控功能:
1、管理Linux的可用性和性能
2、监控性能统计数据,如CPU利用率、内存利用率、磁盘利用率和应答时间
3、监控Linux系统中运行的进程
4、如果Linux系统或该系统中任何指定的属性出现问题,将基于所配置的阈值生成通知和告警;并基于配置自动执行 *** 作
5、能即刻呈现性能图表和报表;并基于可用性、健康状况和连接时间分组和显示报表
6、提供历史的和当前的Linux性能指标,以便了解特定时间段内的性能状态
7、监控整体的CPU利用情况,并显示哪些进程正在占用多少CPU资源
8、监控内存使用情况并检测内存消耗大户
IBM AIX监控能力:
1、管理IBM AIX可用性和性能
2、监控诸如CPU利用率、内存利用率、磁盘利用率和应答时间等性能统计数据
3、监控模式包括Telnet和SSH
4、监控AIX系统上运行的进程
5、如果AIX系统或该系统中任何指定的属性出现问题,将基于所配置的阈值生成通知和告警;并基于配置自动执行 *** 作
6、能即刻呈现性能图表和报表;并基于可用性、健康状况和连接时间分组和显示报表
7、提供历史的和当前的AIX性能指标,以便了解特定时间段内的性能状态
8、监控整体的CPU利用情况,并显示哪些进程正在占用多少CPU资源
9、监控内存使用情况并检测内存消耗大户首先要考虑到网站的情况:
1网站类型:静态还是动态为主、网站程序、运行环境等需求,影响 *** 作系统、存储模式的选择
2网站访问量:日均IP多少?平均同时在线人数有多少?影响CPU、内存、带宽等选择
3网站数据:目前网站数据多少,短期内是否会有所增长?影响硬盘的选择
4网站目标用户:网站是面向国内还是海外用户?理所当然影响机房线路的选择
其次,确定网站之后,根据需求选择相应配置:
如:网站属于BBS论坛类,静态页面为主,可以选择win系统(一般lin适合做开发的程序员)日均IP在3000左右,可选择单核CPU;同时在线人数有20人左右,想要运行流畅最好选2M,因为1M可能会有点紧巴巴的节奏,还要考虑高峰期(1M支持17人在线,2M则34人,以此类推)
数据盘选择根据网站数据来选择就好
面向海外用户,可以选择香港、韩国、日本线路,鉴于稳定性和访问速度,香港是首选,免备案,可以解决很多问题,目前小鸟云家的香港是非常不错,实现了多线BGP。
面向国内用户,可以选择BGP线路,其他情况还可以选择高防双线等线路,根据实际情况而定
第三,挑选靠谱的云服务器商:
1性能保障
云主机的性能虽然没有统一的测定标准,但是可以通过其他途径侧面了解:首先可以是在服务器监控上,用户是否可以随时看到主机的运行情况;其次是数据测试,读写IO速度如何,决定用户体验
例如:小鸟云后台能一览主机运行情况,简单来说是可视化的数据监控,这点很便民,读写速度在50000 IOPS以上,吞吐量也是达到了800MB/S, 小鸟云可以达到这个水准还是让人很惊喜的
2宽带质量
云主机的带宽质量无疑是影响网站或应用响应时间的重要因素。服务器性能、程序架构、带宽质量,基本决定了网站的响应速度。现在带宽种类很多,有双线、单线、多线、BGP,客户应当根据自己的用户覆盖范围合理选择机房位置。通常来说,双线、多线、BGP适用于覆盖全国的应用。带宽质量,主要由丢包率、平均响应时间来决定,对攻击的抵抗能力也是一个参考标准
3性价比
客户考虑云主机租用的一个重要原因是其性价比通常高于传统IDC服务,当然便利性等其他因素也是客户多看重的。需要注意的是这里考察的应该是性价比,而不是单纯的价格。不是价格越低越好,而是看同样的配置和性能保证,在不同的服务商那里需要花多少钱。另外需要注意的是,要考察整体价格,不能使起步价格和部分价格
4研发能力
云主机租用服务器是应用新技术于IDC行业的服务,其背后需要有一个合适规模的研发团队。这个团队需要能解决基本的功能问题,也需要能够开发出管理大规模基础设施、大量用户的自动化的管理系统。这样才能保证用户的体验,才能不断将运营管理能力转化为客户可以享受到得服务。
5资质和备案服务
云主机服务属于基础电信增值服务,所以其服务商需要获得国家的资质审批。如果没有电信增值服务资质,随时会被有关部门叫停,自然会影响到所有的客户。而服务商对国家政策的理解,备案流程的支持,也是保证客户能够合法合规的基础。
欢迎分享,转载请注明来源:内存溢出
评论列表(0条)