SQLServer 2012 Always on配置全过程

可用性组在可用性副本级别进行故障转移。 故障转移不是由诸如因数据文件丢失或事务日志损坏而使数据库成为可疑数据库等数据库问题导致的。 因此,一个辅助数据库可以挂起或失败而不会影响其他辅助数据库,一个主数据库可以挂起或失败而不会影响其他主数据库

 

Kits AI Kits AI

Kits.ai 是一个为音乐家提供一站式AI音乐创作解决方案的网站,提供AI语音生成和免费AI语音训练

Kits AI 492 查看详情 Kits AI

可用性组在可用性副本级别进行故障转移。故障转移不是由诸如因数据文件丢失或事务日志损坏而使数据库成为可疑数据库等数据库问题导致的。

 

因此,一个辅助数据库可以挂起或失败而不会影响其他辅助数据库,一个主数据库可以挂起或失败而不会影响其他主数据库。

 

图显示一个可用性组,该组包含最大数目的可用性副本,即一个主副本和四个辅助副本。

 

来自:

 

虽然2012 Always on是基于WSFC的,但是并不需要共享存储,所以配置就非常简单。

 

下面是我的安装步骤:

 

至少需要三台机器(我创建了三台虚拟机,一台是作为DC,DNS服务器,香港虚拟主机,两台Nod3)

 (备注:为啥一定要3台,网站空间,因为SQL SERVER 的 Cluster服务不能安装在域服务器上。Windows2008 R2 和SQL SERVER 2012 一定要打上sp1.否则有不可预知的错误)

机器名

角色

OS

IP Address

DC

Domain Controller

Windows 2008R2

192.168.1.10

Node1

Cluster Node 1

Windows 2008R2

192.168.1.11 Public

192.168.2.1

心跳线

Node2

Cluster Node 2

Windows 2008R2

192.168.1.12 Public

192.168.2.2

心跳线窗体底端

 

首先配置Windows集群:

 

  1. 安装.NETFramework 3.5.1 Features和Failover Clustering

 

 

 

2. 安装Windows KB 2494036

 

3.新建集群

 

 

 

4.选择加入集群的服务器:

 

 

 

5.检测配置:

 

 

 

6.不需要选择检测共享磁盘(AlwaysOn不需要)

 

 

 

7.开始检测:

 

 

 

8.检测内容(检测完成后可以导出Report):

 

 

 

9.之后输入Cluster名字和IP点击下一步创建成功,成功后打开Server Manager查看集群配置(可以看到并没有共享磁盘,跟传统的集群还是有区别的):

 

 

现在我们集群已经配置后了,下一步是安装SQLServer并且配置Always On.

 

 

 

我们已经配置了Cluster,Part2 我们安装SQL Server 2012 评估版(要使用64位的SQLServer, X86不支持Always On)并且配置Alaways On Group.

 

1.  以管理员身份安装

 

          

2.选择单机安装(不是集群安装)

 

 

 

3.SQL Server 2012的新功能,可以在安装的时候搜索最新的补丁,将补丁也以前安装(这个是可选项)

 

 

 

4.规则检测

 

 

 

5.选择安装组件

 

 

 

6.实例名:

 

 

 

7.计算需要的磁盘空间:

 

 

 

8.Service账户(域账户):

 

 

 

9.排序规则(可以根据自己需要选择):

 

 

 

10.设置权限,数据库文件备份地址以及Filestream选项:

 

 

 

11.安装后需要重新启动(可以查看安装日志):

 

 

 

12.在ConfigurationManager中对SQL Server开启Always OnHigh Availability(可以自动检测到前面我们创建的Cluster名字)

 

 

 

设置更改后需要重启Service.现在一切都具备了,虚拟主机,我们可以配置Always On group了。

 

1.创建新的可用性组(可用性组向导,也可以用下面的选型):

 

                             

 

 

   2.输入可用性组的名字:

 

 

 

3.选择组中的数据库:

 

 

 

4.Replica 选择Node2(选择自动Failover/可读数据库):

 

 

 

5.点击下一步,Node1将会备份数据库到Share Folder然后还原到Node2做同步 (Node1为主,Node2为辅助)

 

 

 

 

下一步就是测试Node2数据可读已经Failover.

 

 

可用性组我们已经创建成功了,现在测试一下Node2 上读取数据以及Failover.

 

1.  数据测据:Node1上创建表test插入记录

 

    

 

 

在Node2上访问test数据库,数据可以查到(在Mirror中是不可以查询的,而且数据同步不会导致Node2的连接断掉):

 

 

2.  Failover测试:

 

 

