Skip to main content

Posts

Showing posts from 2013

[Raspberry pi] 陽台的老鼠偵測器

前言: 話說前陣子爸爸家陽台不斷出現米奇老鼠,立刻清理陽台所有東西,然後又跟市政部門反映問題,可是情況還沒有好轉,米老鼠來完一隻又一隻,我爸陽台在老鼠界應該是網紅打卡聖地(誤),要不然就是米奇老鼠版米奇林三星餐廳(?) 雖然我們抓到了三隻,到上兩個禮拜為止還有至少一隻一直抓不到,每天淩晨還會來吃事後煙留下老鼠屎,真_北。 這隻老鼠對傳統攻擊有抗性,有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+ 萬一老鼠生氣被咬爛錢包也不太痛 . ...

[趨勢] 部落格的未來

最近部落格界最震驚的消息, 應該是YAHOO不再經營部落格了. 首當其衝當然是陪伴我大學生活的無名從此變成回憶了. 其實不用什麼數據支持也知道, 這幾年部落格的市場真的給臉書類的社交媒體狠狠的吃了一大塊. 那嚴重程度呢? 從Google Trend中的數據可以略知一二: 以下是華人地區關於部落格關鍵字熱門度的變化 接下來看看環球的變化又是怎樣 最後再看看facebook的熱門變化 這可以說明: 部落格在2009年以後開始出現負增長, 而且走趨越來越強烈. Facebook在2009年剛剛好出現了顯注的關注程度, 而同年facebook總體使用人數也錄得 很高的增長 . 壓跨帝國的最後一根稻草? 社交網站很多時候強調即時性跟速食性, 即時性絕對跟智慧型手機有很大的關係. 第一支android1.1係業系統誕生於2009年的2月 [1] , 同時iphone的銷售也比同期出現大量的增長. 引用來源 由於寫部落格動不動就兩三百字, 加上插圖修修版面的工作量, 寫部落格其實是一項很費時而且不能anytime也能完成的工作. 要寫得通情達理至少要先找個咖啡廳舒舒服服的坐一下陪養一下心情再慢慢呆個五分鐘才開始寫得出來. 智慧型手機的海量資訊每天佔據人們大量時間, 有毅力寫堅持下去的人就更少了. 另外, 微博, 微訊, 微電影, 微廣告, 在這個強調速度的微世界, 在社交網站只要簡短幾個字, 拍幾張照片, 不需要想題目, 吃飯拉(---靜音)只要你喜歡就行, 隨時隨地不用一分鐘就能分享給所有朋友, 然後快速的獲得大量掌聲與鼔勵 前題你是正妹 , 正好適合年青人懶得寫文章的口味, 同時的確也是部落格難以達到的優點. 由於部落格先天的缺點, 只要有更方便的工具出現的話, 跨倒是早晚的事, 也許facebook只是幫一把而已. 老兵不死, 只是.... 我覺得部落格並不會消失, 正如facebook並沒有取代討論區一樣. 不過也需會變成.... 專業化: 部落格的文章開始變成是針對某一專業領域的內容, 而不是無聊哈啦的好地方, 如 inside , TechCrunch, 當然還有小弟的1010啦 (毆飛). 畢竟天下所有東西不是用三言兩語就能解釋清楚的. ...

[SQL Server]Linked Servers中的login mappings問題

話說前陣子同事打算利用SQL Server 內我已經設定好的Linked Server更新AS400的資料表(table). 出現不能更新的錯誤. 發現原來設漏了東西....囧. 以連接AS400為例子, 如果有大大跟我一樣是用ODBC做連結, 並且在AS400那邊有獨立登入名稱跟密碼的話. 當連結完了以後還要進行user mapping的動作, 否則可能會因為權限不夠更新不到. 在設定之前要先考慮這個Linked Server是否給全部SQL SERVER的使用者使用, 還是只是某些使用者才有權限進行存取. 如果Linked Server打算只開放給某些使用者存取的話: 首先選擇目標的Linked Server, 按右鍵-> "Properties" 轉到 "Security"頁面-> 按一下"Add", 在"Login Login"中選擇一個SQL Server的帳戶, 例如你打算從ABC資料庫存取Linked Server的話, 最好是使用ABC資料庫的使用者帳號. 然後在"Remote User"跟"Remote Password"中輸入AS400那邊的帳號跟密碼按OK. 如果你打算開放Linked Server給所有SQL SERVER的用戶存取的話: 首先還是跟上面一樣進入到Properties的畫面->Security的部分, 往下找到 "For a login not defined in the list above, connections will" 這一欄. 選擇 "Be made using this security context:" 輸入AS400中打算用來登入的名稱跟密碼然後"OK." 那麼所有SQL SERVER的使用者也可以存取AS400的資料庫囉...

