在线精品99_中国九九盗摄偷拍偷看_91免费版在线观看_91.app_91高清视频在线_99热最新网站

怎么使用alwayson后如何收缩数据库日志

112次阅读
没有评论

共计 3682 个字符,预计需要花费 10 分钟才能阅读完成。

自动写代码机器人,免费开通

这篇文章将为大家详细讲解有关怎么使用 alwayson 后如何收缩数据库日志,丸趣 TV 小编觉得挺实用的,因此分享给大家做个参考,希望大家阅读完这篇文章后可以有所收获。

问题描述:

在使用了 alwayson 后,主从库实时同步,原理是通过事务日志同步的,所以造成主数据库的事务日志一直在使用,而且无法收缩主数据库的事务日志。

在主从库同步时,收缩数据库是不起作用的。由于主数据库无法收缩,所以从数据库的日志也会一直跟着增长,造成磁盘空间一直增长。

网上大量的收缩日志的方法,基本上都不管用,怀疑根本没有在实际环境中使用过,以下方案是我在实际中使用后总结记录的。

解决方案:

最开始发现这个问题后,也是研究了好久,发现的方法,先是全手动操作。因为这些操作,并不能用语句来实现自动化,所以一直是手动处理的。

可能人都是比较懒的吧(人只有懒,才能促进机械自动化,才会有各种发表创造!不是吗?呵呵),一直想能过脚本,实现自动化。

今天终于摸索出来了,总结一下。

大概的思路如下

通过脚本将 alwayson 从库,从可用性数据库是移除,就是取消主从同步,这样主库变成单库模式了。然后再收缩事务日志,收缩后再把主从数据库加上。

考虑到有一点,操作中需要删除从库上的数据库,为防止操作错误,把主库的数据库删除了,这个操作相当危险啊,所以将脚本分为三个。在两个机器上来回操作。

第一个脚本在 db1 上执行。

第二个脚本在 db3 上执行

第三个脚本在 db1 上执行

(这里 db1 是主库,db3 是从库。不要问我 db2 呢,因为创建时先创建的 db2 后来 db2 有问题删除了。你根据你的实际情况替换就行了。)

待时机成熟,或者加上判断,可以考虑将以下三个脚本合成一个脚本,然后一键执行,或者加到定时任务,每月自动执行一次。

以下脚本经过亲测可用

syncdb 为 alwayson 同步的名字,

DBSERVER1 和 DBSERVER3 是主从数据库的名称。DBSERVER1 为主库,DBSERVER3 为从库。

:Connect DBSERVER1 -U sa -P abc@123 是使用 SQLCMD 模式连接数据库,请修改后面的密码。

test 为数据库名称。

1、取消主从同步

--- YOU MUST EXECUTE THE FOLLOWING SCRIPT IN SQLCMD MODE.
:Connect DBSERVER1 -U sa -P abc@123 
 
USE [master]
 
 
ALTER AVAILABILITY GROUP [syncdb] REMOVE DATABASE [test];
GO

2 删除从库上的数据库,在收拾后,再添加上。

:Connect DBSERVER3 -U sa -P abc@123 
 
USE [master]
 
DROP DATABASE [test]
GO

3. 备份事务日志,收缩日志文件,添加从库数据库。

--- YOU MUST EXECUTE THE FOLLOWING SCRIPT IN SQLCMD MODE.
:Connect DBSERVER1 -U sa -P abc@123 
 
USE [master]
 
 
 
BACKUP LOG [test] TO DISK= NUL: with STATS = 10
use [test]
DBCC SHRINKFILE (N test_log  , 20480)
 
USE [master]
 
 
ALTER AVAILABILITY GROUP [test]
ADD DATABASE [test];
 
 
:Connect DBSERVER1 -U sa -P test@123 
 
BACKUP DATABASE [test] TO DISK = N \\dbserver3\e$\share\test.bak  WITH COPY_ONLY, FORMAT, INIT, SKIP, REWIND, NOUNLOAD, COMPRESSION, STATS = 5
 
 
:Connect DBSERVER3 -U sa -P test@123 
 
RESTORE DATABASE [test] FROM DISK = N \\dbserver3\e$\share\test.bak  WITH NORECOVERY, NOUNLOAD, STATS = 5
 
 
:Connect DBSERVER1 -U sa -P test@123 
 
