{"id":1477,"date":"2012-05-31T14:41:10","date_gmt":"2012-05-31T16:41:10","guid":{"rendered":"http:\/\/fabriciolima.net\/blog\/?p=1477"},"modified":"2016-07-24T10:19:31","modified_gmt":"2016-07-24T13:19:31","slug":"database-mirroring-operation-mode-high-performance-parte-3","status":"publish","type":"post","link":"https:\/\/fabriciolima.net\/blog\/2012\/05\/31\/database-mirroring-operation-mode-high-performance-parte-3\/","title":{"rendered":"Database Mirroring &#8211; Operation Mode High Performance &#8211; Parte 3"},"content":{"rendered":"<p>Fala Pessoal,<\/p>\n<p>Neste post continuarei o teste do Operation Mode  High Performance. Caso ainda n\u00e3o tenham visto os posts anteriores, sugiro que  os leia antes de continuar:<\/p>\n<p><a href=\"https:\/\/www.fabriciolima.net\/blog\/2012\/05\/23\/database-mirroring-testes-operation-mode-high-performance-parte-1\/\" target=\"_blank\">Database Mirroring \u2013 Operation Mode High Performance \u2013 Parte 1<\/a><\/p>\n<p><a href=\"https:\/\/www.fabriciolima.net\/blog\/2012\/05\/28\/database-mirroring-operation-mode-high-performance-parte-2\/\" target=\"_blank\">Database Mirroring \u2013 Operation Mode High Performance \u2013 Parte 2<\/a><\/p>\n<p>Novamente, com o loop de insert rodando no servidor A (Principal), para esse teste, eu parei o servi\u00e7o do SQL Server do servidor A:<\/p>\n<p><a href=\"https:\/\/www.fabriciolima.net\/blog\/wp-content\/uploads\/2012\/03\/DBMirror1.png\"><img loading=\"lazy\" decoding=\"async\" class=\"aligncenter size-full wp-image-1478\" title=\"DBMirror1\" src=\"https:\/\/www.fabriciolima.net\/blog\/wp-content\/uploads\/2012\/03\/DBMirror1.png\" alt=\"\" width=\"729\" height=\"55\" srcset=\"https:\/\/fabriciolima.net\/blog\/wp-content\/uploads\/2012\/03\/DBMirror1.png 781w, https:\/\/fabriciolima.net\/blog\/wp-content\/uploads\/2012\/03\/DBMirror1-300x23.png 300w, https:\/\/fabriciolima.net\/blog\/wp-content\/uploads\/2012\/03\/DBMirror1-768x58.png 768w, https:\/\/fabriciolima.net\/blog\/wp-content\/uploads\/2012\/03\/DBMirror1-700x53.png 700w, https:\/\/fabriciolima.net\/blog\/wp-content\/uploads\/2012\/03\/DBMirror1-410x31.png 410w, https:\/\/fabriciolima.net\/blog\/wp-content\/uploads\/2012\/03\/DBMirror1-100x8.png 100w, https:\/\/fabriciolima.net\/blog\/wp-content\/uploads\/2012\/03\/DBMirror1-275x21.png 275w, https:\/\/fabriciolima.net\/blog\/wp-content\/uploads\/2012\/03\/DBMirror1-20x2.png 20w\" sizes=\"auto, (max-width: 729px) 100vw, 729px\" \/><\/a><\/p>\n<p>Contudo, dessa vez o pessoal da infraestrutura n\u00e3o conseguiu resolver o problema do Servidor A. Logo, eu tive que acabar com o mirror para que o Log da database do servidor B n\u00e3o ficasse crescendo sem parar.<\/p>\n<p>Para acabar com o mirror, executei o comando: alter database mirror1 set partner off<\/p>\n<p>Logo ap\u00f3s, rodando a query abaixo, \u00e9 poss\u00edvel ver que o mirror n\u00e3o existe mais:<br \/>\nSELECT db.name, mirroring_state_desc, mirroring_safety_level_desc,mirroring_witness_state_desc<br \/>\nFROM sys.database_mirroring m<br \/>\nJOIN sys.databases db ON db.database_id = m.database_id<br \/>\nwhere name = &#8216;Mirror1&#8217;<\/p>\n<p><a href=\"https:\/\/www.fabriciolima.net\/blog\/wp-content\/uploads\/2012\/03\/DBMirror2.png\"><img loading=\"lazy\" decoding=\"async\" class=\"aligncenter size-full wp-image-1479\" title=\"DBMirror2\" src=\"https:\/\/www.fabriciolima.net\/blog\/wp-content\/uploads\/2012\/03\/DBMirror2.png\" alt=\"\" width=\"506\" height=\"35\" srcset=\"https:\/\/fabriciolima.net\/blog\/wp-content\/uploads\/2012\/03\/DBMirror2.png 506w, https:\/\/fabriciolima.net\/blog\/wp-content\/uploads\/2012\/03\/DBMirror2-300x21.png 300w, https:\/\/fabriciolima.net\/blog\/wp-content\/uploads\/2012\/03\/DBMirror2-410x28.png 410w, https:\/\/fabriciolima.net\/blog\/wp-content\/uploads\/2012\/03\/DBMirror2-100x7.png 100w, https:\/\/fabriciolima.net\/blog\/wp-content\/uploads\/2012\/03\/DBMirror2-275x19.png 275w, https:\/\/fabriciolima.net\/blog\/wp-content\/uploads\/2012\/03\/DBMirror2-20x1.png 20w\" sizes=\"auto, (max-width: 506px) 100vw, 506px\" \/><\/a><\/p>\n<p>Mesmo com o mirror n\u00e3o existindo mais, a base do servidor B continua com o status restoring:<\/p>\n<p><a href=\"https:\/\/www.fabriciolima.net\/blog\/wp-content\/uploads\/2012\/03\/DBMirror3.png\"><img loading=\"lazy\" decoding=\"async\" class=\"aligncenter size-full wp-image-1480\" title=\"DBMirror3\" src=\"https:\/\/www.fabriciolima.net\/blog\/wp-content\/uploads\/2012\/03\/DBMirror3.png\" alt=\"\" width=\"217\" height=\"83\" srcset=\"https:\/\/fabriciolima.net\/blog\/wp-content\/uploads\/2012\/03\/DBMirror3.png 217w, https:\/\/fabriciolima.net\/blog\/wp-content\/uploads\/2012\/03\/DBMirror3-100x38.png 100w, https:\/\/fabriciolima.net\/blog\/wp-content\/uploads\/2012\/03\/DBMirror3-20x8.png 20w\" sizes=\"auto, (max-width: 217px) 100vw, 217px\" \/><\/a><\/p>\n<p>Para deix\u00e1-la online, deve-se rodar o comando: restore database mirror1 with recovery<\/p>\n<p>Entretanto, ao execut\u00e1-lo, recebi o seguinte erro:<\/p>\n<p>Msg 5094, Level 16, State 2, Line 1<br \/>\nThe operation cannot be performed on a database with database snapshots or active DBCC replicas.<br \/>\nMsg 3013, Level 16, State 1, Line 1<br \/>\nRESTORE DATABASE is terminating abnormally.<\/p>\n<p>Isso aconteceu porque eu tinha um snapshot na database do servidor B que era o mirror.<\/p>\n<p>Esse snapshot deve ser exclu\u00eddo com o comando abaixo:<br \/>\ndrop database mirror1_snapshot<\/p>\n<p>Onde Mirror1_Snapshot \u00e9 o nome da database snapshot que eu criei. Posteriormente farei um post sobre database snapshot no database mirroring.<\/p>\n<p>Executando o comando \u201c<em>restore database mirror1 with recovery<\/em>\u201d novamente, a database ficou online.<\/p>\n<p>Algum tempo depois a galera da Infraestrutura abriu um chamado no fornecedor de Hardware e conseguiram voltar o servidor A. Ao fazer isso, a database desse servidor tamb\u00e9m ficou online automaticamente. Isso pode gerar um problema grave, pois imagina se existirem muitas aplica\u00e7\u00f5es e servi\u00e7os apontando para o servidor A. Quando o servidor A morre e o servidor B passa a receber as aplica\u00e7\u00f5es e servi\u00e7os, ele se torna o servidor com dados mais atualizados. Agora, imagina que voc\u00ea esqueceu de redirecionar alguma aplica\u00e7\u00e3o ou servi\u00e7o do servidor A para o B, quando o servidor A fica dispon\u00edvel, suas aplica\u00e7\u00f5es e servi\u00e7os podem ficar manipulando dados no servidor A e B. Isso vai gerar um GRANDE problema dependendo do tamanho do seu ambiente. Ent\u00e3o, deve-se ter um cuidado especial com essa situa\u00e7\u00e3o e mapear TODAS as aplica\u00e7\u00f5es e servi\u00e7os que utilizam uma database presente em um Database Mirroring.<\/p>\n<p>Uma solu\u00e7\u00e3o para isso seria um redirecionamento de DNS. As aplica\u00e7\u00f5es utilizariam um ALIAS chamado DBProducao e esse ALIAS apontaria para um servidor f\u00edsico chamado ServerA com IP 192.0.0.1. Caso aconte\u00e7a algum problema com esse servidor, o database mirror far\u00e1 um failover para o serverB com IP 192.0.0.2. Assim, basta voc\u00ea realizar o redirecionamento de DNS do Alias DBProducao para que ele responda pelo IP 192.0.0.2. Com isso, n\u00e3o existe o risco de nenhuma aplica\u00e7\u00e3o ou servi\u00e7o gravar dados em um local indevido.<\/p>\n<p>Continuando o teste, agora vamos verificar como ficou a sincroniza\u00e7\u00e3o dos dados entre os dois servidores com a volta do servidor A.<\/p>\n<p>O servidor B (ambiente5\\inst1) que era o mirror, possui dados at\u00e9 o Cod e data abaixo:<br \/>\nCod: 32610\u00a0\u00a0\u00a0\u00a0\u00a0\u00a0\u00a0 Data: 2012-01-05 15:25:12.710<\/p>\n<p>Ap\u00f3s o servidor A (que era o Principal) ficar online, executei a query abaixo para selecionar os dados que existiam no servidor A, mas ainda n\u00e3o haviam sido espelhados para o servidor B:<\/p>\n<p>select * from mirror1..Teste where cod &gt;= 32610 order by data desc<\/p>\n<p>Comparando o resultado cheguei \u00e0 conclus\u00e3o:<\/p>\n<p>Perdi dados de 2012-01-05 15:<strong>25:12<\/strong>.710 at\u00e9 2012-01-05 15:<strong>25:22<\/strong>.747, ou seja, 10 segundos.<\/p>\n<p>Isso porque meu ambiente estava fazendo apenas um insert em uma tabela. Agora imagina em um ambiente grande onde a quantidade de dados atualizados \u00e9 alta. A perda de dados seria consider\u00e1vel. Contudo, ela ainda pode ser menor do que se voc\u00ea tivesse apenas uma rotina de backup e perdesse os arquivos de log de alguma database. Nesse caso, voc\u00ea n\u00e3o conseguiria salvar o Tail Log e s\u00f3 teria os backups do log j\u00e1 realizados. Como esse job deve rodar a cada 5 minutos, por exemplo, a perda de dados pode ser muito maior do que em um mirror com High Performance.<\/p>\n<p>Artigos relacionados:<\/p>\n<p><a href=\"https:\/\/www.fabriciolima.net\/blog\/2012\/05\/15\/serie-de-posts-sobre-database-mirroring\/\" target=\"_blank\">S\u00e9rie de Posts sobre Database Mirroring<\/a><\/p>\n<p><a href=\"https:\/\/www.fabriciolima.net\/blog\/2012\/05\/15\/database-mirroring-como-alterar-o-operation-mode\/\" target=\"_blank\">Database Mirroring \u2013 Como alterar o Operation Mode<\/a><\/p>\n<p><a href=\"https:\/\/www.fabriciolima.net\/blog\/2012\/05\/23\/database-mirroring-testes-operation-mode-high-performance-parte-1\/\" target=\"_blank\">Database Mirroring \u2013 Operation Mode High Performance \u2013 Parte 1<\/a><\/p>\n<p><a href=\"https:\/\/www.fabriciolima.net\/blog\/2012\/05\/28\/database-mirroring-operation-mode-high-performance-parte-2\/\" target=\"_blank\">Database Mirroring \u2013 Operation Mode High Performance \u2013 Parte 2<\/a><\/p>\n<p>At\u00e9 o pr\u00f3ximo post.<\/p>\n<p><b>Gostou desse Post?<\/b><\/p>\n<p>Cadastre seu e-mail para receber novos Posts e curta minha <a href=\"https:\/\/www.facebook.com\/FabricioLimaSolucoesemBancodeDados\/\" target=\"_blank\">P\u00e1gina no Facebook<\/a> para receber Dicas de Leituras e Eventos sobre SQL Server.<\/p>\n<p>Abra\u00e7os,<\/p>\n<p>Fabr\u00edcio Lima<\/p>\n<p>MCITP \u2013 Database Administrator<\/p>\n<p>Consultor e Instrutor SQL Server<\/p>\n<p>Trabalha com SQL Server desde 2006<\/p>\n","protected":false},"excerpt":{"rendered":"<p>Fala Pessoal, Neste post continuarei o teste do Operation Mode High Performance. Caso ainda n\u00e3o tenham visto os posts anteriores, sugiro que os leia antes de continuar: Database Mirroring \u2013 Operation Mode High Performance \u2013 Parte 1 Database Mirroring \u2013 Operation Mode High Performance \u2013 Parte 2 Novamente, com o loop de insert rodando no [&hellip;]<\/p>\n","protected":false},"author":1,"featured_media":0,"comment_status":"open","ping_status":"open","sticky":false,"template":"","format":"standard","meta":{"_exactmetrics_skip_tracking":false,"_exactmetrics_sitenote_active":false,"_exactmetrics_sitenote_note":"","_exactmetrics_sitenote_category":0,"footnotes":""},"categories":[3,280],"tags":[604,606,391,23,607,372,613,611,612,610,608,616,49,33,50,34,605,609,614,615],"class_list":["post-1477","post","type-post","status-publish","format-standard","hentry","category-administracao-de-bd","category-virtual-pass-br","tag-alta-disponibilidade","tag-database-mirror","tag-database-mirroring","tag-dba","tag-espelhamento-de-banco-de-dados","tag-high-availability","tag-high-performance","tag-high-safety-with-automatic-failover","tag-high-safety-without-automatic-failover","tag-operation-mode","tag-perda-de-dados","tag-safety","tag-sql","tag-sql-server","tag-sql-server-2005","tag-sql-server-2008","tag-sql-server-mirror","tag-sql-server-online","tag-sys-database_mirroring","tag-witness"],"post_mailing_queue_ids":[],"_links":{"self":[{"href":"https:\/\/fabriciolima.net\/blog\/wp-json\/wp\/v2\/posts\/1477","targetHints":{"allow":["GET"]}}],"collection":[{"href":"https:\/\/fabriciolima.net\/blog\/wp-json\/wp\/v2\/posts"}],"about":[{"href":"https:\/\/fabriciolima.net\/blog\/wp-json\/wp\/v2\/types\/post"}],"author":[{"embeddable":true,"href":"https:\/\/fabriciolima.net\/blog\/wp-json\/wp\/v2\/users\/1"}],"replies":[{"embeddable":true,"href":"https:\/\/fabriciolima.net\/blog\/wp-json\/wp\/v2\/comments?post=1477"}],"version-history":[{"count":0,"href":"https:\/\/fabriciolima.net\/blog\/wp-json\/wp\/v2\/posts\/1477\/revisions"}],"wp:attachment":[{"href":"https:\/\/fabriciolima.net\/blog\/wp-json\/wp\/v2\/media?parent=1477"}],"wp:term":[{"taxonomy":"category","embeddable":true,"href":"https:\/\/fabriciolima.net\/blog\/wp-json\/wp\/v2\/categories?post=1477"},{"taxonomy":"post_tag","embeddable":true,"href":"https:\/\/fabriciolima.net\/blog\/wp-json\/wp\/v2\/tags?post=1477"}],"curies":[{"name":"wp","href":"https:\/\/api.w.org\/{rel}","templated":true}]}}