[SQL Server] 關於發送電子郵件(email)例子

今天小弟需要在SQL Server 2008上建立一個每天定時執行的Jobs(作業), 而這個Job出現問題的時候會發出email告訴DBA. 由於公司的SQL Server並沒有設好mail server, 所以今天在網路上整理了一下資料, 分享給有需要的大大參考: 先設定DataBase Mail: funkent大的 SQL Server 無敵手冊第十三篇-設定SQL Server的Database Mail  講得很詳細, 小弟就不多說明了. 設好以後可以按"Send Test E-mail" 做下測試. 再來把DataBase Mail 連結到SQL Server Agent: funkent大的另一篇  SQL Server 無敵手冊第十四篇-設定SQL Server Agent使用Database Mail  也有很詳細的說明怎樣弄. 在SQL Agent底下建立Operator帳號: 同上也有介紹怎樣設定. 最後在作業(Job)中的Notifications頁面, 在e-mail中選擇剛剛建立的Operator. 完成. p.s:  funkent關於資料庫的文章寫得很不錯, 要用的幾乎都寫到了, 所有文章可以到這裡 看看

[SQL SERVER] 找出LOCK方法懶人包

話說休假回公司才不到兩天SQL SERVER就出狀況 Orz 昨天同事跟我說文件系統不能存取ID, 第一件事當然想到是存放ID的資料表LOCK住了. 要查出LOCK方法其實有很多, 以下是小弟歸納的網路資源, 希望幫到大家 什麼是LOCK? 德瑞克大的解釋很詳細:  http://sharedderrick.blogspot.com/2007/12/blocked-lock-connectoin.html sp_lock: 使你對系統中發生的LOCK有深入的了解。它會從master資料庫中的syslockinfo中截取與LOCK相關的大量訊息[1]. 不過我認為由於這個功能的資訊太多, 而且資料沒有好好的做sorting, 所以在危急關頭未必有閒去慢慢看. 在sp_lock會看到spid、dbid、objid、indid、type、resource、mode和status共八個欄位[2]. spid: 連線ID. 可配塔sp_who找出用那些用戶和該連線(spid)有關連. dbid: 資料庫的唯一編號 Objid: 資料表的唯一編號, 可用 select object_id('<table name>') 找到資料表相關Objid 其他的欄位可以在 這裡 找到相關意思. sp_who2 sp_who的加強版本. sp_who主要提供 Microsoft SQL Server Database Engine 執行個體中有關目前使用者、工作階段和處理序的資訊[3]。而sp_who2比較像是sp_who的view, 把sp_who的資料整理得比較好. 小弟經常用它來找出那台PC的發出的process產生了LOCK.  然後毆飛那個user 列出最初導致一連串其它處理序被鎖住的起始源頭(Blocking locks) 很多時候LOCK住的原因是其他的LOCK引發的, 要找出這種關係可以用下面網址的SQL 列出最初導致一連串其它處理序被鎖住的起始源頭 http://www.dotblogs.com.tw/karen0416/archive/2011/11/18/58623.aspx 或者是德瑞克大寫得好好用的SQL http://sharedderrick.blogspot.co...

[ASP.NET] GridView CRUD - 如何利用DetailsView新增Gridview資料?

