史林楓:sqlserver資料庫中數據日誌的壓縮及sqlserver占用記憶體管理設置

来源:http://www.cnblogs.com/jayshsoft/archive/2016/10/25/5997950.html
-Advertisement-
Play Games

使用sqlserver和IIS開發.net B/S程式時,數據量逐漸增多,用戶也逐漸增多,那麼伺服器的穩定性就需要維護了。資料庫如何占用更小記憶體,無用的日誌如何瞬間清空? ...


使用sqlserver和IIS開發.net B/S程式時,數據量逐漸增多,用戶也逐漸增多,那麼伺服器的穩定性就需要維護了。資料庫如何占用更小記憶體,無用的日誌如何瞬間清空?

 

今天在給一個客戶維護網站的時候,發現運行了2年的程式,資料庫中主表的數據已超過70萬條,按理說這樣的數據量根本不算多。資料庫是Sqlserver2012版本,伺服器是Windows Server 2008。

在遠程連接過程中,IIS和sqlserver總是打開一會兒自動閃退,打開任務管理器,發現IIS進程占用幾百MB記憶體,資料庫進程占用了將近600M記憶體。為了讓伺服器穩定運行IIS和sqlserver 我強制重啟了伺服器。

重啟後,發現資料庫和IIS都能正常打開使用了。資料庫的日誌文件已經有2個多GB,數據文件不到200MB。於是開始清空資料庫日誌:

需要用以下命令:

1 ALTER DATABASE [資料庫名稱]  SET RECOVERY SIMPLE -- 更改為簡單模式
2 
3 DBCC SHRINKDATABASE([資料庫名稱])  --壓縮資料庫命令
4 
5 ALTER DATABASE [資料庫名稱] SET RECOVERY FULL  --恢復為完全模式

先將資料庫改為簡單模式,再壓縮資料庫,最後恢復完全模式即可。這樣資料庫就回收了一部分空間,並清空了日誌,只保留了必要的數據。

另外,資料庫占用的記憶體是可以調控的,這裡說一下可視化界面的調控

第一步:打開資料庫 連接後  如圖操作 右鍵選擇屬性

 

選擇“記憶體”管理 

 

 

調整最大記憶體,即可。這樣就可以限制資料庫占用的記憶體了。當然,這隻是臨時做法,真正優化資料庫記憶體還有很多方法,如分庫,分表,讀寫分離,程式優化,sql語句優化等。

關於IIS的記憶體占用過大,這裡就只能優化程式了,某些演算法的升級,請求次數的減少都可以幫助優化IIS所占用的記憶體。

 


您的分享是我們最大的動力!

