SQL Server服务器内存升级后的烦恼

SQL Server服务器内存升级后的烦恼,第1张

不久之前 笔者一个在企业中从事网管工作的朋友向我求助关于SQL Server服务器内存升级后遇到的问题 原来 他们企业准备上一个企业邮箱系统 为了节省开支 他们准备在原来的SQL Server服务器上部署企业的邮箱服务器 为了提高这个服务器的性能 让其能够承担其两种应用服务的重任 所以 他们对内存进行了升级 从原先的 G升级到了 G

但是 内存升级完以后 邮箱应用服务的性能不但没有改善 而且 还有恶化的趋势 运行一段时间后 这台服务器上运行的邮箱系统就出现了异常情况 时不时的会报出内存分配不足的情况 一开始 他们还以为是邮箱服务器跟SQL Server服务器不兼容 故还请了邮箱服务器的技术人员前来查看 经过他们的检查 发现是SQL Server服务占用的大部分内存所导致的 SQL Server服务所需要的内存 从升级之前的 M左右一下子到了 个G 难怪邮箱应用服务要警报说内存不够了

一 原因分析

笔者对这种问题已经是见怪不怪了 已经遇到过好几次类似的故障 在SQL Server数据库启动的时候 数据库系统会根据物理内存的大小来动态的增大或者缩小高速缓冲区的容量 这主要是为了提高SQL Server服务器的性能才如此的设计的

我们知道 一般情况下 高速缓冲区越大 则SQL Server服务器的性能越好 这主要是因为有些用户查询过的数据都可以放在高速缓冲区(即内存的其中一部分)中 如此的话 当用户下次再次需要这些数据的时候 就不用到硬盘中去读取 而直接在内存中读取即可 而从内存中读取数据要比在硬盘中读取速度要快的多

所以 只要当服务器的可用内存在 MB与 MB之间的话 数据库系统就会把它的高速缓冲区不断的扩大 如此的话 当邮箱服务器突然需要用到比较大的内存 如对邮箱进行备份或者有用户群发邮件的时候 就会报错说 内存分配不足

故一般只是内存升级 往往不能够解决SQL Server服务与其他应用服务抢占内存的情况 为了让SQL Server能够与其他应用服务友好的共处 数据库管理员还需要对内存进行合理的分配 限制SQL Server数据库服务内存的占用率

二 解决方法

针对他们企业的这种情况 笔者给出两个建议 一是合理地给SQL Server数据库分配内存 而是不要把SQL Server服务跟其他应用服务放在同一台服务器上 毕竟数据库服务的并发行访问比较多 对服务器的性能要求比较高

若果企业选择第一种应对措施的话 就需要限制SQL Server服务器的内存使用率 为了使得运行在同一台服务器的SQL Server服务器与邮箱服务能够达到一个合理的性能 能够和平共处 就需要采取一定的措施限制SQL Server数据库服务的内存使用量 在SQL Server服务器中 专门提供了一个工具(数据库引擎) 可以用来帮助我们干预SQL Server服务器的内存分配

具体的说 可以按如下方法进行配置

第一步 打开SQL Server企业管理器

在SQL Server数据库中 提供了一个图形化界面的企业管理器 在这个管理平台上可以对SQL Server的大部分服务进行管理与配置 SQL Server数据库服务的内存分配规则当然也不例外 可以在这里进行调整

第二步 找到我们需要调整的服务器

有些企业 可能在网络中部署了多个SQL Server服务器 为了管理的方面 会在其中一台服务器上的企业管理器中集中进行管理 不过 这家企业他们只有一个SQL Server服务器 在我们需要调整的服务器上 右键单击 选择 属性 然后就会d出一个对话框 在对话框中选择 内存选项卡 在这里就可以对数据库应用服务的内存分配方法进行设置

第三步 调整相关的内存参数

在这张选项卡中 一般有两个参数 分别为最小服务内存与最大服务内存 在实际工作中 我们往往有两种配置方法

一是配置一个最大最小内存 即给SQL Server数据库应用服务设置一个最大的使用内存 如此的话 在这个最大的范围之后 数据库系统会根据实际情况 在最大内存范围之内对内存的分配进行调整 一般情况下 最小内存我们可以不设置 只对最大内存进行限制即可 这就给数据库一种自主选择的权利 可以提高内存的使用效率

二是固定内存分配 即把 最小服务内存 与 最大服务内存 两个参数设置为相同 如此的话 不管数据库服务需要多大的内存 在服务器启动的时候 *** 作系统都会给其预留这么大的内存 其他的应用程序及时内存再怎么不足 也不会跨越数据库的内存领地 很明显 这种方式虽然保证了数据库服务的内存需求 但是 内存的使用率并不是很高

