SQL SERVER——通过计划任务方式每月对配置数据、审计数据等进行备份

1.设置当前Windows用户角色

sql 复制代码
-- 1. 在 msdb 中为登录名创建用户(如果尚未存在)
USE msdb;
CREATE USER [登录用户] FOR LOGIN [登录用户];

-- 2. 加入只读角色(关键!)
ALTER ROLE SQLAgentReaderRole ADD MEMBER [登录用户];

USE msdb;
CREATE USER [SKYL\winning] FOR LOGIN [登录用户];
GRANT SELECT ON dbo.sysjobs TO [登录用户];
-- 如果还需作业步骤、历史等,继续授权:
GRANT SELECT ON dbo.sysjobsteps TO [登录用户];
GRANT SELECT ON dbo.sysjobhistory TO [登录用户];

2.创建备份脚本

命名为:monthly_backup_config_audit.ps1

修改实例名

vbscript 复制代码
# 启用严格模式和错误停止
Set-StrictMode -Version Latest
$ErrorActionPreference = "Stop"

try {
    Write-Host "开始月度备份任务..." -ForegroundColor Green

    # --- 原有逻辑放在这里 ---
    $DateStr = Get-Date -Format "yyyy-MM"
    $BackupRoot = "C:\DB_Backups\Monthly_Audit_Config\$DateStr"
    $SqlServerInstance = "localhost"  # ← 请根据实际修改,可以用ip,端口!

    # 创建目录
    $null = New-Item -ItemType Directory -Path $BackupRoot -Force

    # 导入模块(关键!)
    Import-Module SqlServer -ErrorAction Stop

    
	# 1. 导出配置数据(T-SQL 查询结果保存为 CSV)
	$ConfigQueries = @{
		"Logins.csv"               = "SELECT name, type_desc, create_date, is_disabled FROM sys.server_principals WHERE type IN ('S','U','G')"
		"ServerRoles.csv"          = "SELECT sp.name AS login, sr.name AS role FROM sys.server_role_members rm JOIN sys.server_principals sp ON rm.member_principal_id = sp.principal_id JOIN sys.server_principals sr ON rm.role_principal_id = sr.principal_id"
		"LinkedServers.csv"        = "SELECT name, product, provider, data_source FROM sys.servers WHERE is_linked = 1"
		"Jobs.csv"                 = "SELECT name, enabled, date_created FROM msdb.dbo.sysjobs"
		"ConfigSettings.csv"       = "SELECT name, value,value_in_use, minimum, maximum, description FROM sys.configurations ORDER BY name;"
	}

	foreach ($file in $ConfigQueries.Keys) {
		$query = $ConfigQueries[$file]
		$outputPath = Join-Path $BackupRoot $file
		Invoke-Sqlcmd -ServerInstance $SqlServerInstance -Query $query -OutputAs DataTables | Export-Csv -Path $outputPath -NoTypeInformation -Encoding UTF8
	}

	# 2. 复制默认跟踪文件(如果启用)
	try {
		$traceResult = Invoke-Sqlcmd -ServerInstance $SqlServerInstance -Query "SELECT path FROM sys.traces WHERE is_default = 1"
		
		if ($null -ne $traceResult -and $traceResult.Count -gt 0) {
			$DefaultTracePath = $traceResult[0].path  # 安全取第一行
			if ($DefaultTracePath) {
				$TraceDir = Split-Path $DefaultTracePath -Parent
				if (Test-Path $TraceDir) {
					$TraceFiles = Get-ChildItem -Path $TraceDir -Filter "log_*.trc" | 
								  Sort-Object LastWriteTime -Descending | 
								  Select-Object -First 5
					foreach ($f in $TraceFiles) {
						Copy-Item $f.FullName -Destination $BackupRoot -ErrorAction SilentlyContinue
					}
					Write-Host "默认跟踪文件已备份。"
				}
			}
		} else {
			Write-Host "默认跟踪未启用,跳过跟踪文件备份。" -ForegroundColor Yellow
		}
	}
	catch {
		Write-Host "获取默认跟踪路径失败:$($_.Exception.Message)" -ForegroundColor Yellow
	}

	# 3. 复制 SQL Server Audit 文件(如有)
	$AuditPath = "C:\Audits\"  # 替换为您实际的 Audit 文件路径
	if (Test-Path $AuditPath) {
		$AuditFiles = Get-ChildItem -Path $AuditPath -Filter "*.sqlaudit" | Where-Object { $_.LastWriteTime -gt (Get-Date).AddMonths(-1) }
		foreach ($af in $AuditFiles) {
			Copy-Item $af.FullName -Destination $BackupRoot
		}
	}

	# 4. (可选)导出 Windows 登录事件(最近30天)
	$EventLogPath = Join-Path $BackupRoot "LoginEvents.evtx"
	wevtutil epl Application $EventLogPath /q:"*[System[Provider[@Name='MSSQLSERVER'] and (EventID=18456 or EventID=18453)]]"

	# 5. 压缩归档(可选)
	Compress-Archive -Path "$BackupRoot\*" -DestinationPath "$BackupRoot.zip" -Force
	Remove-Item -Path "$BackupRoot\*" -Exclude "*.zip" -Recurse

	Write-Host "? 月度配置与审计备份完成: $BackupRoot.zip"

    Write-Host "备份成功完成!" -ForegroundColor Green
}
catch {
    Write-Host "脚本执行失败:" -ForegroundColor Red
    Write-Host $_.Exception.Message -ForegroundColor Yellow
    Write-Host "堆栈跟踪:$($_.ScriptStackTrace)" -ForegroundColor Gray
    pause  # 防止窗口关闭,便于查看错误
}

