作過replication的人都知道,distribution數據庫會不斷的增大,特別是操做平凡,數據增加是至關嚇人的。能夠一會兒增長到5g以上。 sql
當時我被嚇到了。不知如何是好?從新作replication的話是能夠,可是不可能每次都由於distribution數據庫過大就作,這樣太浪費時間。 數據庫
最後,我找了不少資料,也嘗試了其實很簡單。只須要執行sql query就ok ui
select name, log_reuse_wait, log_reuse_wait_desc
from sys.databases
where name = 'Distribution'
--(shows breakout by day, by hour. Took 2 hours on 350million rows, 100gb distribtuion db)
SELECT T.[publisher_database_id]
,datepart(mm,[entry_time]) 'month'
, datepart(dd,[entry_time]) 'day'
, datepart(hh,[entry_time]) 'hour'
,count(C.[xact_seqno]) 'count of commands'
FROM [distribution].[dbo].[MSrepl_transactions](nolock) T
JOIN [MSrepl_commands](nolock) C
ON T.[xact_seqno] = C.[xact_seqno]
GROUP BY T.[publisher_database_id]
,datepart(mm,[entry_time])
, datepart(dd,[entry_time])
, datepart(hh,[entry_time])
order by 1,2,3,4
--Or, just select oldest 10 rows and note the entry_time stamp.
--(select took 5 minutes on 350million rows, 100gb distribtuion db)
SELECT TOP 10 * FROM [distribution].[dbo].[MSrepl_transactions](nolock)
EXEC dbo.sp_MSdistribution_cleanup @min_distretention = 0, @max_distretention = 120
sp_helptext sp_MSdelete_publisherdb_trans spa
ALTER PROCEDURE sp_MSdelete_publisherdb_trans
sp_helptext sp_MSdelete_dodelete it
--以上代碼只須要執行第一次就ok。 io
--下面兩行代碼就是要直接執行屢次,直接執行到影響的行數爲0就ok了。記得要shrink distribution數據庫。
DELETE TOP(20000) MSrepl_commands
delete TOP(50000) MSrepl_transactions
date