前言: 承接小弟所分享的 Gridview顯示 , GridView更新資料 的兩篇文章, 最後剩下新增了 (謎之聲: 不是先分享新增然後修改刪除才對嗎). 假如要新增一筆公司資料應該要怎樣呢? 新增Gridview資料的部分比較簡單. 所以下部分是多字小圖喔(無誤) 方法: 先拉一個DetailsView出來, 按一下DetailsView-> SmartTag->Configure Data Source, 把Business Object指向XSD檔案內公司主資料表COMPANY, 按Next, 然後確定insert頁面已經連結相關statement, 按finish. 然後把不需要填寫的欄位刪除掉, 順便把foreign ID的欄位轉成TemplateField. 最後把foreign ID的欄位跟DropDownList綁定, 詳細做法如 這篇有說明

[ASP.NET] GridView CRUD - 如何修改被轉為顯示值的ID

前言: 上一篇提到 怎樣把原本在資料庫的foreign ID在presentation layer中轉為給人看的值. 這一次談一下小弟的經驗, 利用GridView去修改已經轉為顯示值的foreign ID. 例如現在需要像下圖一樣把ID為2的那筆資料的CategoryName從糖水鋪轉為其他 我需要提供可供選擇的DropDownList 方法: 先把CategoryName轉成TemplateField. 在Gridview上按一下SmartTag, 選取Edit Columns. 在Selected fields中選取CategoryName, 然後在右邊選"Convert this field into a TemplateField". 然後按OK. 再次在Gridview中按一下SmartTag, 選擇"Edit Template", 然後在Smart Tag中選擇CategoryName的EditItemTemplate. 把原來的TextBox刪除, 然後拉一個DropdownList, 一個ObjectDatasource進去. 先設定ObjectDatasourceCompanyType. 按一下smart tag, 然後選"Configure Data Source", 然後選取放置文字的資料表, 像我這裡在COMPANY_TYPE, 選好以後按finish. 把DropDownList連結到ObjectDataSourceCompanyType. 按一下DropDownList-> smartTag -> Choose Data Souce. 把要顯示值還有data field設好. 按OK. 把DropDownList綁定GridView上的Category ID, 即是告訴系統說我這個DropDownList的值其實就是Category ID. 在DropDowdList中-> SmartTag->Edit Databindings 在"Bindable properties"中選取"SelectedValue", 在右邊Bound to選取儲存Category ID的欄位...

[ASP.NET] GridView CRUD - 如何把ID轉為顯示的值

前言: 我想很多大大寫ASP.NET的時候也會遇到同樣的問題: 很多時候為了很多原因, 例如Data size, 速度, 不過度扁平化資料表等等, 在資料庫的設計上我們會進行normalization. 例如公司名稱用CompanyID取代, 然後把真實給人看的名字分割到另外一個Table. 因此當我們要把資料顯示在Presentation layer(就是使用者介面)的時候, 一定逃不過要把資料表JOIN起來. 傳統的做法是把JOIN好的SQL直接寫在SqlDataSource裡面. 這樣很方便是沒錯, 不過除了在維護上會很困難, 也違反了把Data access layer跟Presentation layer 盡量loosely coupled的原則. 不過好死不死, ASP.NET 的Gridview功能實在有點雞肋, 它不能像dropdownlist一樣可以選擇Display value. 我自己之前用的笨方法是先把只有值的table跟Gridview進行連結, 再寫一個class放在Data bounded的事件中把值換成顯示的值. 老實說真笨.... 前幾天又遇到了老問題, 我堅決不相信就是沒有解決方法, 查了MSDN老半天 終於守得雲開見月明, 柳暗花明又一.....(喂). 方法: 準備工作: 先用XSD檔案(Dataset)描述資料表, 例如公司資料表中的CATEGORY欄位對應顯示用資料表COMPANY_TYPE的COMPANY_TYPE_ID.  另外資料表中的TableAdapter使用最簡單的SQL STATEMENT, 例如資料表COMPANY使用的就是select * from COMPANY, 完成後應該會自動產生UPDATE, INSERT跟DELETE的指令. 接下來修改COMPANY資料表. 在COMPANY資料表上的TableAdapter按一下右鍵->Configure 把原來超簡單的sql換成下面這一句 好像很難, 說穿了其實只是在原本COMPANY資料表後面加上要願示的欄位而已. 改好了以後按NEXT NEXT NEXT到OK就可以了. 實作: 設定ObjectDataSource 首先反回aspx頁面, 抽一個ObjectDataSource叫Obj...

