SQL Server on Linux之主體環境設定

本篇介紹SQL Server on Linux主體環境的設定,當我們安裝好mssql-server、mssql-tools等套件,也使用"/opt/mssql/bin/mssql-conf setup"指令來安裝、設定及啟動mssql-server服務後,後續可能還需要異動一些設定,如:啟動Agent Service服務、修改預設的備份路徑、變更SQL Server版本等,此時有三種方式可以參考 -- 使用參數指令、使用參數設定檔、使用環境變數

...繼續閱讀 »

SQL Server on Linux之Database Mail設定及測試(使用postfix套件設定Mail Server)

在本篇介紹SQL Server on Linux的Database Mail設定,其實設定方式跟在Windows的版本差不多,只是這裡將自行額外安裝postfix套件來設定Mail Server,擔任MTA(Mail Transfer Agent)的角色,並嘗試設定兩種郵件設定檔(Profile),即"公開性質"跟"私人性質"兩種,另外,將在sqllnx1及sqllnx2分別使用【UI介面】及【T-SQL】兩種方式分別建置Database Mail。

...繼續閱讀 »

永久保存Container中SQL Server資料庫檔案的方式

在前一篇【在容器中備份及還原SQL Server資料庫,以及資料磁碟區容器(Docker Volume)的初步應用】有提到利用Docker Volume來保存container上所儲存的SQL Server資料及檔案,這是由於image只是一個檔案,不是程序,裡面封裝了要產生容器時的所有層層資訊,且image只能唯讀;而container不太一樣,container依據image產生,一個image可以建立多個container,很像程式中[class(類別)]與[object(物件)]的關係,但container是可以讀/寫的,所以container一旦被刪除,裡面的資料也會跟著消失,所以才會需要利用Docker Volume來保存資料。本篇將介紹兩種保存SQL Server資料庫檔案的方式,最後亦嘗試搭配MSSQL_DATA_DIR環境變數來變更容器中SQL Server的"預設資料目錄"(即 /var/opt/mssql/data)。

...繼續閱讀 »

資料分頁(Data Page)中的剩餘空間(m_freeCnt)是如何計算出來的?

常常聽說,也常常看到書上這樣寫,一個Page有8K,即8192 Bytes,而能夠用來儲存資料的空間為8060 Bytes,這是因為必須扣除Page Header占用的96 Bytes,以及Page尾端的Row Offset所保留使用的36 Bytes(此數據可能會因record的數量而有所變動),所以8192 Bytes - 96 Bytes - 36 Bytes=8060  Bytes,一個簡單Page Structure的示意圖如下:

...繼續閱讀 »

透過備份及還原資料庫來初始化交易式複寫的訂閱

 一般透過複寫精靈來設定交易式複寫時,都會選擇透過快照集代理程式(Snapshot Agent)來產出快照,然後藉由散發代理程式(Distribution Agent)來初始化訂閱的資料,這種方式確實是方便省事,而且當你產出快照集到訂閱被新增,這中間的資料異動,交易式複寫機制都會自動幫你補上去,然而當要複寫的資料量大到上百GB,甚至是TB時,同步資料到訂閱者所耗費的時間將會相當長,更遑論如果是跨國同步資料的情境。

...繼續閱讀 »

交易式複寫若常常執行大量資料的更新,用預存程序處理或許也是另一個可以考慮的選項

拜讀了楊志強老師在FB上的一篇文章【管理 Life Saver 】之 【拯救交易式複寫問題之未遞送大量交易20170311】,老師使用了(1)關閉Log Reader讓Distributor先遞送,以及(2)調高遞送量這兩個步驟,漂亮的解決了大量交易所造成的複寫堵車問題,心想若複寫能搭配使用預存程序來更新大量資料的話,能否改善此類問題?

...繼續閱讀 »