3.测试备份

  1. Win + R,输入 powershell,回车 → 打开 PowerShell 控制台

  2. 手动执行脚本

vbscript 复制代码
cd C:\Scripts 
.\monthly_backup_config_audit.ps1

查看备份目录是否有文件,如果有的话,即成功,否则需要排查问题;

4.创建任务计划

  1. 打开 任务计划程序

  2. 创建任务 → 名称:Monthly SQL Config & Audit Backup

  3. 触发器:每月(如每月1号 2:00 AM)

  4. 操作:

    • 程序:powershell.exe路径

    • 参数:-ExecutionPolicy Bypass -WindowStyle Hidden -File "C:\Script\monthly_backup_config_audit.ps1"

  5. "常规"选项卡:

    • 使用最高权限运行

    • 选择专用服务账户(如 svc-sqlbackup

相关推荐
大树881 天前
金刚石散热越强,管路越先见顶
大数据·运维·服务器·人工智能·ai
摇滚侠1 天前
Linux CentOS7 rpm 安装 MySQL 5.7
linux·运维·mysql
霸道流氓气质1 天前
领域驱动设计(DDD)在 Spring Boot 微服务中的实践指南
运维·spring boot·微服务
小宇宙Zz1 天前
Maven依赖冲突
java·服务器·maven
Inhand陈工1 天前
基于台达PLC与映翰通IG502的智慧水产养殖精准投喂与远程运维解决方案
运维·人工智能·物联网·阿里云·信息与通信
酣大智1 天前
ARP代理--工作原理
运维·网络·arp·arp代理
shushangyun_1 天前
2026年快消品B2B系统推荐:支持终端门店订货、促销政策自动化的工具?
java·运维·网络·数据库·人工智能·spring·自动化
古城小栈1 天前
Unix 与 Linux 异同小叙
linux·服务器·unix
施努卡机器视觉1 天前
SNK施努卡侧滑门锁上滑轮总成自动化装配线,从零件到组件,全流程精密制造方案
运维·自动化·制造
程序猿阿伟1 天前
《Chrome离线扩展安装的底层逻辑与场景落地指南》
服务器·网络·chrome