內存中OLTP與內存不足

我已經寫了好幾回內存中OLTP的文章和」爲何我還不推薦內存中OLTP給用戶」。今天我想進一步談下內存中OLTP背後的內存需求,還有若是你內存不夠的話會發生什麼。sql

一切都與內存有關!

咱們都知道好久以前有個名人說過對於任何人,640K的內存應該足夠了。他錯了!對於內存中OLTP,內存需求很是高:數據庫

  • 哈希索引的每一個哈希桶由64位長的指針組成
  • 每次你修改/刪除一條記錄,新版本的寫入在內存中存儲。

微軟建議內存至少是你內存優化表的2倍。當你修改或刪除記錄時,這個兩倍數量的空間是用作可能的行版本存儲。瀏覽器

幾個星期前,有人問我一個很是有趣的問題:當你沒有足夠的內存,在數據庫啓動期間內存中OLTP不能重建哈希索引會發生什麼?這哥聽起來像很是簡單的問題,但在這個特定場景裏知道內存中OLTP如何反應很是重要。less

假設你在虛擬機裏運行內存中OLTP,在某個時候你的虛擬機管理員給你的虛擬機比以前更少的內存。在虛擬化結合中,我常常看到這個。優化

讓咱們玩壞內存中OLTP!

咱們來模擬這樣的情景。在第一步,我想向你展現下,當你建立了內存優化表,你沒有足夠的可用物理內存,會發生什麼。下列代碼建立有4個哈希索引的新的內存優化表,每一個哈希索引包含250百萬的哈希桶。所以對這個整個表須要近7.4GB的內存,但我運行的虛擬機只有8G的內存。
this

-- 250 000 000 x 4 =  1 000 000 000 Hash Buckets of 8 bytes: 8 000 000 000 = 7.4 GB of memory overhead.
-- The following query will fail, because there is too less memory available.
CREATE TABLE Foo
(
    Col1 INT NOT NULL PRIMARY KEY NONCLUSTERED HASH WITH (BUCKET_COUNT = 250000000),
    Col2 INT NOT NULL INDEX idx_Col2 NONCLUSTERED HASH WITH (BUCKET_COUNT = 250000000),
    Col3 INT NOT NULL INDEX idx_Col3 NONCLUSTERED HASH WITH (BUCKET_COUNT = 250000000),
    Col4 INT NOT NULL INDEX idx_Col4 NONCLUSTERED HASH WITH (BUCKET_COUNT = 250000000)
)
WITH
(
    MEMORY_OPTIMIZED = ON, 
    DURABILITY = SCHEMA_AND_DATA
)
GO

幾秒後,CREATE TABLE語句失敗,內存中OLTP給你一個漂亮的錯誤信息:你有太少的可用內存。spa

Msg 701, Level 17, State 137, Line 43 There is insufficient system memory in resource pool ‘default’ to run this query.設計

到目前還好。讓咱們從新設計表,只須要3.7G內存:指針

 1 -- 250 000 000 x 2 = 500 000 000 Hash Buckets of 8 bytes: 4 000 000 000 = 3.7 GB of memory overhead.
 2 -- The following query will fail, because there is too less memory available.
 3 CREATE TABLE Foo
 4 (
 5     Col1 INT NOT NULL PRIMARY KEY NONCLUSTERED HASH WITH (BUCKET_COUNT = 250000000),
 6     Col2 INT NOT NULL INDEX idx_Col2 NONCLUSTERED HASH WITH (BUCKET_COUNT = 250000000)
 7 )
 8 WITH
 9 (
10     MEMORY_OPTIMIZED = ON, 
11     DURABILITY = SCHEMA_AND_DATA
12 )
13 GO

此次表建立成功,由於我有足夠的可用內存。如今我使壞,關掉虛擬機。我配置它只有3G的內存:日誌

如今當咱們重啓虛擬機和SQL Server,你認爲會發什麼?你以爲SQL Server能夠把咱們數據庫恢復在線麼?或者你認爲只有主文件組(PRIMARY file group)恢復在線,內存中文件組(In-Memory file group)仍是離線?咱們來試下!

重啓後,當你在SSMS裏查看對象瀏覽器,你能夠看到咱們「整個」數據庫在恢復待定狀態(Recovery Pending)!

這真的真的太糟糕了,由於你不能訪問你的任何數據庫!即便基於傳統硬盤的表也不能訪問!當你查看SQL Server日誌,你也會看到SQL Server給你有太少可用內存的錯誤信息:

偶滴神哪,咱們已經玩壞內存中OLTP……

小結

我知道模擬的狀況很是少見,但我說過,當虛擬機管理員只從虛擬機裏拿走內存時,這個狀況很常見。與內存中OPTP結合,這就意味着你的整個數據庫不可訪問!

當你在基於內存中OLTP部署數據庫時,請記住這個。你要認真考慮你的內存需求,你也要按需調整你的將來可用內存。

感謝關注!

原文連接:

http://www.sqlpassion.at/archive/2016/05/31/in-memory-oltp-and-too-less-memory/

相關文章
相關標籤/搜索