实战:监控sqlserver 2008 R2群集状态

实战:监控sqlserver 2008 R2群集状态,第1张

概述  declare @OutputType varchar(20) declare @debug char(1) declare @ForceRefresh char(1) declare  @xp_cmdshell_available char(1) set @OutputType='LIST' set  @Debug= 'Y' set  @ForceRefresh= 'Y' set  @xp_  

declare @OutputType varchar(20)
declare @deBUG char(1)
declare @ForceRefresh char(1)
declare  @xp_cmdshell_available char(1)

set @OutputType='List'
set  @DeBUG= 'Y'
set  @ForceRefresh= 'Y'
set  @xp_cmdshell_available = 'Y'

begin
  set nocount on
declare @ID int
declare @ID2 int
declare @line varchar(300)
declare @CurrentCmd varchar(30)
declare @Cmd varchar(300)
declare @Node varchar(100)
declare @Resource varchar(100)
declare @Status varchar(20)
declare @i int
declare @Group varchar(100)
declare @Num varchar(10)
declare @ClusterID int
declare @tmp int
declare @ThisGroupsCurrentNode varchar(100)
declare @DoneClustername char(1)
declare @RunningOnACluster char(1)
declare @line2 varchar(300)
declare @sqlname sysname
declare @windowsMachinename sysname
declare @PreferredServer sysname
declare @sql varchar(4100)
declare @FailCnt int
declare @PreferredServers int
declare @z int
declare @CurrentsqlServerGroup sysname
declare @CurrentsqlServer sysname
declare @QuorumResource varchar(300)
declare @CreatedTemptables char(1)
declare @LoopGroup varchar(300)
declare @PreferredServerExists char(1)
if @DeBUG = 'Y' print convert(varchar(30),getdate(),109) + ': ' + object_name(@@procID) + ' started.'
select @DoneClustername = 'N'