BACKUP LOG [test] TO DISK = N \\dbserver3\e$\share\test.trn  WITH NOFORMAT, NOINIT, NOSKIP, REWIND, NOUNLOAD, COMPRESSION, STATS = 5
 
 
:Connect DBSERVER3 -U sa -P test@123 
 
RESTORE LOG [test] FROM DISK = N \\dbserver3\e$\share\test.trn  WITH NORECOVERY, NOUNLOAD, STATS = 5
 
 
:Connect DBSERVER3 -U sa -P test@123 
 
 
-- Wait for the replica to start communicating
begin try
declare @conn bit
declare @count int
declare @replica_id uniqueidentifier 
declare @group_id uniqueidentifier
set @conn = 0
set @count = 30 -- wait for 5 minutes 
 
if (serverproperty( IsHadrEnabled) = 1)
 and (isnull((select member_state from master.sys.dm_hadr_cluster_members where upper(member_name COLLATE Latin1_General_CI_AS) = upper(cast(serverproperty( ComputerNamePhysicalNetBIOS) as nvarchar(256)) COLLATE Latin1_General_CI_AS)), 0)   0)
 and (isnull((select state from master.sys.database_mirroring_endpoints), 1) = 0)
begin
 select @group_id = ags.group_id from master.sys.availability_groups as ags where name = N yorkdb 
 select @replica_id = replicas.replica_id from master.sys.availability_replicas as replicas where upper(replicas.replica_server_name COLLATE Latin1_General_CI_AS) = upper(@@SERVERNAME COLLATE Latin1_General_CI_AS) and group_id = @group_id
 while @conn   1 and @count   0
 begin
 set @conn = isnull((select connected_state from master.sys.dm_hadr_availability_replica_states as states where states.replica_id = @replica_id), 1)
 if @conn = 1
 begin
 -- exit loop when the replica is connected, or if the query cannot find the replica status
 break
 waitfor delay  00:00:10 
 set @count = @count - 1
end try
begin catch
 -- If the wait loop fails, do not stop execution of the alter database statement
end catch
ALTER DATABASE [test] SET HADR AVAILABILITY GROUP = [syncdb];
GO

在执行:Connect 命令前记得把 SQLCMD 模式打开

怎么使用 alwayson 后如何收缩数据库日志

打开后,你能看到 SQLCMD 命令是灰色的。

怎么使用 alwayson 后如何收缩数据库日志

关于“怎么使用 alwayson 后如何收缩数据库日志”这篇文章就分享到这里了,希望以上内容可以对大家有一定的帮助,使各位可以学到更多知识,如果觉得文章不错,请把它分享出去让更多的人看到。

向 AI 问一下细节

正文完
 
丸趣
版权声明:本站原创文章,由 丸趣 2023-12-04发表,共计3682字。
转载说明:除特殊说明外本站除技术相关以外文章皆由网络搜集发布,转载请注明出处。
评论(没有评论)
主站蜘蛛池模板: 精品视频一区二区观看 | 色综合视频一区中文字幕 | 亚洲国产精品一区二区第四页 | 青春草在线视频观看 | 欧洲美女黑人粗性暴交视频 | 日韩 视频在线播放 | 久久夜色精品国产亚洲av动态图 | 欧美成人国产一区二区 | 欧美午夜精品 | 97国产精华最好的产品亚洲 | 台湾一级毛片永久免费 | 国产精品久久久久久日本 | 95视频在线观看在线分类h片 | 国产精品久久久久免费视频 | 老熟妇仑乱视频一区二区 | 青青自拍| 亚洲一区爱区精品无码 | 一级片免费在线观看 | av香港经典三级级 在线 | 成人黄色大全 | 国产一区二区三区日韩精品 | 亚洲 日本 欧美 日韩精品 | 五月婷婷啪啪 | 亚洲精品在线免费看 | 成人福利视频 | 97人妻无码一区二区精品免费 | 国产精品人人 | 最近2019中文字幕大全视频1 | 欧美日韩一区二区三区毛片 | 人妻av无码一区二区三区 | 伊人网综合在线视频 | 成人1000部免费观看视频 | 国产20岁美女一级毛片 | 中文字幕第一页在线视频 | 成码无人av片在线电影网站 | 高清欧美色欧美综合网站 | 成人免费手机在线看网站 | 一级毛片免费播放视频 | 女性特黄一级毛片 | 久久久久久亚洲精品中文字幕 | 日韩视频福利 |