连接到Node2:

 

 

 

 

 

Failover后(Primary已经变成Node2):

 

 

 

 可以看到Always On group 既保证了高可用性,有可以实现同步数据库的只读访问,提供了硬件的利用率,非常给力的一个功能。

 

 

版权声明:本文内容由互联网用户自发贡献,该文观点仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。
如发现本站有涉嫌抄袭侵权/违法违规的内容, 请发送邮件至 chuangxiangniao@163.com 举报,一经查实,本站将立刻删除。
发布者:程序猿,转转请注明出处:https://www.chuangxiangniao.com/p/902051.html

(0)
打赏 微信扫一扫 微信扫一扫 支付宝扫一扫 支付宝扫一扫
上一篇 2025年11月28日 20:58:06
下一篇 2025年11月28日 21:28:31

相关推荐

  • 火狐如何切换html5_火狐浏览器启用HTML5模式设置方法【浏览器切换】

    火狐浏览器需手动启用HTML5支持:一、在about:config中启用media.mediasource.enabled、webgl.enable-for-all-sites和dom.webaudio.enabled;二、禁用Flash插件并允许自动播放;三、开启Web Components、H.…

    2025年12月23日
    000
  • 在vscode中怎么运行html_vscode运行html文件方法【教程】

    1、使用Live Server扩展可实现自动刷新预览,安装后右键选择Open with Live Server即可在浏览器中实时查看HTML页面效果。 如果您在使用VSCode编写HTML文件,但不知道如何快速预览页面效果,可以通过多种方式在浏览器中运行HTML文件。以下是几种常用的实现方法: 一、…

    2025年12月23日
    000
  • html怎么在浏览器上运行php文件_浏览器运html中php文件方法【教程】

    PHP代码需服务器解析才能执行。1、安装XAMPP等集成环境,启动服务后将文件放入htdocs目录,通过http://localhost访问;2、VS Code安装PHP Server插件,右键文件选择“Open with PHP Server”即可在浏览器查看运行结果;3、使用3v4l.org等在…

    2025年12月23日
    000
  • 团队协作时如何统一HTML格式化标准_团队协作HTML格式化标准统一方法

    使用Prettier统一HTML格式,通过工具自动化和团队约定解决协作开发中的代码风格不一致问题。首先在项目中安装Prettier并配置.prettierrc文件,定义缩进、引号等规则;配合VS Code插件实现保存自动格式化;进一步结合Husky与lint-staged,在Git提交前自动执行格式…

    2025年12月22日
    000
  • 前端输出设置

    前端output配置,需要具体代码示例 前端开发中,output配置是一项非常重要的配置。它用于定义项目打包后生成的文件路径、文件名以及相关的资源路径等。本文将介绍前端output配置的作用、常用配置选项,并给出具体的代码示例。 output配置的作用:output配置项用于指定项目打包后生成的文件…

    2025年12月22日
    000
  • 在React应用中实现沙盒与生产环境的动态切换与API管理

    本教程详细介绍了如何在React应用中构建一个健壮的环境切换机制,以动态管理沙盒(Sandbox)与生产(Production)模式。内容涵盖了如何通过集中式配置定义不同环境的API端点,实现UI界面的实时更新,以及利用API抽象层确保API请求根据当前环境自动路由,从而提升应用的可维护性和开发效率…

    2025年12月21日
    000
  • Kubernetes JavaScript应用部署

    答案:在Kubernetes中部署JavaScript应用需先容器化Node.js服务,构建并推送Docker镜像,编写Deployment和Service配置文件,最后通过kubectl部署并暴露服务。1. 创建Express应用并定义启动脚本;2. 编写Dockerfile构建镜像,推送到镜像仓…

    2025年12月20日 好文分享
    000
  • Next.js构建ID的获取与在客户端展示教程

    本教程详细阐述了如何在Next.js应用中获取并自定义构建ID,并通过next.config.js将其作为环境变量暴露。文章重点介绍了如何利用next-build-id包基于Git版本生成ID,以及如何区分服务器端和客户端环境变量,最终实现在浏览器控制台显示构建ID的方法。 Next.js构建ID的…

    2025年12月20日
    000
  • 如何配置JS负载均衡?

    答案:JavaScript负载均衡将请求路由决策下放至客户端,通过浏览器端JS从后端服务列表中按策略选择目标地址,补充传统服务端负载均衡。它适用于多CDN切换、边缘计算、微服务降级等场景,提升系统弹性与用户体验。常见实现策略包括轮询、随机、加权及基于延迟的动态选择,并可通过Service Worke…

    2025年12月20日
    000
  • 如何配置JS代码签名?

    答案:JavaScript代码“签名”主要通过子资源完整性(SRI)实现,利用哈希值验证脚本完整性。首先为JS文件生成SHA-384等哈希值,命令如cat your-script.js | openssl dgst -sha384 -binary | openssl base64 -A,得到形如sh…

    2025年12月20日
    000
  • 如何配置JS弹性伸缩?

    代码分割通过将JS应用拆分为按需加载的模块,减少初始加载时间,提升缓存效率,优化资源利用,从而实现前端弹性伸缩。 在前端领域,我们谈论“JS弹性伸缩”时,通常不是指服务器那种根据负载自动增减实例的物理扩容,而是指JavaScript应用本身,如何智能地根据用户设备、网络环境和交互需求,动态调整其资源…

    2025年12月20日
    000
  • 如何配置JS无缝升级?

    答案:Service Worker通过install、activate和fetch事件实现JS无缝升级,利用缓存策略和版本化资源确保平滑更新;在activate阶段清理旧缓存,fetch中采用stale-while-revalidate策略提升体验,结合skipWaiting和clients.cla…

    2025年12月20日
    000
  • 如何配置JS错误跟踪?

    配置JS错误跟踪需选择Sentry等服务,注册获取DSN,集成SDK并初始化,通过window.onerror和onunhandledrejection捕获全局错误与Promise拒绝,结合try…catch处理异常,配置Source Maps还原压缩代码错误位置,注意敏感数据过滤与采样…

    2025年12月20日
    000
  • 如何配置JS代码检查?

    答案:JS代码检查通过工具如ESLint、JSHint、JSLint提前发现代码问题。ESLint因可配置性强、支持TypeScript和JSX、社区活跃成为主流,适合复杂项目;JSHint和JSLint规则固定,适合简单语法检查。集成ESLint需安装Node.js和npm,运行npm insta…

    2025年12月20日
    000
  • c++怎么用Protobuf进行数据序列化_c++结构化数据编码与跨语言通信方案

    Protobuf通过定义.proto文件实现高效数据序列化,使用protoc生成C++代码,通过SerializeToOstream和ParseFromIstream完成序列化与反序列化,支持跨语言通信,需保持字段编号不变以确保兼容性。 在C++中使用Protobuf(Protocol Buffer…

    2025年12月19日
    000
  • C++如何将程序注册为系统服务(Windows/Linux)_C++服务进程创建与系统集成方法

    答案:Windows通过SCM注册C++程序为服务,需编写服务入口函数并用sc命令注册;Linux使用systemd,编写单元文件并配置启动参数。两者均需处理权限、日志与进程管理,跨平台时可用条件编译适配逻辑。 在Windows和Linux系统中,将C++程序注册为系统服务可以让其随系统启动自动运行…

    2025年12月19日
    000
  • 如何在C++中读取文件内容到字符串_C++文件内容读取技巧

    最推荐使用std::istreambuf_iterator将文件内容一次性读入std::string,因其高效且简洁;需注意错误处理与编码问题,对大文件可采用逐行读取或内存映射优化性能。 在C++中,将文件内容读取到字符串最直接且高效的方法,通常是利用 std::ifstream 配合 std::i…

    2025年12月19日
    000
  • 如何用C++实现桥接模式 抽象与实现分离设计方案

    c++++中桥接模式的核心优势在于解耦抽象与实现,使其能独立变化。1. 它通过将一个类中可能变动的具体操作抽离为独立的实现体系,降低类组合数量,避免“m x n”组合爆炸;2. 抽象类(如shape)包含指向实现接口的指针或引用,调用具体实现(如drawingapi),使两者互不影响;3. 适用于多…

    2025年12月18日 好文分享
    200
  • 揭秘C++框架的配置和加载过程

    c++++ 框架配置过程涉及设置编译选项、链接标志和其他参数,以确保在特定环境中正确运行。加载过程包括实例化框架对象、初始化它并使用其提供的组件和服务。实战案例演示了使用 qt 框架配置和加载 gui 应用程序的过程,其中 qtconfig 用于设置编译选项,而 qapplication 类实例化并…

    2025年12月18日
    000
  • C# Avalonia如何集成Entity Framework Core Avalonia EF Core教程

    在 Avalonia 中集成 EF Core 可行,关键在于异步操作、DI 注入 DbContextFactory 及正确管理生命周期;需避免 UI 线程阻塞,推荐用 AddDbContextFactory 而非 Scoped 或 Singleton 注册。 在 Avalonia 中集成 Entit…

    2025年12月17日
    000

发表回复

登录后才能评论
关注微信