基于windows系统的netcore架构与SqlServer数据库,实现双机热备。
以下是基于 SQL Server Always On 可用性组 和 故障转移群集 的详细配置步骤,用于实现双机热备。
步骤 1:准备环境
1.1 硬件和软件准备
- 两台服务器:分别作为主服务器和备用服务器。
- SQL Server版本:确保两台服务器上安装的SQL Server版本一致,且支持Always On功能(通常需要企业版)。
- Windows Server版本:确保两台服务器的操作系统版本一致。
- 网络配置:确保两台服务器之间网络通畅,并且可以访问共享存储(如果使用)。
1.2 安装SQL Server
- 在两台服务器上安装SQL Server实例,但不要选择“故障转移群集安装”选项。
- 确保SQL Server服务以具有本地管理员权限的账户运行。
步骤 2:配置Windows Server Failover Clustering(WSFC)
2.1 安装故障转移群集功能
- 在两台服务器上打开“服务器管理器”。
- 添加角色和功能,选择“故障转移群集”功能并安装。
2.2 创建故障转移群集
- 打开“故障转移群集管理器”。
- 创建新的群集,指定群集名称和IP地址。
- 将两台服务器添加为群集节点。
- 使用群集验证向导验证群集配置是否正确。
2.3 配置群集网络和存储
- 如果使用共享存储(如SAN),需要在WSFC中配置共享磁盘。
- 确保群集网络配置正确,两台服务器可以通过群集网络通信。
步骤 3:配置SQL Server故障转移群集实例
3.1 在主服务器上安装故障转移群集实例
- 在主服务器上运行SQL Server安装程序。
- 在安装向导中选择“新SQL Server故障转移群集安装”。
- 按照向导提示完成安装,包括:
- 指定产品密钥和许可条款。
- 安装安装程序支持文件。
- 指定SQL Server服务的登录账户。
- 配置数据库引擎和Analysis Services。
- 指定群集资源组名称和共享磁盘。
- 配置网络设置,指定故障转移群集实例的IP地址。
- 完成安装后,重启服务器。
3.2 在备用服务器上添加节点
- 在备用服务器上运行SQL Server安装程序。
- 在安装向导中选择“添加节点到现有SQL Server故障转移群集”。
- 按照向导提示完成安装,包括:
- 指定要添加到群集的节点。
- 配置网络设置,指定故障转移群集实例的IP地址。
- 完成安装后,重启服务器。
步骤 4:配置Always On可用性组
4.1 在主服务器上创建可用性组
- 打开SQL Server Management Studio(SSMS)。
- 在“对象资源管理器”中,右键单击“Always On 高可用性”,选择“新建可用性组向导”。
- 在“新建可用性组向导”中,完成以下步骤:
- 指定可用性组选项:输入可用性组的名称(例如
MyTestAG
)。 - 选择数据库:选择要加入可用性组的数据库。
- 指定副本:添加辅助副本(备用服务器的SQL Server实例)。
- 配置数据库镜像端点:确保端口配置正确。
- 选择初始数据同步:选择“完全同步”,并指定一个共享网络位置用于备份和还原。
- 指定可用性组选项:输入可用性组的名称(例如
4.2 配置可用性组监听器
- 在“新建可用性组向导”中,完成监听器配置:
- 指定监听器名称和IP地址。
- 确保监听器名称可以被客户端解析。
- 在故障转移群集管理器中,验证监听器资源是否已正确配置。
步骤 5:测试故障转移
- 手动触发故障转移,确保辅助副本可以正常接管主副本的工作。
- 在故障转移群集管理器中,手动将可用性组故障转移到辅助副本。
- 验证数据库连接和数据完整性。
- 测试客户端连接到可用性组监听器,确保在故障转移后客户端可以自动连接到新的主副本。
步骤 6:配置Web服务(.NET Core)
6.1 更新连接字符串
在.NET Core应用程序中,数据库连接字符串需要指向可用性组监听器,而不是直接指向主服务器的IP地址。示例连接字符串如下:
{"ConnectionStrings": {"DefaultConnection": "Server=myAvailabilityGroupListener;Database=myDatabase;User Id=myUser;Password=myPassword;"}
}
myAvailabilityGroupListener
是可用性组监听器的名称。myDatabase
是数据库名称。myUser
和myPassword
是数据库登录凭据。
6.2 实现重试机制
在.NET Core应用程序中,建议实现重试机制,以应对故障转移期间可能出现的短暂连接中断。可以使用Polly
库来实现重试策略。
步骤 7:监控和维护
7.1 监控可用性组状态
- 使用SSMS中的“可用性组仪表板”查看可用性组的状态。
- 使用T-SQL查询或SQL Server Agent警报来监控数据同步状态。
7.2 定期测试故障转移
- 定期手动触发故障转移,确保系统在故障情况下可以正常切换。
- 验证数据库连接和数据完整性。
7.3 备份和恢复策略
- 定期备份数据库,确保数据安全。
- 测试备份恢复流程,确保在灾难情况下可以快速恢复数据。
注意事项
- 网络延迟:如果主备服务器之间存在较大的网络延迟,建议使用异步提交模式,但需注意数据丢失的风险。
- 存储配置:确保主备服务器的存储性能一致,避免因存储瓶颈影响数据库性能。
- 客户端连接:客户端连接到可用性组监听器时,可能会出现短暂的连接中断,建议在应用程序中实现重试机制。
通过以上详细步骤,可以实现SQL Server的双机热备,确保在主服务器故障时,备用服务器可以无缝接管,保障Web服务的高可用性。
相关文章:
基于windows系统的netcore架构与SqlServer数据库,实现双机热备。
以下是基于 SQL Server Always On 可用性组 和 故障转移群集 的详细配置步骤,用于实现双机热备。 步骤 1:准备环境 1.1 硬件和软件准备 两台服务器:分别作为主服务器和备用服务器。SQL Server版本:确保两台服务器上安装的SQL S…...
【转bin】EXCEL数据转bin
如果DEC2BIN函数的默认设置无法满足需求(它最多只能处理10位的二进制转换),可以通过VBA宏方法来处理较大数的二进制转换并提取特定位置的数字: 十进制转二进制(不限位宽) 1、打开VBA编辑器(Al…...

BERT:让AI真正“读懂”语言的革命
BERT:让AI真正“读懂”语言的革命 ——图解谷歌神作《BERT: Pre-training of Deep Bidirectional Transformers》 2018年,谷歌AI团队扔出一篇核弹级论文,引爆了整个NLP领域。这个叫BERT的模型在11项任务中屠榜,甚至超越人类表现…...
【计算机组成原理】SPOOLing技术
SPOOLing技术 关键点内容核心思想通过输入/输出井虚拟化独占设备,实现共享,即让多个作业共享一台独占设备依赖条件1. 外存(井文件)2. 多道程序设计虚拟实现多道程序技术磁盘缓冲数据流方向输入设备 → 输入井 → CPU → 输出井 →…...

冷雨泉教授团队:新型视觉驱动智能假肢手,拟人化抓握技术突破,助力截肢者重获生活自信
研究背景:日常生活中,健康人依靠手完成对物体的操作。对于手部截肢患者,手部的缺失导致他们难以有效地操作物体,进而影响正常的日常生活。拥有一个能够实现拟人地自然抓取多种日常物体的五指动力假手是手部截肢患者的夙愿…...
CanvasGroup篇
🎯 Unity UI 性能优化终极指南 — CanvasGroup篇 🧩 什么是 CanvasGroup? CanvasGroup 是UGUI的透明控制器,用于整体控制一组UI元素的: 可见性 (alpha)交互性 (interactable)射线检测 (blocksRaycasts) 🎯…...
[Java 基础]银行账户程序
编写一个 Java 控制台应用程序,模拟一个简单的银行账户。该程序应允许用户执行以下操作: 查询账户余额。 账户初始余额设置为 1000.0 元。向账户存入资金。 用户可以输入存款金额,程序应更新账户余额。存款金额必须为正数。从账户提取资金。…...
2025.6.4总结
工作:今天效率比较高,早上回归4个问题,下午找了3个bug,晚上二刷了科目一(贪吃蛇系统),写了四个点,唯一没达标的就是两自动化没完成。美中不足的是电脑上下载不了PC版的番茄工作软件。…...
将音频数据累积到缓冲区,达到阈值时触发处理
实现了音频处理中的 AEC(声学回声消除)和 AES(音频增强)功能,其核心功能是: 数据缓冲管理:将输入的麦克风和扬声器音频数据块累积到缓冲区中块处理机制:当缓冲区填满预设大小&#…...

pikachu靶场通关笔记14 XSS关卡10-XSS之js输出(五种方法渗透)
目录 一、源码分析 1、进入靶场 2、代码审计 二、渗透实战 1、根据提示输入tmac 2、XSS探测 3、注入Payload1 4、注入Payload2 5、注入Payload3 6、注入Payload4 7、注入Payload5 本系列为通过《pikachu靶场通关笔记》的XSS关卡(共10关)渗透集合&#x…...
5.Promise,async,await概念(1)
Promise 是 JavaScript 原生提供的异步处理机制,而 async 和 await 是基于 Promise 的语法糖,由 JavaScript 语言和其运行时环境(如浏览器、Node.js)支持,用于更清晰地编写异步代码,从而避免回调地狱。 Pr…...

李沐-动手学深度学习:RNN
1.RNN从零开始实现 import math import torch from torch import nn from torch.nn import functional as F from d2l import torch as d2l#8.3.4节 #batch_size:每个小批量中子序列样本的数目,num_steps:每个子序列中预定义的时间步数 #loa…...
Windows系统下npm报错node-gyp configure got “gyp ERR“解决方法
感谢原博主,此文参考网址:https://zhuanlan.zhihu.com/p/398279220 确保已经安装node.js (官方网址:https://nodejs.org/zh-cn/download) 首先在命令窗口执行命令安装windows-build-tools: npm install -…...
Elasticsearch中的文档(Document)介绍
在Elasticsearch(ES)中,文档(Document)是最基本的数据单元,类似于关系型数据库中的“行”。它以JSON格式存储,包含多个字段(Field),每个字段可以是不同类型(如文本、数值、日期等)。文档是索引(Index)的组成部分,通过唯一ID标识,并支持动态映射(Dynamic Mappi…...
15个基于场景的 DevOps 面试问题及答案
第一部分:持续集成和部署 (CI/CD) 场景 1:构建中断 “您的 CI 流水线突然出现‘找不到依赖项’的错误。您会如何处理这个问题?” 回答:首先,我会检查是否有新的依赖项被添加到需求文件中,但这些依赖项并未包含在需求文件中。我还会验证构建服务器是否可以访问互联网来下…...
今日主题二分查找(寻找峰值 力扣162)
峰值元素是指其值严格大于左右相邻值的元素。 给你一个整数数组 nums,找到峰值元素并返回其索引。数组可能包含多个峰值,在这种情况下,返回 任何一个峰值 所在位置即可。 你可以假设 nums[-1] nums[n] -∞ 。 你必须实现时间复杂度为 O(…...

【教学类-36-10】20250531蝴蝶图案描边,最适合大小(一页1图1图、2图图案不同、2图图案相同对称)
背景说明: 之前做了动物头像扇子(描边20),并制作成一页一套图案对称两张 【教学类-36-09】20250526动物头像扇子的描边(通义万相)对称图40张,根据图片长宽,自动旋转图片,最大化图片-CSDN博客文章浏览阅读1k次,点赞37次,收藏6次。【教学类-36-09】20250526动物头像…...

高效DBA的日常运维主题沙龙
2024年11月10日,在宁波组织了高效DBA的日常运维沙龙活动,大概有20人左右现场参加。会议的主题为: 目标: 1、识别高频低效操作并制定自动化方案 2、建立关键运维指标健康度体系 3、输出可立即落地的优化清单 会议议程 一、效能瓶…...

AAAI 2025论文分享│STD-PLM:基于预训练语言模型的时空数据预测与补全方法
本文详细介绍了一篇发表于人工智能顶级会议AAAI 2025的论文《STD-PLM: Understanding Both Spatial and Temporal Properties of Spatial-Temporal Data with PLM》。该论文提出了一种基于预训练语言模型(Pre-trained Language Model,PLM)的…...

Ethernet/IP转DeviceNet网关:驱动大型矿山自动化升级的核心纽带
在大型矿山自动化系统中,如何高效整合新老设备、打通数据孤岛、实现统一控制,是提升效率与安全的关键挑战。JH-EIP-DVN疆鸿智能EtherNet/IP转DeviceNet网关,正是解决这一难题的核心桥梁,为矿山各环节注入强劲连接力: …...
Android 11以上App主动连接WIFI的完整方案
早期Android版本App内连接指定的WIFI还是比较简单的,但是随着Android版本的提升,限制也越来越多。以下是一套完整的Android 11以上的WIFI应用内主动连接方案。 第一步:添加到建议连接: val wifiManager getSystemService(WIFI_…...

[蓝桥杯]模型染色
模型染色 题目描述 在电影《超能陆战队》中,小宏可以使用他的微型机器人组合成各种各样的形状。 现在他用他的微型机器人拼成了一个大玩具给小朋友们玩。为了更加美观,他决定给玩具染色。 小宏的玩具由 nn 个球型的端点和 mm 段连接这些端点之间的边…...
力扣上C语言编程题
一. 简介 本文简单记录一下力扣上 C语言编程题。作为自己做题笔记。 二. 力扣上 C 语言编程题 1. 从数组中找到两个元素之和,等于一个 target目标值 具体题目说明:给定一个整数数组 nums 和一个整数目标值 target,请你在该数组中找出 和为…...

卡西欧模拟器:Windows端功能强大的计算器
引言 大家还记得初中高中时期用的计算器吗?今天给大家分享的就是一款windows端的卡西欧计算器。 软件介绍 大家好,我是逍遥小欢。 CASIO fx-9860G是一款功能强大的图形计算器,适用于数学、科学和工程计算。以下是其主要功能和特点的详细介…...
鸿蒙OSUniApp结合机器学习打造智能图像分类应用:HarmonyOS实践指南#三方框架 #Uniapp
UniApp结合机器学习打造智能图像分类应用:HarmonyOS实践指南 引言 在移动应用开发领域,图像分类是一个既经典又充满挑战的任务。随着机器学习技术的发展,我们现在可以在移动端实现高效的图像分类功能。本文将详细介绍如何使用UniApp结合Ten…...

机器学习基础(三) 逻辑回归
目录 逻辑回归的概念核心思想 Sigmoid 函数 逻辑回归的原理和底层优化手段伯努利分布最大似然估计 Maximum Likelihood Estimation (MLE)伯努利分布的似然函数交叉熵损失函数(Cross-Entropy Loss),也称为 对数损失&…...
系统调试——ADB 工具
ADB 工具 1.1 概述 ADB(Android Debug Bridge) 是 Android SDK 里的一个工具, 用这个工具可以操作管理Android 模拟器或真实的 Android 设备。 主要功能有: 运行设备的 shell(命令行)管理模拟器或设备的端…...

Qwen-3 微调实战:用 Python 和 Unsloth 打造专属 AI 模型
虽然大家都忙着在 DeepSeek 上构建应用,但那些聪明的开发者们却悄悄发现了 Qwen-3 的微调功能,这可是一个隐藏的宝藏,能把通用型 AI 变成你的专属数字专家。 通过这篇文章,你将学到如何针对特定用途微调最新的 Qwen-3 模型。无论…...

微软Build 2025:Copilot Studio升级,解锁多智能体协作未来
微软Build 2025大会圆满落幕,作为年度科技盛会,它一直是开发与AI技术突破性创新的重要展示平台。对于工程师、创作者和领域专家来说,这是了解微软生态未来动向的关键时刻。今年,Microsoft Copilot Studio推出了一系列新功能&#…...

设计模式——系统数据建模设计
摘要 本文主要介绍了UML在软件系统分析和设计中的应用,详细阐述了六大类关系(泛化、实现、依赖、关联、聚合、组合)及其在UML类图中的表示方法,并通过具体例子说明了这些关系在实际编程中的应用。同时,文章还概述了UM…...