场景 因为有需求需要把当前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我使用的是第三个。找个sqlservr.exe的目录,启动cmd,并执行命令:
https://blog.csdn.net/foreveryangting/article/details/79076682
http://www.mamicode.com/info-detail-1910981.html
sqlservr.exe -sMSSQLSERVER -mSQLCMD –c -f -m
【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服务即可。
推荐阅读
- 数据库|SQL行转列方式优化查询性能实践
- SQL|SQL基本功(五)--函数、谓词、CASE表达式
- SQL|SQL基本功(三)-- 聚合与排序
- 数据库|数据库并发操作的一致性问题
- Database|mongodb
- MySQL|MySQL命令行创建用户与授权
- mysql my.cnf 配置建议
- H2|H2数据库使用
- 完全卸载Microsoft SQL Server 2005软件,解决多次安装软件失败问题