dbatools项目:使用PowerShell管理SQL Server实例认证模式
2025-06-30 08:42:07作者:卓炯娓
在SQL Server数据库管理中,实例的认证模式是一个关键的安全配置选项。dbatools作为一款强大的PowerShell模块,虽然提供了丰富的SQL Server管理功能,但当前版本中缺少直接修改实例认证模式的命令。本文将介绍如何通过自定义PowerShell函数来实现这一功能。
SQL Server认证模式概述
SQL Server支持两种主要的认证模式:
- Windows认证模式(Integrated):仅允许使用Windows账户登录
- 混合认证模式(Mixed):允许同时使用Windows账户和SQL Server账户登录
认证模式的选择直接影响数据库服务器的安全策略和用户访问方式。在生产环境中,管理员可能需要根据安全要求调整认证模式。
自定义PowerShell函数实现
以下是一个完整的PowerShell函数实现,可以添加到dbatools模块中使用:
function Set-DbaInstanceAuthenticationMode {
[CmdletBinding(SupportsShouldProcess, ConfirmImpact='Medium')]
Param (
[Parameter(ValueFromPipeline)]
[DbaInstanceParameter[]]$SqlInstance,
[PSCredential]$SqlCredential,
[Parameter(Mandatory)]
[ValidateNotNullOrEmpty()]
[ValidateSet('Integrated','Mixed','Normal')]
[string]$AuthenticationMode,
[switch]$Restart,
[switch]$EnableException
)
Process {
foreach ($instance in $SqlInstance) {
try {
$server = Connect-DbaInstance -SqlInstance $instance -SqlCredential $SqlCredential
} catch {
Write-Warning "无法连接到实例 $instance"
continue
}
if($server.Settings.LoginMode -ne $AuthenticationMode){
if ($pscmdlet.ShouldProcess($server, "将认证模式从 $($server.Settings.LoginMode) 更改为 $AuthenticationMode")) {
try {
$server.Settings.LoginMode = [Microsoft.SqlServer.Management.SMO.ServerLoginMode] $AuthenticationMode
$server.Settings.Alter()
if($Restart){
Restart-DbaService -SqlInstance $instance
}
} catch {
Write-Warning "无法修改 $server 的认证模式"
continue
}
}
} else {
Write-Verbose "跳过:认证模式已设置为 $AuthenticationMode"
}
}
}
}
函数功能详解
参数说明
- SqlInstance:指定要修改的SQL Server实例,支持多个实例
- SqlCredential:连接SQL Server的凭据
- AuthenticationMode:目标认证模式,支持以下值:
- Integrated:Windows认证
- Mixed:混合认证
- Normal:传统SQL认证(不推荐)
- Restart:是否在修改后自动重启服务使更改生效
- EnableException:控制异常处理行为
使用示例
# 将单个实例改为混合认证模式并重启服务
Set-DbaInstanceAuthenticationMode -SqlInstance "server01.domain.local" -AuthenticationMode Mixed -Restart
# 修改多个实例的认证模式但不重启
$instances = "server01","server02","server03"
Set-DbaInstanceAuthenticationMode -SqlInstance $instances -AuthenticationMode Integrated
技术实现要点
- 使用SMO(Server Management Objects)的
ServerLoginMode枚举来设置认证模式 - 通过
Settings.Alter()方法将更改应用到SQL Server实例 - 提供
-WhatIf支持,可以预览将要执行的操作 - 包含详细的错误处理和日志记录
注意事项
- 修改认证模式通常需要重启SQL Server服务才能生效
- 从Windows认证改为混合认证时,需要确保已设置强壮的sa密码
- 在生产环境中执行前,建议先在测试环境验证
- 该操作需要管理员权限
这个自定义函数填补了dbatools在SQL Server认证模式管理方面的空白,为数据库管理员提供了一个方便、安全的工具来管理实例认证配置。
登录后查看全文
热门项目推荐
相关项目推荐
atomcodeClaude Code 的开源替代方案。连接任意大模型,编辑代码,运行命令,自动验证 — 全自动执行。用 Rust 构建,极致性能。 | An open-source alternative to Claude Code. Connect any LLM, edit code, run commands, and verify changes — autonomously. Built in Rust for speed. Get StartedRust0193
cann-learning-hubCANN 学习中心仓,支持在线互动运行、边学边练,提供教程、示例与优化方案,一站式助力昇腾开发者快速上手。Jupyter Notebook0121
Step-3.7-FlashStep-3.7-Flash是一个拥有 1980 亿参数的稀疏混合专家(MoE)视觉语言模型,由 1960 亿参数的语言主干网络和 18 亿参数的视觉编码器组合而成,具备原生图像理解能力。Python00
JoyAI-EchoJoyAI-Echo,这是一个独立的、仅用于推理的版本,旨在实现分钟级多镜头音视频生成。它采用了经过蒸馏的DMD生成器、配对的跨模态记忆以及故事级别的一致性。其性能的核心在于,一个跨模态视听记忆库能够在长达五分钟的视频中保持角色外观和语音音色的一致性。同时,一个训练后处理流程将基于记忆的强化学习与分布匹配蒸馏相结合,实现了7.5倍的速度提升,显著增强了视觉质量和对齐效果。00
fun-rec推荐系统入门教程,在线阅读地址:https://datawhalechina.github.io/fun-rec/Python03
so-large-lm大模型基础: 一文了解大模型基础知识01
项目优选
收起
暂无描述
Dockerfile
766
4.99 K
本项目是CANN提供的transformer类大模型算子库,实现网络在NPU上加速计算。
C++
857
1.94 K
本项目是CANN提供的神经网络类计算算子库,实现网络在NPU上加速计算。
C++
686
1.34 K
Ascend Extension for PyTorch
Python
721
884
本项目是CANN提供的数学类基础计算算子库,实现网络在NPU上加速计算。
C++
1.08 K
1.1 K
deepin linux kernel
C
32
16
openEuler内核是openEuler操作系统的核心,既是系统性能与稳定性的基石,也是连接处理器、设备与服务的桥梁。
C
458
443
本仓库是 Flutter SDK 与 Flutter Engine 的 OpenHarmony 适配版本,由 CPF-Flutter 团队维护。开发者可使用熟悉的 Flutter 技术栈开发 OpenHarmony 应用,3.35.7 及以后的适配版本可基于本仓库源码构建支持 OpenHarmony 的 Flutter Engine。
Dart
1.01 K
262
华为昇腾面向大规模分布式训练的多模态大模型套件,支撑多模态生成、多模态理解。
Python
151
253
CANNBot 是面向 CANN 开发的用于提升开发效率的系列智能体,本仓库为其提供可复用的 Skills 模块。
Python
1 K
612