-Advertisement-
Play Games
更多相關文章
  • 以前寫了篇SQL SERVER 2008資料庫各版本功能對比,官網提供的那個功能確實很好很強大,後面發現那個鏈接失效了。今天又遇到要對比SQL Server 2014資料庫版本功能需求,搜索找了好久才找到,索性將這些鏈接收錄在此,以備不時之需。 SQL Server 2008https://tech... ...
  • Hadoop集群搭建安裝過程(三)(圖文詳解 盡情點擊!!!) 一、JDK的安裝 安裝位置都在同一位置(/usr/tools/jdk1.8.0_73) jdk的安裝在克隆三台機器的時候可以提前安裝,通過scp使安裝文件和環境配置(/etc/profile)都拷貝過去,並使三台機 器都通過(sourc ...
  • 對於大神來說,不看都知道,但是對於和我一樣的菜鳥,就需要解釋一下了。 a,b是數據表名稱,c,d,e,f是數據。而c,d,e,f這些數據不一定非得來自b表,可以來自left join,right join和內連接查詢出來的結果 個人覺得使用起來還是比較方便的。 1 SELECT c,d,e FROM ...
  • 業務運行一段時間,發現原來的主鍵設置並不合理,這個時候,想變更主鍵。這種需求在實際生產中還是蠻多的。 下麵,看看pt-online-schema-change解決這類問題的處理方式。 首先,創建一張測試表 create table t2(c1 int primary key, c2 int); 構造 ...
  • 在開髮網站時,我們需要對用戶註冊的郵箱進行核對與驗證,用戶填寫的郵箱是否有效郵箱。好吧,我們先從資料庫入手,修改用戶表讓用戶有填寫email的欄位,添加了2個欄位: ALTER TABLE [dbo].[Users] ADD [Email] VARCHAR(100) NULL, [IsVerify] ...
  • ORA-00001: 違反唯一約束條件 (.) ORA-00017: 請求會話以設置跟蹤事件 ORA-00018: 超出最大會話數 ORA-00019: 超出最大會話許可數 ORA-00020: 超出最大進程數 () ORA-00021: 會話附屬於其它某些進程;無法轉換會話 ORA-00022:  ...
  • Hadoop集群搭建(一)(上篇中講到了Linux虛擬機的安裝) 一、安裝所需插件(以hadoop2.6.4為例,如果需要可以到官方網站進行下載:http://hadoop.apache.org) hadoop2.6.4插件、已經裝好的虛擬機(CentOS,這個百度一下自行安裝)、虛擬機安裝後將其克 ...
  • 配置Spark standalone HA 主機:node1,node2,node3 master: node1,node2 slave:node2,node3 修改配置文件: node1,node3: spark-env.sh node2: spark-env.sh node2與node1的差別僅 ...
一周排行
    -Advertisement-
    Play Games
  • 示例項目結構 在 Visual Studio 中創建一個 WinForms 應用程式後,項目結構如下所示: MyWinFormsApp/ │ ├───Properties/ │ └───Settings.settings │ ├───bin/ │ ├───Debug/ │ └───Release/ ...
  • [STAThread] 特性用於需要與 COM 組件交互的應用程式,尤其是依賴單線程模型(如 Windows Forms 應用程式)的組件。在 STA 模式下,線程擁有自己的消息迴圈,這對於處理用戶界面和某些 COM 組件是必要的。 [STAThread] static void Main(stri ...
  • 在WinForm中使用全局異常捕獲處理 在WinForm應用程式中,全局異常捕獲是確保程式穩定性的關鍵。通過在Program類的Main方法中設置全局異常處理,可以有效地捕獲並處理未預見的異常,從而避免程式崩潰。 註冊全局異常事件 [STAThread] static void Main() { / ...
  • 前言 給大家推薦一款開源的 Winform 控制項庫,可以幫助我們開發更加美觀、漂亮的 WinForm 界面。 項目介紹 SunnyUI.NET 是一個基於 .NET Framework 4.0+、.NET 6、.NET 7 和 .NET 8 的 WinForm 開源控制項庫,同時也提供了工具類庫、擴展 ...
  • 說明 該文章是屬於OverallAuth2.0系列文章,每周更新一篇該系列文章(從0到1完成系統開發)。 該系統文章,我會儘量說的非常詳細,做到不管新手、老手都能看懂。 說明:OverallAuth2.0 是一個簡單、易懂、功能強大的許可權+可視化流程管理系統。 有興趣的朋友,請關註我吧(*^▽^*) ...
  • 一、下載安裝 1.下載git 必須先下載並安裝git,再TortoiseGit下載安裝 git安裝參考教程:https://blog.csdn.net/mukes/article/details/115693833 2.TortoiseGit下載與安裝 TortoiseGit,Git客戶端,32/6 ...
  • 前言 在項目開發過程中,理解數據結構和演算法如同掌握蓋房子的秘訣。演算法不僅能幫助我們編寫高效、優質的代碼,還能解決項目中遇到的各種難題。 給大家推薦一個支持C#的開源免費、新手友好的數據結構與演算法入門教程:Hello演算法。 項目介紹 《Hello Algo》是一本開源免費、新手友好的數據結構與演算法入門 ...
  • 1.生成單個Proto.bat內容 @rem Copyright 2016, Google Inc. @rem All rights reserved. @rem @rem Redistribution and use in source and binary forms, with or with ...
  • 一:背景 1. 講故事 前段時間有位朋友找到我,說他的窗體程式在客戶這邊出現了卡死,讓我幫忙看下怎麼回事?dump也生成了,既然有dump了那就上 windbg 分析吧。 二:WinDbg 分析 1. 為什麼會卡死 窗體程式的卡死,入口門檻很低,後續往下分析就不一定了,不管怎麼說先用 !clrsta ...
  • 前言 人工智慧時代,人臉識別技術已成為安全驗證、身份識別和用戶交互的關鍵工具。 給大家推薦一款.NET 開源提供了強大的人臉識別 API,工具不僅易於集成,還具備高效處理能力。 本文將介紹一款如何利用這些API,為我們的項目添加智能識別的亮點。 項目介紹 GitHub 上擁有 1.2k 星標的 C# ...