[Windows7] 跨距磁碟區, 等量磁碟區, 鏡像磁碟區之區別

話說前兩天用來備份的USB硬碟無緣無故去領便當了. 大幸的是我一直有好好備份, 資料至少存在兩顆硬碟上, 所以備份硬碟掛了損失也不大(錢包除外). 所以昨天下班以後趕緊去買一顆seagate的2TB內置硬碟回家(感覺USB硬碟還是不太安全), 裝好以後突然想到一個問題: 現在我桌機總共有5顆硬碟, 首先是剛買回來的2TB, 1顆80G SSD, 1顆640G, 1顆320G, 1顆160G. (真多舊硬碟囧), 關於硬碟的部分Windows 7比XP多了一些選項, 應該選那個才對? 讓我自己先分析一下: 那麼零碎的硬碟應該選擇合拼方案為主 關於合拼的方案Windows7有三大選項, 分別是 跨距磁碟區 ;  等量磁碟區;  鏡像磁碟區三種, 應該怎樣選呢? 說穿了那三種其實就是軟體的RAID方案, 硬要改一些好像很簡單又不簡單的中文字 . 其實: 跨距磁碟區 = JOBD,  就是簡單把幾顆硬碟變成一顆大的邏輯硬碟,  資料的存放機制是由第一顆硬碟開始依序往後存放,即作業系統看到的是一個大硬碟(由許多小硬碟組成的)。但如果硬碟損毀,則該顆硬碟上的所有資料將無法救回。若第一顆硬碟損壞,通常無法作救援(因為大部分檔案系統將磁碟分割表(partition table)‎存在磁碟前端,即第一顆)[1] 等量磁碟區 = RAID 0 把資料分散在幾顆硬碟, 存取的速度比較快, 不過壞一顆又是全部壞掉. 鏡像磁碟區 = RAID 1 顧明思義有兩份data, 超安全, 不過由於write的時候也要write兩份, 所以速度會慢. 更詳細的解釋 這裡 [2] 魚仔大有好好的解釋說明三種功能, 小弟就再不說了. 總結: 那我要怎麼辦? 最後我選擇的是.... 什麼都不做 , 80G的SSD留給OS及程式專用, 640G的用來放照片/動畫/影片/影像檔, 320G的用來放文件還有裝一些不重要的應用程式(遊戲啦,遊戲啦,還有一些遊戲之類的), 160G的用來裝音樂還有.......你懂的. 至於2TB的那顆就是當成上面所有硬碟的mirror, 用sync工具即時備份. 為 什 麼 ? 因為JORB不是不好, 不過把那幾顆舊硬碟變一顆有很大的風險, ...

[SQL Server] 移動資料庫檔案

有使用SQL SERVER的大大也知道SQL SERVER的資料庫其實只是一個檔案(感覺好虛). 最近公司要把資料庫檔案移到新硬碟, 寫下了一些T-SQL順便筆記一下步驟: 首先把要移動的資料庫離線(OFFLINE), 例如我的資料庫是dbABC ALTER DATABASE dbABC SET OFFLINE WITH ROLLBACK IMMEDIATE WITH ROLLBACK IMMEDIATE 跟據 這裡 的解釋是說把所有在跑的transaction全部ROLLBACK.   如果發現不行的話, 可以用下面的指令把佔用database的process殺掉: exec sp_who2 ( 把所有資料庫在跑的sessions列出來) kill <process_id> (幹掉它)   移動資料庫檔案及log file到新硬碟去: ALTER DATABASE GEE MODIFY FILE ( NAME = ABC , FILENAME = 'D:\dbABC.mdf') ALTER DATABASE GEE MODIFY FILE ( NAME = ABC_log , FILENAME = 'D:\dbABC_log.ldf')   重新啟動資料庫: ALTER DATABASE GEE SET ONLINE   喝淡定紅茶

