如何使用MSCS建立SQL Server集群

集群是一种技术解决方案,它将硬件和软件结合起来,为Web、Email以及数据库等服务提供高可用性和高伸缩性的架构。本文将分析集群的类型,然后将重点放在如何建立一个基于Microsoft的集群解决方案。

集群的类型

集群分为两种类型:负载平衡和失效转移(Failover)。负载平衡集群将负载分散到集群内的各个资源,这要涉及跨越多个前端服务器的分布式网络传输。负载平衡集群令每个可用的服务器都拥有较为平均的负载量,以提高系统整体的性能和伸缩能力。这类集群一般用于Web和COM+程序,集群内部支持两个以上的节点。

Failover集群主要针对硬件和软件故障时的系统可用性。它监视系统资源,以确定何时启动失效转移。当系统发生故障时,集群会将资源从故障服务器转移到集群中的其他服务器,以恢复资源的可访问性。

一个具有容错能力的failover集群需要大量的硬件和专用软件,确定应用状态,它可以在硬件和软件发生故障时进行实时故障恢复,包括恢复到当前的应用状态。一个高可用性的集群必定是一个具有容错能力的集群,但它不一定能提供和failover集群同样的错误恢复能力。

Microsoft的Cluster Service (MSCS)是一种比容错集群更好的高可用性集群。它和专用的容错集群相比,所需硬件更少,但可以操作更多种类的应用。同时,它也可以对硬件和软件的故障进行恢复,但发生故障时无法正常恢复到应用状态则。高可用性的MSCS可以在一个集群内支持两个服务器节点。

基本的软硬件组件

集群中的服务器节点都采用各自独立的硬件设备,相互间协同工作。每个服务器有自己的操作系统,并独立连接在网络上。服务器间采用外部硬盘和专用网络连接。共享硬盘通过硬盘控制器与各个节点相连,这种硬盘控制器一般采用外置SCSI设备或存储局域网(SAN)作为共享硬盘,不同于包含操作系统的硬盘控制器。

MSCS解决方案可以采用主动/被动模式工作。在同一时间集群中只有一个节点是主动的,主动服务器存储着集群内的全部资源,并不断将数据写入共享硬盘,这就是所谓的quorum驱动器。它可以在故障恢复时,将共享状态信息从一个节点转移到另一个节点。定时的发送信号会通过服务器间的专用网传递,当处于被动模式的服务器没有受到这个信号,就认为主动服务器已经失效。此时,它便开始接管集群资源,并从quorum分区上读取状态信息。

在集群中安装 SQL Server

为了在集群上安装 SQL Server ,你必须首先按以下步骤建立一个可操作的集群:

1. 在每个服务器上安装支持MSCS的Windows Server操作系统。

2. 为每个服务器建立一个"公开的"网络连接。这个连接用来接收外部查询请求。

3. 在集群的两个节点间建立一个专用网络,用来传输节点状态信号。

4. 在域中建立一个用户,用来操作集群。在每个服务器上将该用户添加到管理员组。

5. 将两个服务器关闭。连接到共享驱动器上,并建立磁盘资源。开启集群中的一号节点(主动模式)。建立并初始化逻辑磁盘空间用来设置quorum驱动器,并建立其它的逻辑分区。

6. 通过控制面板的添加/删除程序中的Windows组件添加并配置Microsoft Cluster Service。其中包括设置集群的虚拟名称、IP地址,以及共享磁盘资源。

7. 开启二号节点(被动模式)。当二号节点在线时,回到一号节点,通过集群管理程序添加二号节点。在集群中添加二号节点非常容易,只要通过在一号节点进行简单配置就可以完成。

集群建立好后,就按照以下步骤安装SQL Server了:

1. 插入SQL Server企业版的安装光盘。如果没有启动自动安装程序,就在光盘上点击setup.exe。

2. 在确认计算机名界面,选择虚拟服务器并输入一个虚拟名称。

3. 建立一个运行SQL Server的服务账号。将集群中每个节点的管理权限赋给这个账号。

4. 填写IP地址、服务账号,以及共享磁盘资源等内容。

安装程序会在集群中的每个节点上安装SQL Server的复本,并在集群中建立虚拟设置。之后用户就可以通过集群管理器对SQL Server进行控制了。

时间: 2024-09-19 09:40:13

如何使用MSCS建立SQL Server集群的相关文章

SQL Server集群服务器的优缺点