针对上面两种方法 笔者比较倾向与使用第一种配置 即只对数据库应用服务的最大内存使用率进行限制 只要不超过这个范围 则服务器可以自主的进行调解 那么这个最大的使用率设置成多少合适呢这主要要看企业所部属的服务了 由于这家企业 在同一台服务器上运行了邮箱服务器与数据库服务器 可能对硬件的压力比较大 因为这两个应用服务 都涉及到比较多的并发访问 所以 即使把硬件升级成了 G 估计也不能够给数据库服务分配比较多的内存 一般来说 并发性访问越多 则最好能够给其配置比较多的内存

配置完成之后 不用重新启动 这个规则就会起效 不过笔者还是建议把SQL Server服务重新启动一下 在可以的情况下 把服务器重新启动一下最好 如此的话 *** 作系统就会根据这个规则 对内存进行重新的调整分配 也可以让SQL Server服务器更好的队内存进行合理的安排 如可以把SQL Serve可用内存固定在一个连续的区域内 以提高数据库的性能

三 总结

针对这个内存升级后所产生的烦恼 笔者有几句话说

一是硬件升级只是数据库服务器性能提升的一个充分条件 而不是必要条件 也就是说 硬件的升级并不一定会导致服务器性能的提升 在硬件升级的同时 往往也需要调整相关的配置 让硬件升级的优势得到极大的发挥 笔者认为 有时候服务配置比纯粹的硬件升级更加重要 一些经验不足的网络管理人员只知道升级硬件 而忽视了服务的调整配置 他们这是走进了一个死胡同 效果往往不能够达到他们的预期

二是一些并发性比较大的应用服务器 最好不要放在同一个服务器上 现在企业基于服务器 客户端模式的管理软件应用越来越多 这种模式一个显著的特点 就是并发性访问比较频繁 给应用服务器带来了很大的压力 在一些性能要求比较高的企业 它们把数据库与前台的应用程序服务器都分开放置 以求优化服务器的性能 而且 现在服务器价格已经逐渐能够被企业所接受 笔者认为 企业没有必要在这方面省钱 若多个应用服务并发性访问比较多的情况下 则最好考虑把他们部署在不同的服务器上 以提高各个应用服务的性能

lishixinzhi/Article/program/SQLServer/201311/22435

服务器是一种高性能计算机,作为网络的节点,存储、处理网络上80%的数据、信息,因此也被称为网络的灵魂。也可以这样讲,服务器指一个管理资源并为用户提供服务的计算机软件,通常分为文件服务器、数据库服务器和应用程序服务器。运行以上软件的计算机或计算机系统也被称为服务器。相对于普通PC来说,服务器在稳定性、安全性、性能等方面都要求更高,因此CPU、芯片组、内存、磁盘系统、网络等硬件和普通计算机有所不同,在质量与处理器数据性能上更出色。
我们也可以讲服务器称之为电脑,只是服务器对稳定性与安全性以及处理器数据能力有更高要求,比如我们每天浏览一个网站,发现这个网站每天24小时都能访问,为什么呢,原因在于网站服务器不能关闭,要保证长时间稳定运行,并且要承受很多人同时访问,因此服务器在稳定性、质量以及性能方面要比普通电脑有更苛刻要求。比如我们电脑如果一年四季不关机,可能很容易坏掉,但针对个人计算机,不可能这样做,因此电脑硬件的设计要求相比服务器要低不少。因此我们可以这样理解,其实服务器就是比我们一般电脑更高级的电脑,再各个硬件上拥有更高标准的做工,服务器内部硬件和一般电脑一样,均是由CPU、内存、主板、显卡、硬盘等组成,不过需要注意的是,服务器由于偏向处理器处理器数据能力,因此很多服务器主板均可以安装多个处理器、多条内存以及更多硬盘,因此看起主板、机箱等均比较庞大,最后服务器由于对于显示性能不是很重要,很多服务器都不需要显示器,远程管理即可,因此一般服务器均使用的是集成显卡。

共用一个服务器是可以的

只要是多个微信小程序所需要的环境是一样的,在服务器中统一配置就可以的。

至于想共享域名的话,域名是有二级及以上域名的,不同的小程序或者是页面用二级域名就可以的。

理论上实现不是问题,但是具体的 *** 作要看您的技术 *** 作。还有就是根据你的小程序选择一个适合配置的服务器租用,要稳定的,要不然机器崩溃,数据损毁会很麻烦的。


欢迎分享,转载请注明来源:内存溢出

原文地址: https://outofmemory.cn/zz/13473561.html

(0)
打赏 微信扫一扫 微信扫一扫 支付宝扫一扫 支付宝扫一扫
上一篇 2023-08-14
下一篇 2023-08-14

发表评论

登录后才能评论

评论列表(0条)

保存