[SQL Server] 利用Linked Server轉移大量數據到SQL Server之方法(以AS400為例)

[20140110] 新增OLE DB版本 上次提到當我們進行異質資料庫的資料轉移,使用SQL Server內建的工具經常會發生很多不明的錯誤(例如Column size太大)。那怎麼辦呢?總不可能把資料全部變成insert Statement吧?經過爬文以後小弟最後選用了SQL Server裡的Linked Server功能. 也成功轉移了超過2000萬筆資料的資料庫,雖然可能並不是好方法也希望對大家有幫助 :-) 什麼是SQL Server 的Linked Server? Linked Server (連結的伺服器) 根據 msdn的解釋 , 就是 "可讓 SQL Server Database Engine 對 SQL Server 執行個體外部的 OLE DB 資料來源執行命令。" 再說白一點, 就是可用T-SQL查詢其他品牌的資料庫。 來源資料特性: 資料在老舊的V5R4 AS400上. 很多資料表(Table)的欄位(Columns)很多,接近50個欄位以上。 欄位的size很大, 長度達3000或以上, 而且因為是char的關係就算改成varchar也沒用. 資料量大, 很多Table超過200萬筆. 準備工作: 由於這次使用的是AS400的ODBC或OLE DB, 所以在SQL Server端一定要先安裝IBM iSeries Client Access. 在SQL Server中先建立一空的資料庫 需要有SQL Server SA權限的帳號 動手做: 建立Linked Server 打開SQL Server Management  Studio, 登入後到Server Objects->Linked Servers->按右鍵新增Linked Server 如果你用的是ODBC 在"Linked Server"中填入此Linked Server的名字, 任意也OK, 由於這次對象是AS400, Server type要選擇Other data source, 由於這次使用的是ODBC connection, 所以Provider一欄要選擇 "Microsoft OLE DB Provider for ODBC Drivers...

[AS400] 小量數據轉移數據到SQL Server之方法 (2013/07/11更新)

這幾天要幫公司把data從老舊的AS400轉移到SQL Server上面去。 由於之前沒有任何經驗所以先問一下古哥。 很多大大也是使用SQL Server內建的Import Export Wizard。 以下是我利用odbc的方法成功移轉的經驗,未必是最好不過希望給大家參考一下。 準備工作: 先在目的SQL Server建立一空的資料庫, 例如"AS400" 由於我用的是ODBC,所以目的地端的SQL SERVER一定要先設好IBM的Client Access,我的版本是V5R4M0。最後要設好連接到成功連接到AS400的ODBC連接字串。 另外檢查一下Client Access中有沒有設定使用者名稱,不然等一下會連不到喔。 在ODBC資料來源管理員中選擇AS400的連接,按"設定" 在"General"頁面中按"Connection Options" 在"Use the user ID specified below"中輸入登入名稱,按"OK" 步驟: 在剛剛建立的空資料庫按右鍵-> Tasks-> Import Data,彈出匯入和匯出精靈後按下一步。 接下來是 "選擇資料來源" 頁面: 資料來源選擇".Net Framework Data Provider for Odbc" Dsn填寫ODBC中連接AS400的字串名稱,如我的ODBC字串是AS400ODBC,填寫的就是這個名稱。並不是Dsn=AS400ODBC;uid=terence 這種喔。 填寫完以後按下一步。 如果連接成功會來到"選擇目的地"頁面,不然就會出現謎一樣的錯誤,小弟試過的錯誤包括: DSN格式錯誤 在Client Access中沒有指定使用者名稱。 在選擇目的地畫面設好目的地的資料庫,如我目的地的資料庫叫AS400,設好以後按下一步。 選擇"從一或多個資料或檢視表複製資料"或"寫入查詢來指定要傳送的資料",我選的是第一頁,按下一步。 接下來選擇需要匯入的資料表,要注意的是在準備工作中提到的在Client Access中的User權限是否足夠。選擇好以後按下一步。 ...

[SQL Server] 關於香港常用字(或難字)的字元儲存問題

