前言: 話說前陣子爸爸家陽台不斷出現米奇老鼠,立刻清理陽台所有東西,然後又跟市政部門反映問題,可是情況還沒有好轉,米老鼠來完一隻又一隻,我爸陽台在老鼠界應該是網紅打卡聖地(誤),要不然就是米奇老鼠版米奇林三星餐廳(?) 雖然我們抓到了三隻,到上兩個禮拜為止還有至少一隻一直抓不到,每天淩晨還會來吃事後煙留下老鼠屎,真_北。 這隻老鼠對傳統攻擊有抗性,有IT9朋友前陣子用Raspberry pi自製了一台electric mouse trap ,用pi的超聲波雷達放在鞋盒裡,鞋盒裡有一堆食物,底部佈了鐵網,偵測到有老鼠進去以後立即關門通9V電,通個1分鐘再放牠離開,大推我自己也造一台 (Youtube片搜尋一大堆,人類真變態啊,朋友好變態啊)。可是我覺得這樣又好像有點太殘忍,不如先偵測牠們什麼時候來,嚇嚇牠們看看有沒有效果再說吧。 目的: 用Raspberry pi及手上有的感測器弄一隻放陽台用來偵測和嚇嚇老鼠的東西,並把紀錄圖像化到雲端給老爸使用。 邏輯及設計: 當老鼠進入偵測範圍,Motion Sensor偵測到生物活動Raspberry pi 處理來自Motion Sensor的訊號,如果夠強的話開始準備作出回應 Raspberry pi在Angry cats sounds中隨機選出叫聲,再經由Speaker輸出貓叫聲 Raspberry pi指示強光元件發出強光束照射目標 把偵測計數上傳到雲端圖表 材料: Sensor 在網路上看了一些Raspberry pi wild animal camera ,很多也是用Motion Sensor先偵測動物再來,我用的是PIR Motion Sensor被動式紅外線感測器,有低耗電成本便宜的好處。[1],而且可手動調整靈敏度及反應時間。 PIR Motion Sensor就是下面這個 圖片來源: learn.adafruit.com 可手動調整敏感度還有反應時間,這個有點不好調,要試好多遍才找到最佳位置。 可以在Raspbian中輸入pinout查詢GPIO避免插錯 圖片來源: learn.adafruit.com . 一台Raspberry pi 這次使用較舊的Raspberry pi model B+ 萬一老鼠生氣被咬爛錢包也不太痛 . ...
背景:
公司最近把一套每天有相對大量交易(之前公司更大很多很多倍)的系統轉移到SQL Server去,不到一個月交易檔(ldf)已經貼近數據檔(mdf)的size,真的好可怕啊。
公司最近把一套每天有相對大量交易
身為SQL Server的DBA當然 要替月行道,警惡懲奸 不能讓這種情況繼續下去。
解決方案選擇:
- 第一個我想到的方法是把Database的Recovery model設成Simple,簡單來說就是不需要交易記錄,對於Insert Delete Update 很少的系統勉強還說得過去,不過對於交易量大的系統來說就不行了,沒有交易記錄萬一資料庫突然往生,總不能用full backup還原然後要User重新輸入一天的交易吧。
- 第二個方法是定時進行備份。為什麼log大小跟備份有關係呢? 簡單來說,資料庫的ldf檔就是用來儲存Full Backup後所發生的所有交易。如果你從今天從來沒有為資料庫進行過備份,理論上ldf檔會無限的膨脹下去,而且利用Shrink指令也無法把交易檔壓縮。因為沒備份的話就等於ldf檔裡面的東西統統有用,當然沒辦法壓縮了。所以要保持交易檔案的size就是要持續保持備份,在每次備份完了以後自動把交易檔Truncate成初始大小,這樣可以長期保持相對小的交易檔。
所以,最後我選擇了方案二。
實作流程考慮因素:
SQL Server的backup model一定要一份full backup再塔配其他備份檔一起使用(SQL Server的備份model解釋在此),要達到控制ldf檔案大小的目的,備份可以每天只是Full Backup,也可以是Full->T-log,也可以是最複雜Full->Diff->T-log,我考慮使用那一種的因素主要有以下:
實作流程考慮因素:
SQL Server的backup model一定要一份full backup再塔配其他備份檔一起使用(SQL Server的備份model解釋在此),要達到控制ldf檔案大小的目的,備份可以每天只是Full Backup,也可以是Full->T-log,也可以是最複雜Full->Diff->T-log,我考慮使用那一種的因素主要有以下:
- 資料庫本身只是約55GB不是太大;
- 每天交易量不多,每分鐘約10筆交易;
- 使用者允許少量的data loss,一天Data loss肯定不行;
- 資料庫只是辦公時間才會用。
實現步驟:
好吧,根據之前實作流程的結論動手做看看吧。要自動化整個備份工作,SQL Server 2008以後有一個很好用的工具叫Maintainence Plan,可以把需要routie的日常維護的工作放到這裡。
好吧,根據之前實作流程的結論動手做看看吧。要自動化整個備份工作,SQL Server 2008以後有一個很好用的工具叫Maintainence Plan,可以把需要routie的日常維護的工作放到這裡。
- 首先用有sysadmin權限的帳號登入,然後到Management-> Maintenance Plan按右鍵-> New Maintainance Plan
- 輸入Maintenance Plan的名字,例如 XXX Server Backup Plan,按OK。
- 接下來會看到一個空白的Maintenance Plan,如上面所述我們需要每天Full Backup一次,然後每小時來一個T-log的備份,所以Maintenance Plan裡應該有兩項的Subplan,一個是負責Full Backup,另一個是負責T-log Backup。
- 先設定Full Backup。先點一下選取Subplan_1,然後在左邊的Toolbox欄拉出一個Back up Database Task,在拉出的Backup元件中按右鍵-> Edit
- 備份的位置按公司的規定,小弟公司習慣放回資料庫裡。Compression選項就要看實際情況了,我習慣把備份壓縮,因為小弟公司不是24小時運作,淩晨的時候資料庫反正也很閒,省個空間也不錯....不過要記得如果Full Backup是選擇壓縮的話,Diff或者T-log備份一定要一樣選擇壓縮,不然的話小弟試過最後合不起來,然後....(下刪一萬字悲情文)
- 接下來是設定Full Backup的運作時間,按一下Sub_plan1右邊的小icon,進入到Properties畫面。
- 回憶一下,我們的Full backup是每天non Office Hour一次。所以Schedule type選擇Recurring,Frequency選擇Daily,時間設在每天淩晨12點然後按OK,如下圖。
- 設好FullBackup了以後重覆步驟設定T-Log備份。開一個新的Subplan,設好每小時跑一次,要比較注意的是BackUp Database Task中BackUp Type要選Transaction Log、If backup files exist選Append。為什麼是Append呢? 因為像我這個案例是每小時備份一次,如果每次也Overwrite的話T-log的備份永遠只有最近的那一小時,結果當然是T-log備份無法跟Full backup結合在一起,因為根本就不完整啊(哀)~!!!,不過話說回來,如果純是為了壓縮ldf檔的話選擇Overwrite也是OK的,不過小弟要弄的資料庫一小時才幾MB T-Log,幹嘛不順便備份一下呢? 最後記得要多新增一個Maintenance Cleanup Task每天把這個T-log刪掉,不然這個T-log的備份也會
像通膨一樣無限的變大
- 全部設好以後按save. Plan就會按你定的時間開始跑了,確定你的備份有按時進行並且無誤(可以把Full Backup及T-log backup 還原到testing environment看看)以後,可以為database進行Shrink動作,T-log應該會回到原始大小了。定時監控一下ldf檔案應該不會再發現爆大的情況了...
總結:
T-log ldf檔案過大除了浪費空間,還會直接影響系統的效能(想像一下每次要把資料寫進十幾GB的檔案),所以定時清理是必須的,可透過定時的備份把沒用的T-log清理掉,來保持T-log ldf檔不會無限制的過度膨脹。
如發現小弟任何觀念錯了歡迎提出喔^口^
OhaebiXber_ge Sherard Linson https://wakelet.com/wake/f-ZDFmqVZRcGhVAmJhsM_
ReplyDeletelandlogavi
elfiZpuncha-Lafayette Annette Daigle https://www.msmconsult.com.br/profile/Il-Ballo-Irene-Nemirovsky-Pdf-Download-BETTER/profile
ReplyDeleteramilosa
YinnoKneuni Ean Cummings There
ReplyDeleteUnHackMe
Movavi Video Editor
studunansu
gemi0hi_yu Joe Bonsness
ReplyDeleteThis is there
icdedere