由二台或更多物理上独立的服务器共同组成的"虚拟"服务器称之为集群服务器.一项称做MicroSoft集群服务(MSCS)的微软服务可对集群服务器进行管理.一个SQL Server集群是由二台或更多运行SQL Server的服务器(节点)组成的虚拟服务器.如果集群中的一个节点发生故障,集群中的另一个节点就承担这个故障节点的责任. 认为一个 SQL Server集群能够给集群中的两个节点带来负载平衡,这是一种常见的误解.虽然这似乎很有用,但却是不正确的.这也意味着集束SQL Server不能

visual studio-vs2015中有个建立sql server项目有什么用

问题描述 vs2015中有个建立sql server项目有什么用 vs2015默认装了sql server有什么用呢?用再装一个sql server么,vs2015装sql server哪种版本好呢? 解决方案 vs2015默认会安装sql server express.sql localdb和sql ce 开发来说,足够了. 解决方案二: 你想将数据保存到数据库就有用了

建立HBase的集群和HDInsight在Hadoop中使用Hive来查询它们

建立HBase的集群和HDInsight在Hadoop中使用Hive来查询它们 在本教程中,您将学习如何创建和查询HDInsight使用HiveHadoop的HBase的表.下列步骤描述:•如何使用提供在Azure门户的HBase的集群.•如何启用和使用RDP访问HBase的外壳,并使用HBase的外壳创建HBase的示例表,添加行,然后列出表中的行.•如何创建一个Hive表映射到一个现有的HBase的表,使用HiveQL查询数据在HBase的表.•如何使用Microsoft HBase的RES

fms-求flash media server集群方案

问题描述 求flash media server集群方案 需要做视频网站,怎么对fms做集群, 有一个外网静态IP ,大概方案是什么

6点入手建立SQL Server 2000安全策略

SQL Server 是一个关系数据库管理系统它最初是由Microsoft Sybase 和Ashton-Tate三家公司共同开发的于1988 年推出了第一个OS/2 版本在Windows NT 推出后Microsoft与Sybase 在SQL Server 的开发上就分道扬镳了Microsoft 将SQL Server 移植到Windows NT系统上专注于开发推广SQL Server 的Windows NT 版本Sybase 则较专注于SQL Server在UNIX 操作系统上的应用在本书中

用扩展属性和第三方工具建立SQL Server数据字典

数据字典是一个数据模型中数据和对象的相关描述集合,它有利于程序员和用户在创建应用程序.报 告时查阅数据和对象.当用到数据模型时,创建一个数据字典是很理想的.当数据库很小时,开发人员 经常利用内嵌的SQL Server工具和脚本来创建数据模型.但是当数据库模型变成企业级的数据模型并且 具有相对应的复杂性时,管理和维护的复杂性也随之增加.所以可以用什么办法管理和创建这样的数据 模型呢?有没有什么可用的第三方工具呢? 迄今为止,大多数数据建模工具使用相同的方法存储数据 字典.一些工具可能使用不同的术语

用Excel建立SQL Server数据字典和报表的脚本

这是一个很好的问题.解决这个问题最简单的方法是从扩展属性中获得值到物理表中,因此你可以很容易通过Microsoft Excel.报表服务或其它任何报表工具导出数据. 要启动这个过程,你需要配置下面列出的存储过程dbo.sp_get_extendedproperty. [dbo].[sp_get_extendedproperty] USE [master] GO CREATE PROCEDURE [dbo].[sp_get_extendedproperty] @databasename varch

SQL Server 2000集群服务器优缺点

由二台或更多物理上独立的服务器共同组成的"虚拟"服务器称之为集群服务器.一项称做MicroSoft集群服务(MSCS)的微软服务可对集群服务器进行管理.一个SQL Server集群是由二台或更多运行SQL Server的服务器(节点)组成的虚拟服务器.如果集群中的一个节点发生故障,集群中的另一个节点就承担这个故障节点的责任. 认为一个SQL Server集群能够给集群中的两个节点带来负载平衡,这是一种常见的误解.虽然这似乎很有用,但却是不正确的.这也意味着集束SQL Server不能真

在JBoss集群中建立JMS集群服务

JMS集群的意义在于提升系统在处理消息时的并发能力,建立这样的集群,有三个步骤: 1.配置JMS消息持久化所使用的数据库 2.配置分布式的jndi环境 3.配置分布式JMS集群 在JBoss集群中,系统采用hibernate的方式来保存消息,所以能够兼容hibernate支持的所有数据库. JBoss默认采用 hsql,在我们的例子中,将使用oracle 9.2.首先需要配置连接到数据库的jndi数据源. 方法是把doc\examples\jca下的 oracle-ds.xml文件拷贝到serv