哎。又是歷史交給我們偽DBA的問題。 最近有很多big-5碼的資料從AS400轉移到SQL Server上去。 把Big-5的資料轉到SQL Server其實並不難(可參考小弟的 這篇 文章) 問題是資料中有很多Big-5編碼的香港字(或叫難字,造字,增補字,罕用字), 當這些字放到只有相容Unicode的資料型別(Data Type)的時候就會變成問號。 加上將來公司鐵定會慢慢放棄使用Big-5編碼改成Unicode,就算今天A眼開B眼閉,面對全民Unicode的趨勢早晚也是 單拖 要面對囧。現在做點研究,也許將來就省點事吧。 所以剛剛小弟就做了點小測試,首先建立一個Table包含以下data type的四個欄位,然後在每一個不同data type的欄位中新增同一筆含有香港字的數據。 char nchar varchar nvarchar 測試過程小弟就不多說了,結果如下圖: 結論: 如果資料欄位需要支援 Unicode,必須使用 nchar,nvarchar或ntext 型態。 nchar,nvarchar在同一欄位同一筆資料中可同時存在big-5或Unicode的香港字。 當存取Unicode的香港字的時候,請記得在Insert statement中加入N字,不然將無法存取。( 說明在此 ) 將Big-5編碼的香港字變成Unicode會是一種非常爆肝的過程(無誤)

[SQL Server] 什麼是BUILTIN\Administrators用戶?

昨天代表公司去聽一個SQL Server 2012的講座,內容中提到2012版本中已經移除BUILTIN\Administrator帳號,身為SQL Server界Lv1的菜鳥當然不知道那是什麼,回公司以後上網問問古哥大大(Google),終於搞懂了。 這個群組最大的問題是無法明確分辨誰是SQL Server的Administrator,誰是系統的Administrator。 因為這個群組 令伺服器的Local Administrator具備SQL Server的管理權限。 那至少保安考慮上問題就大了。 要解決這個問題可以把群組刪除掉,詳細步驟 在此 。 話說這個年頭One Man Band的IT人真的不好當啊 唉 參考資料: http://www.blackberryforums.com/bes-admin-corner/195873-qq-what-builtin-administrators.html http://social.msdn.microsoft.com/forums/en-US/sqlsecurity/thread/81970e88-104d-4e89-ade8-746def18108e/ http://www.chinaz.com/program/2009/0204/65528.shtml

[ASP.NET]如何登入網路上提供的服務?

原文: http://msdn.microsoft.com/en-us/magazine/jj883954.aspx 話說這一陣子很多網站流行把使用者認證外包給facebook的API去處理。先不談這個方法好不好,如果要做到的話應該怎樣弄呢? 剛好看到MSDN一篇技術文章有一個例子大家可以 抄 參考看看喔.....=皿= 大概就是使用Windows.Security.Authentication.Web這個namesapce. 機制如下:

Popular posts from this blog

[SQL Server] 解決log檔(ldf file)過度膨脹的實戰經驗

背景: 公司最近把一套每天有相對大量交易 (之前公司更大很多很多倍) 的系統轉移到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,我考慮使用那一種的因素主要有以下: 資料庫本身只是約55GB不是太大; 每天交易量不多,每分鐘約10筆交易; 使用者允許少量的data loss,一天Data loss肯定不行; 資料庫只是辦公時間才會用。 我個人認為Backup Plan越簡單越好,發生狀況的時候已經很緊張,複雜的Backup只會令事情更糟。反正今天硬碟實在是太便宜,天天備份幾次也無所謂,因此在儘量簡化備份流程的前題之下,小弟傾向 每天Full BackUp一次,每小時備份一次T-lo...

[Windows7] 跨距磁碟區, 等量磁碟區, 鏡像磁碟區之區別