--验证@OutputType类型
if lower(@OutputType) in ('q','quick', 's','summary', 'sum') select @OutputType = 'Quick'
else if lower(@OutputType) in ('l', 'List') select @OutputType = 'List'
else
begin
 select @Cmd = 'Error in ' + object_name(@@procID) +
   ': @OutputType parameter must be ''Quick'' or ''List'',not ''' +
   isnull(@OutputType,'<null>') + '''.'
 raiserror 50001 @Cmd
 return
end

if UPPER(@xp_cmdshell_available) in ('Y','')
 SET @xp_cmdshell_available = 'Y'
else
 SET @xp_cmdshell_available = 'N'
if @DeBUG = 'Y' print convert(varchar(30),109) + ': Calling Spot_CheckCluster...'
select @FailCnt = 0,@PreferredServers = 0

--检查xp_cmdshell是否开启

--declare @Localtable table(result int,ErrorCode int)
--insert into @Localtable
-- execute QS_SoSS58_CheckCmdshell
--if 1 <> (select count(*) from @Localtable where result = 1)

  if (0 = (select value_in_use from sys.configurations where name = 'xp_cmdshell'))
 set @xp_cmdshell_available = 'N'
 
 select @RunningOnACluster = case when convert(int,serverproperty('IsClustered')) = 1 then 'Y' else 'N' end
  set @sqlname = convert(sysname,serverproperty('Servername'))
 
  set @windowsMachinename = convert(sysname,serverproperty('Machinename'))
 
if @DeBUG = 'Y' print convert(varchar(30),109) + ': 创建临时表...'
create table #w3
(ID int IDentity,
 ParentID int null,
 Type varchar(20) null,
 name sysname null,
 OtherData sysname null,
 Status varchar(20) null,
 Comment varchar(255) null,
 PreferredServerExists char(1),
 RunningOnPreferredServer char(1) null,
 ControlsTheCurrentsqlServer char(1) null,
 TakeOfflineCmd char(1) null,
 BringOnlineCmd char(1) null,
 MoveGroupCmd char(1) null,
 StopMSCSCmd char(1) null,
 StartMSCSCmd char(1) null,
 RunningOnServer sysname null,
 Sequencer smallint null
 )
 
create table #w4 (ID int IDentity(1,1), group_name varchar(255) NulL)

create table #CmdOutput
(
ID int IDentity,
Outputline varchar(255) null
)
create unique clustered index #PK_CmdOutput on #CmdOutput(ID)
select @CreatedTemptables = 'Y'


if @RunningOnACluster = 'N'
begin
 if @DeBUG = 'Y' print convert(varchar(30),109) + ': 非群集 - 退出...'
 goto OutputData
end

if UPPER(@xp_cmdshell_available) = 'N'
begin
 if @DeBUG = 'Y' print convert(varchar(30),109) + ': xp_cmdshell不可用 - 退出...'
 goto OutputData
end

 

if @OutputType = 'List' 
 Select @Cmd = 'echo Cluster name & cluster /ver | findstr "name" & cluster node & cluster group & cluster resource & cluster /quorum'
else
 select @Cmd = 'cluster node & cluster group & cluster resource'

if @DeBUG = 'Y' print convert(varchar(30),109) + ': 运行系统的群集命令: ' + @Cmd
insert into #CmdOutput with (tablockx) (Outputline)
  exec xp_cmdshell @Cmd
if @DeBUG = 'Y' print convert(varchar(30),109) + ': 系统命令结束...'
if @DeBUG = 'Y' select Outputline from #CmdOutput order by ID
if @DeBUG = 'Y' print convert(varchar(30),109) + ': 解释数据...'
select @CurrentCmd = 'none'


select @ID = 0
while 1 = 1
begin
 if @DeBUG = 'Y' print convert(varchar(30),109) + ': - 开始获取下一条记录...'
 select @ID = min(ID)
 from #CmdOutput
 where ID > @ID
  and Outputline not like '-------%'
  and isnull(Outputline,'') <> ''
  and Outputline <> char(13)
 if @@rowcount = 0 or @ID is null break
 select @line = replace(replace(Outputline,char(13),' '),char(12),' ')
 from #CmdOutput
 where ID = @ID
 if @@rowcount = 0 break
 if @DeBUG = 'Y' print convert(varchar(30),109) + ': - 获得下一条记录...'
 select @Node = '',@Group = '',@Resource = '',@Status = '',@tmp = 0,
  @line2 = @line
 select @line = replace(@line,'Online Pending','OnlinePending')
 select @line = replace(@line,'Offline Pending','OfflinePending')
 if @line like 'Listing status for%'
 or @line like 'Quorum Resource name%'
 begin
  select @CurrentCmd = 'none'

 end
 if @DeBUG = 'Y' print convert(varchar(30),109) + ':  @CurrentCmd = ' + @CurrentCmd
 if @CurrentCmd <> 'none'
 begin

  if @CurrentCmd = 'clusterList'
  and @OutputType = 'List'  
  begin
   ClusterList:
   select @line = LTRIM(RTRIM(SUBSTRING(@line,14,999)))
   insert into #w3 with (tablockx) (ParentID,Type,name,Status,Sequencer)
    select 0,@CurrentCmd,@line,'',10
   select @CurrentCmd = 'none',@ClusterID = @@IDentity
   
   insert into #w3 with (tablockx) (ParentID,Sequencer)
    select @ClusterID,'Groups',20
   insert into #w3 with (tablockx) (ParentID,'Servers',60
   select @DoneClustername = 'Y'
  end
  if @CurrentCmd = 'nodeList'
  begin
   if @DeBUG = 'Y' print convert(varchar(30),109) + ':   - ' + @CurrentCmd + ' text scan...'
   select @Node = substring(@line,1,charindex(' ',@line)),
    @line = ltrim(substring(@line,@line),999))
   select @Num = substring(@line,999))
   select @Status = substring(@line,@line))
   if @DeBUG = 'Y' print convert(varchar(30),109) + ':   - ' + @CurrentCmd + ' lookup...'
   select @tmp = ID from #w3
   where Type = 'Servers'
   if @DeBUG = 'Y' print convert(varchar(30),109) + ':   - ' + @CurrentCmd + ' insert(1)...'
   insert into #w3 with (tablockx) (ParentID,Sequencer)
   values (@tmp,'Node',@Node,@Status,70)
   select @tmp = @@IDentity
   if @DeBUG = 'Y' print convert(varchar(30),109) + ':   - ' + @CurrentCmd + ' insert(2&3)...'
   insert into #w3 with (tablockx) (ParentID,OtherData,'NodeGroups','Active Groups',80)
  end
  if @CurrentCmd = 'groupList'
  begin
   select @line = LTRIM(RTRIM(REVERSE(@line)))
   select @Status = LTRIM(RTRIM(REVERSE(substring(@line,@line))))),999))
   if @Status = 'Online' and REVERSE(LTRIM(RTRIM(SUBSTRING(@line,9)))) = 'Partially'
    select @Status = LTRIM(RTRIM(REVERSE(substring(@line,@line))))) + ' ' + @Status,999))
   select @Node = LTRIM(RTRIM(REVERSE(substring(@line,999))
   select @Group = REVERSE(LTRIM(RTRIM(@line)))
   select @tmp = ID from #w3
   where Type = 'Groups'
   insert into #w4 with (tablockx) (group_name) SELECT @Group
   insert into #w3 with (tablockx) (ParentID,RunningOnServer,Sequencer)
   select @tmp,'Group',@Group,30
   select @tmp = @@IDentity
   insert into #w3 with (tablockx) (ParentID,'GroupResources','Resources',40
   insert into #w3 with (tablockx) (ParentID,'PreferredServers','Preferred Servers',45
   select @tmp = ID from #w3
   where Type = 'NodeGroups'
    and OtherData = @Node
   if @@rowcount = 0 select @tmp = 0
   insert into #w3 with (tablockx) (ParentID,'NodeGroup',90
  end
  
  if @CurrentCmd = 'resourceList'
  and @OutputType = 'List' 
  begin
   --  We need to parse this in reverse order
   select @line = ltrim(rtrim(reverse(@line)))
   select @Status = substring(@line,999))
   select @Node = substring(@line,999))
   select @ID2 = 0
   while 1 = 1
   begin
    select @ID2 = ID,@LoopGroup = RTRIM(LTRIM(group_name)) from #w4 where ID = (select min(ID) from #w4 where ID > @ID2)
    if @@ROWCOUNT = 0
    begin
     SELECT @LoopGroup = ''
     break
    end
    if @LoopGroup = RTRIM(LTRIM(REVERSE(SUBSTRING(@line,DataLength(@LoopGroup)))))
    begin
     select @Group = @LoopGroup
     break
    end
   end
   SELECT @line = ltrim(substring(@line,DATALENGTH(@LoopGroup) + 1,999))
   select @Resource = @line
   select  @Status = ltrim(rtrim(reverse(@Status))),
    @Node = ltrim(rtrim(reverse(@Node))),
    @Resource = ltrim(rtrim(reverse(@Resource)))
   select @tmp = ID from #w3
   where Type = 'GroupResources'
    and OtherData = @Group
    
   if @@rowcount = 0 select @tmp = 0
   insert into #w3 with (tablockx) (ParentID,'GroupResource',@Resource,50
   select @tmp = ID from #w3
   where Type = 'NodeGroup'
    and name = @Group
    and OtherData = @Node
   if @@rowcount = 0 select @tmp = 0
   insert into #w3 with (tablockx) (ParentID,'NodeGroupRes',substring(@Node + '\' + @Group,100),100
  end
  
  if @CurrentCmd = 'quorum'
  and @OutputType = 'List' 
  begin
   select @QuorumResource = @line
  end
 end
 select @line = @line2
 if @line = 'Cluster name'
 begin
  select @CurrentCmd = 'clusterList'
 end
 if @line like 'Node%Node%ID%status%'
 begin
  if @DoneClustername = 'N'
  begin
   Select @line = 'CLUSTER' 
   select @DoneClustername = 'Y'
   if @DeBUG = 'Y' print convert(varchar(30),109) + ': 没有群集名用 - 使用默认值 ''' + @line + '''...'
   goto ClusterList
  end
  select @CurrentCmd = 'nodeList'
 end
 if @line like 'Group%Node%status%'
 begin
  select @CurrentCmd = 'groupList'
 end
 if @line like 'Resource%Group%Node%status%'
 begin
  select @CurrentCmd = 'resourceList'
 end
 if @line like 'Quorum%resource%name%'
 begin
  select @CurrentCmd = 'quorum'
 end
  
end

if @DeBUG = 'Y' print convert(varchar(30),109) + ': 收集首选服务器...'
select @ID = 0
while 1 = 1
begin
 delete from #CmdOutput with (tablockx)
 select @Group = rtrim(name),@ID = ID,@ThisGroupsCurrentNode = OtherData
 from #w3
 where Type = 'Group'
  and ID > @ID
 order by ID desc
 if @@rowcount = 0 break
 select @tmp = ID from #w3
 where Type = 'PreferredServers'
  and OtherData = @Group
 if @@rowcount = 0 select @tmp = 0
 if @DeBUG = 'Y' print convert(varchar(30),109) + ': 开始进程ID ' + convert(varchar(5),@tmp) + ' ...'
 select @Cmd = 'cluster group "' + @Group + '" /Listowners'
 insert into #CmdOutput (Outputline)
 exec xp_cmdshell @Cmd

 declare PScsr cursor for
 select Outputline
 from #CmdOutput
 where isnull(Outputline,'') <> ''
  and Outputline <> char(13)
  and Outputline not like 'Preferred Owner Nodes%'
  and Outputline not like '--------%'
  and Outputline not like 'Listing preferred%'
 order by ID
 open PScsr
 select @z = 0
 while 1 = 1
 begin
  fetch PScsr into @Cmd
  if @@fetch_Status <> 0 break
  select @z = @z + 1
  insert into #w3 with (tablockx) (ParentID,Sequencer)
  select @tmp,'PreferredServer',replace(@Cmd,''),50 + @z
 end
 close PScsr
 deallocate PScsr
 if @z = 0
 begin
  if @DeBUG = 'Y' print convert(varchar(30),109) + '        : 没有首选的服务器组发现 "' + @Group + '" - 分配所有服务器...'
  insert into #w3 with (tablockx) (ParentID,Sequencer,PreferredServerExists)
  select @tmp,@ThisGroupsCurrentNode,51,'N'
  insert into #w3 with (tablockx) (ParentID,52,'N'
  from #w3
  where Type = 'Node'
  and name <> @ThisGroupsCurrentNode
 end
 else
 begin
  If @DeBUG = 'Y' print convert(varchar(30),109) + '        ... 检查组"' + @Group + '"是否在首选服务器上运行'
  select @tmp = 0
  select @tmp = node.ID
  from #w3 curr,
   #w3 node
  where curr.Type = 'Group'
   and curr.name = @Group
   and curr.name = node.OtherData
   and node.Type = 'PreferredServer'
   and curr.OtherData = node.name
  select @PreferredServer = node.name,@PreferredServerExists = node.PreferredServerExists
  from #w3 node
  where node.Type = 'PreferredServer'
   and node.OtherData = @Group
  order by ID desc
 
  if exists (select 1
    from #w3
    where Type = 'PreferredServer'
     and OtherData = @Group
     and ID < @tmp)
  begin
   select @PreferredServers = @PreferredServers + 1
   if @OutputType = 'List'
   begin
    If @DeBUG = 'Y' print convert(varchar(30),109) + '        --- 未在首选的服务器上运行'
    update #w3 with (tablockx)
    set RunningOnPreferredServer = 'N',
      Comment =
     Case @PreferredServerExists
      when 'N' then 'No preferred server has been set.'
      else 'Warning: Not running on preferred server (' + isnull(@PreferredServer,'<null>') + ').'
     end
    where ID = @ID
    and Status = 'Online'
     update b
    set RunningOnPreferredServer = a.RunningOnPreferredServer,
     Comment = a.Comment
    from #w3 a
     join #w3 b
     on a.ID = @ID
     and b.Type = 'NodeGroup'
     and b.name = @Group
    where  a.ID = @ID
    and b.Type = 'NodeGroup'
    and b.name = @Group
   end
  end
 end
 if @DeBUG = 'Y' print convert(varchar(30),109) + ': 完成进程ID'
end
select @CurrentsqlServerGroup = null
if @OutputType = 'List'
begin
 if @DeBUG = 'Y' print convert(varchar(30),109) + ': 设置优选服务器状态...'
 update ps
 set Status = node.Status
 from #w3 ps join #w3 node
  on node.Type = 'Node'
    and ps.Type = 'PreferredServer'
    and node.name = ps.name
 if @DeBUG = 'Y' print convert(varchar(30),109) + ': 收集当前的sql Server依赖...'
 select @ID = 0
 while 1 = 1
 begin
  delete from #CmdOutput with (tablockx)
  select @Resource = rtrim(name),@Group = rtrim(OtherData),@ID = ID
  from #w3
  where Type = 'GroupResource'
   and ID > @ID
  order by ID desc
  if @@rowcount = 0 break
 
  select @Cmd =  'cluster resource "' + @Resource + '" /prop:type' +
    ' & ' +
    'cluster resource "' + @Resource + '" /priv:name'
  insert into #CmdOutput with (tablockx) (Outputline)
  exec xp_cmdshell @Cmd
  if exists (select 1 from #CmdOutput
    where Outputline like '%Type%Network name%')
  begin
   if exists (select 1 from #CmdOutput
     where replace(Outputline,'') + '    ' like '%  ' + @windowsMachinename + '   %')
   begin
    select @CurrentsqlServerGroup = @Group
    break
   end
  end
 
 end
 select @CurrentsqlServer = null
 select @CurrentsqlServer = OtherData
 from #w3
 where Type = 'NodeGroup'
  and name = @CurrentsqlServerGroup
 if @DeBUG = 'Y' print convert(varchar(30),109) + ': sql Server 组是: ' + isnull(@CurrentsqlServerGroup,'<null>') +
    ',运行在节点: ' + isnull(@CurrentsqlServer,'<null>')
 
 update #w3 with (tablockx)
 set ControlsTheCurrentsqlServer = 'Y'
 where Type = 'clusterList'
   or (Type in ('Group','NodeGroup') and name in (@CurrentsqlServerGroup,@CurrentsqlServer))
   or (Type in ('Node') and name = @CurrentsqlServer)
   or ((OtherData = @CurrentsqlServerGroup or OtherData like '%\' + @CurrentsqlServerGroup)
  and name not like '%sql Server Agent%'
  and name not like '%sql Server Fulltext%'
  and name not like '%MSDTC%')
 update #w3 with (tablockx)
 set ControlsTheCurrentsqlServer = 'N'
 where ControlsTheCurrentsqlServer is null
 update #w3 with (tablockx)
 set  TakeOfflineCmd = case when Type in ('Group','NodeGroupRes') and Status in('Online','Partially','Pending') and ControlsTheCurrentsqlServer = 'N'
      then 'Y'
      else 'N'
     end,
  BringOnlineCmd = case when Type in ('Group','NodeGroupRes') and Status in ('Offline','Failed','Partially Online') and ControlsTheCurrentsqlServer = 'N'
      then 'Y'
      else 'N'
     end,
  MoveGroupCmd = case when Type in ('Group','NodeGroup') and ControlsTheCurrentsqlServer = 'N'
      then 'Y'
      else 'N'
     end,
  StopMSCSCmd = 'N',
  StartMSCSCmd = 'N'
  
 update #w3 with (tablockx)
 set Comment = '没有可用的群集节点.'
 where Type in ('Node','PreferredServer')
  and isnull(Status,'') <> 'Up'
  and isnull(Comment,'') = ''  

 update #w3 with (tablockx)
 set Comment = '警告: 群集 ' +
    case  when Type like '%res%' then '资源'
     when Type like '%Group%' then '组'
     else Type
    end + ' offline.'
 where Status = 'Offline'
  and isnull(Comment,'') = ''  
 update #w3 with (tablockx)
 set Comment = '警告: 群集组包括一些脱机资源.'
  where Status like '%Partial%'
  and isnull(Comment,'') = ''  
 update #w3 with (tablockx)
 set Comment = '群集资源失败.'
 where Status like '%Failed%'
  and isnull(Comment,'') = ''  
 update #w3 with (tablockx)
 set Comment = '<== 仲裁资源',
  TakeOfflineCmd = 'N'
 where @QuorumResource like name + '%'
  and isnull(Comment,'') = ''  
 update #w3 with (tablockx)
 set Comment = '<== 当前的sql Server组'
 where name = @CurrentsqlServerGroup
  and isnull(Comment,'') = ''  
end

OutputData:
if @DeBUG = 'Y' print convert(varchar(30),109) + ': 输出数据...'

if @OutputType = 'List'
begin

 if @RunningOnACluster = 'N'
 begin
  insert into #w3 with (tablockx) (ParentID,Comment)
  select 0,'Msg','非群集','sql Server 没有运行在一个群集服务器上!'
 end
 else if UPPER(@xp_cmdshell_available) = 'N'
 begin
  insert into #w3 with (tablockx) (ParentID,'不能使用xp_cmdshell. 没有数据可用!'
 end
 
 select ID   as 'ID',
  ParentID   as 'ParentID',
  Type   as 'Type',
  name  as 'name',
  replace(replace(
   isnull(case Status when 'Partially' then 'Partially Online' else Status end,
   'OnlinePending','Online Pending'),'OfflinePending','Offline Pending') as 'Status',
  isnull(Comment,'') as 'Comment',
  isnull(OtherData,'') as 'OtherData',
  case  when Type in ('Group','NodeGroup') and RunningOnPreferredServer = 'N' then '警告'
   when Status in ('Up','Online','') then 'OK'
   when Status = 'Offline' then '警告'
   when Status like 'Partially%' then '警告'
   when Status like '%Pending%' then '警告'
   when Status in('Down','Failed') then '错误'
   else 'UnkNown'
   
  end     as 'IconFlag',
  
  isnull(TakeOfflineCmd,'N')   as 'TakeOfflineCmd',
  
  isnull(BringOnlineCmd,'N')   as 'BringOnlineCmd',
  
  isnull(MoveGroupCmd,'N')   as 'MoveGroupCmd',
  
  isnull(StopMSCSCmd,'N')   as 'StopMSCSCmd',
  
  isnull(StartMSCSCmd,'N')   as 'StartMSCSCmd',
  
  isnull(RunningOnPreferredServer,'N') as 'RunningOnPreferredServer',
  
  ControlsTheCurrentsqlServer  as 'ControlsTheCurrentsqlServer',
  
  isnull(RunningOnServer,'')   as 'RunningOnServer',
  
  case  when Type in ('PreferredServer','Node') then
  
    case  when Status in ('Up','Online') then 'Y'
      else 'N'
    end
   else 'N'
  end       as 'CanAcceptMove'
 from #w3
 order by Sequencer,name
end
else 
begin
 if @RunningOnACluster = 'N' goto Output2
 select @FailCnt = count(*)
 from #w3
 where Type = 'Node'
  and Status <> 'Up'
 Output2: 

 select  1 as 'ID',
  case @RunningOnACluster when 'Y' then 1 else 0 end as 'IsClusteredServer',
  isnull(@FailCnt,0) as 'DownServerCnt',
  isnull(@PreferredServers,0) as 'PreferredServers'
end
set nocount on
if @DeBUG = 'Y' print convert(varchar(30),109) + ': 开始清除...'
if @CreatedTemptables = 'Y'
begin
 drop table #w3
 drop table #CmdOutput
 drop table  #w4
end
if @DeBUG = 'Y' print convert(varchar(30),109) + ': ' + object_name(@@procID) + ' ended.'

end

总结

以上是内存溢出为你收集整理的实战:监控sqlserver 2008 R2群集状态全部内容,希望文章能够帮你解决实战:监控sqlserver 2008 R2群集状态所遇到的程序开发问题。

如果觉得内存溢出网站内容还不错,欢迎将内存溢出网站推荐给程序员好友。

欢迎分享,转载请注明来源:内存溢出

原文地址: http://outofmemory.cn/sjk/1179415.html

(0)
打赏 微信扫一扫 微信扫一扫 支付宝扫一扫 支付宝扫一扫
上一篇 2022-06-02
下一篇 2022-06-02

发表评论

登录后才能评论

评论列表(0条)

保存