Database|【sql】sqlserver因设置最大内存(256)过小导致无法启动的修复

场景 因为有需求需要把当前sqlserver的使用内存降下来,但是不方便重启sqlserver服务,所以就从网上查找如何释放内存。看到很多文章都是坑爹的把最大内存设置为256,然后再设置成一个最大值的思路。魔性代码如下:

CREATE proc [dbo].reclaimmemory--强制释放内存 as begin DBCC FREEPROCCACHE DBCC FREESESSIONCACHE DBCC FREESYSTEMCACHE('All') DBCC DROPCLEANBUFFERS exec sp_configure 'max server memory', 256 EXEC ('RECONFIGURE' ) WAITFOR DELAY '00:00:05' EXECsp_configure 'max server memory', 2147483647 EXEC ('RECONFIGURE' ) GO

执行这段代码后,sqlserver的服务就崩溃了,根本无法重新启动。看到的解释是因为设置最大内存过小导致无法运行起来。我当时的运行报错也差不多,似乎是设置成256后没能功能设置成更大的最大内存。执行失败后,整个服务就处于宕机状态。
解决方案 查了些资料,都是从cmd启动个最精简版的sqlserver服务,然后在上面执行设置代码,最后重启成功。
http://www.7kb.org/1048.html
https://blog.csdn.net/foreveryangting/article/details/79076682
http://www.mamicode.com/info-detail-1910981.html
我使用的是第三个。找个sqlservr.exe的目录,启动cmd,并执行命令:
sqlservr.exe -sMSSQLSERVER -mSQLCMD –c -f -m

【Database|【sql】sqlserver因设置最大内存(256)过小导致无法启动的修复】Database|【sql】sqlserver因设置最大内存(256)过小导致无法启动的修复
文章图片

这里我不太能理解-mSQLCMD的实际意义,觉得应该用处不大。不过我的bug已经解决了,也就没有办法尝试。
然后再开一个cmd窗口,执行sqlcmd -E -S IP\<实例名>
成功登录后就可以运行重新设置最大内存的代码了。我使用的代码如下:
sp_configure 'show advanced options', 1; GO RECONFIGURE; GO sp_configure 'max server memory', 最大内存数; GO RECONFIGURE; GO

成功运行后,关闭所有窗口,重新启动sqlserver服务即可。

    推荐阅读