話說前兩天用來備份的USB硬碟無緣無故去領便當了. 大幸的是我一直有好好備份, 資料至少存在兩顆硬碟上, 所以備份硬碟掛了損失也不大(錢包除外). 所以昨天下班以後趕緊去買一顆seagate的2TB內置硬碟回家(感覺USB硬碟還是不太安全), 裝好以後突然想到一個問題: 現在我桌機總共有5顆硬碟, 首先是剛買回來的2TB, 1顆80G SSD, 1顆640G, 1顆320G, 1顆160G. (真多舊硬碟囧), 關於硬碟的部分Windows 7比XP多了一些選項, 應該選那個才對? 讓我自己先分析一下: 那麼零碎的硬碟應該選擇合拼方案為主 關於合拼的方案Windows7有三大選項, 分別是 跨距磁碟區 ;  等量磁碟區;  鏡像磁碟區三種, 應該怎樣選呢? 說穿了那三種其實就是軟體的RAID方案, 硬要改一些好像很簡單又不簡單的中文字 . 其實: 跨距磁碟區 = JOBD,  就是簡單把幾顆硬碟變成一顆大的邏輯硬碟,  資料的存放機制是由第一顆硬碟開始依序往後存放,即作業系統看到的是一個大硬碟(由許多小硬碟組成的)。但如果硬碟損毀,則該顆硬碟上的所有資料將無法救回。若第一顆硬碟損壞,通常無法作救援(因為大部分檔案系統將磁碟分割表(partition table)‎存在磁碟前端,即第一顆)[1] 等量磁碟區 = RAID 0 把資料分散在幾顆硬碟, 存取的速度比較快, 不過壞一顆又是全部壞掉. 鏡像磁碟區 = RAID 1 顧明思義有兩份data, 超安全, 不過由於write的時候也要write兩份, 所以速度會慢. 更詳細的解釋 這裡 [2] 魚仔大有好好的解釋說明三種功能, 小弟就再不說了. 總結: 那我要怎麼辦? 最後我選擇的是.... 什麼都不做 , 80G的SSD留給OS及程式專用, 640G的用來放照片/動畫/影片/影像檔, 320G的用來放文件還有裝一些不重要的應用程式(遊戲啦,遊戲啦,還有一些遊戲之類的), 160G的用來裝音樂還有.......你懂的. 至於2TB的那顆就是當成上面所有硬碟的mirror, 用sync工具即時備份. 為 什 麼 ? 因為JORB不是不好, 不過把那幾顆舊硬碟變一顆有很大的風險, ...

[SQL SERVER] 找出LOCK方法懶人包

話說休假回公司才不到兩天SQL SERVER就出狀況 Orz 昨天同事跟我說文件系統不能存取ID, 第一件事當然想到是存放ID的資料表LOCK住了. 要查出LOCK方法其實有很多, 以下是小弟歸納的網路資源, 希望幫到大家 什麼是LOCK? 德瑞克大的解釋很詳細:  http://sharedderrick.blogspot.com/2007/12/blocked-lock-connectoin.html sp_lock: 使你對系統中發生的LOCK有深入的了解。它會從master資料庫中的syslockinfo中截取與LOCK相關的大量訊息[1]. 不過我認為由於這個功能的資訊太多, 而且資料沒有好好的做sorting, 所以在危急關頭未必有閒去慢慢看. 在sp_lock會看到spid、dbid、objid、indid、type、resource、mode和status共八個欄位[2]. spid: 連線ID. 可配塔sp_who找出用那些用戶和該連線(spid)有關連. dbid: 資料庫的唯一編號 Objid: 資料表的唯一編號, 可用 select object_id('<table name>') 找到資料表相關Objid 其他的欄位可以在 這裡 找到相關意思. sp_who2 sp_who的加強版本. sp_who主要提供 Microsoft SQL Server Database Engine 執行個體中有關目前使用者、工作階段和處理序的資訊[3]。而sp_who2比較像是sp_who的view, 把sp_who的資料整理得比較好. 小弟經常用它來找出那台PC的發出的process產生了LOCK.  然後毆飛那個user 列出最初導致一連串其它處理序被鎖住的起始源頭(Blocking locks) 很多時候LOCK住的原因是其他的LOCK引發的, 要找出這種關係可以用下面網址的SQL 列出最初導致一連串其它處理序被鎖住的起始源頭 http://www.dotblogs.com.tw/karen0416/archive/2011/11/18/58623.aspx 或者是德瑞克大寫得好好用的SQL http://sharedderrick.blogspot.co...