{"id":1629,"date":"2012-10-31T22:10:25","date_gmt":"2012-11-01T00:10:25","guid":{"rendered":"http:\/\/fabriciolima.net\/blog\/?p=1629"},"modified":"2016-07-24T10:27:56","modified_gmt":"2016-07-24T13:27:56","slug":"database-mirroring-operation-mode-high-safety-with-automatic-failover","status":"publish","type":"post","link":"https:\/\/fabriciolima.net\/blog\/2012\/10\/31\/database-mirroring-operation-mode-high-safety-with-automatic-failover\/","title":{"rendered":"Database Mirroring &#8211; Operation Mode High Safety with Automatic Failover"},"content":{"rendered":"<p>Fala Pessoal,<\/p>\n<p>A ideia desse teste \u00e9 verificar o tempo que o Database Mirroring leva para fazer um failover autom\u00e1tico de um servidor para o outro utilizando esse Operation mode.<\/p>\n<p>Inst\u00e2ncias participantes dos testes:<\/p>\n<p>1 &#8211; Instancia5\u00a0\u00a0\u00a0\u00a0\u00a0\u00a0\u00a0\u00a0\u00a0\u00a0\u00a0\u00a0\u00a0 &#8211; Servidor Principal, referenciado no texto por Servidor A<br \/>\n2 &#8211; Instancia5\\INST1\u00a0\u00a0\u00a0 &#8211; Servidor Mirror, referenciado no texto por Servidor B<\/p>\n<p>Nome da database espelhada: Mirror1<\/p>\n<p>Script de cria\u00e7\u00e3o da tabela Teste:<\/p>\n<p>CREATE TABLE [dbo].[Teste](<br \/>\n[Cod] [int] IDENTITY(1,1) NOT NULL,<br \/>\n[Data] [datetime] NULL,<br \/>\n[Texto] [varchar](4000) NULL)<\/p>\n<p>Loop de insert do teste:<br \/>\nwhile 1=1<br \/>\nbegin<br \/>\nif exists (select null<br \/>\nfrom sys.databases<br \/>\nwhere name = &#8216;MIRROR1&#8217; and state_desc = &#8216;ONLINE&#8217;)<br \/>\ninsert into mirror1..Teste(texto)<br \/>\nselect @@servername<br \/>\nend<\/p>\n<p>Com um database mirroring configurado com o modo High Safety with Automatic Failover conforme pode ser visto abaixo:<\/p>\n<p style=\"text-align: center;\"><a href=\"https:\/\/www.fabriciolima.net\/blog\/wp-content\/uploads\/2012\/10\/Figura-1.png\" target=\"_blank\"><img loading=\"lazy\" decoding=\"async\" class=\"aligncenter size-full wp-image-1865\" title=\"Figura 1\" src=\"https:\/\/www.fabriciolima.net\/blog\/wp-content\/uploads\/2012\/10\/Figura-1.png\" alt=\"\" width=\"404\" height=\"292\" srcset=\"https:\/\/fabriciolima.net\/blog\/wp-content\/uploads\/2012\/10\/Figura-1.png 572w, https:\/\/fabriciolima.net\/blog\/wp-content\/uploads\/2012\/10\/Figura-1-300x218.png 300w, https:\/\/fabriciolima.net\/blog\/wp-content\/uploads\/2012\/10\/Figura-1-410x297.png 410w, https:\/\/fabriciolima.net\/blog\/wp-content\/uploads\/2012\/10\/Figura-1-100x73.png 100w, https:\/\/fabriciolima.net\/blog\/wp-content\/uploads\/2012\/10\/Figura-1-275x200.png 275w, https:\/\/fabriciolima.net\/blog\/wp-content\/uploads\/2012\/10\/Figura-1-20x15.png 20w\" sizes=\"auto, (max-width: 404px) 100vw, 404px\" \/><\/a><\/p>\n<p>Foram executadas cinco queries com loops infinitos de Inserts.<\/p>\n<p>Em seguida foi parado o servi\u00e7o do SQL Server do servidor A simulando um poss\u00edvel problema.<\/p>\n<p>Como a query do loop possui uma verifica\u00e7\u00e3o que s\u00f3 realiza o insert quando a database est\u00e1 ONLINE, esse loop tamb\u00e9m ficou sendo executado no servidor B para que assim que a database ficasse online, um insert fosse feito nessa tabela.<\/p>\n<p>Dessa forma, como a coluna Texto possui o nome do servidor onde o insert foi executado, \u00e9 poss\u00edvel medir o tempo de failover entre as duas instancias. Para isso, foi verificado quando a coluna Texto troca o nome do servidor e assim podemos saber a \u00faltima inser\u00e7\u00e3o em um ambiente e a primeira inser\u00e7\u00e3o em outro ambiente.<\/p>\n<p>Segue o resultado encontrado:<\/p>\n<p style=\"text-align: center;\"><a href=\"https:\/\/www.fabriciolima.net\/blog\/wp-content\/uploads\/2012\/10\/Figura-2.png\" target=\"_blank\"><img loading=\"lazy\" decoding=\"async\" class=\"aligncenter size-full wp-image-1866\" title=\"Figura 2\" src=\"https:\/\/www.fabriciolima.net\/blog\/wp-content\/uploads\/2012\/10\/Figura-2.png\" alt=\"\" width=\"531\" height=\"149\" srcset=\"https:\/\/fabriciolima.net\/blog\/wp-content\/uploads\/2012\/10\/Figura-2.png 619w, https:\/\/fabriciolima.net\/blog\/wp-content\/uploads\/2012\/10\/Figura-2-300x84.png 300w, https:\/\/fabriciolima.net\/blog\/wp-content\/uploads\/2012\/10\/Figura-2-410x115.png 410w, https:\/\/fabriciolima.net\/blog\/wp-content\/uploads\/2012\/10\/Figura-2-100x28.png 100w, https:\/\/fabriciolima.net\/blog\/wp-content\/uploads\/2012\/10\/Figura-2-275x77.png 275w, https:\/\/fabriciolima.net\/blog\/wp-content\/uploads\/2012\/10\/Figura-2-20x6.png 20w\" sizes=\"auto, (max-width: 531px) 100vw, 531px\" \/><\/a><\/p>\n<p>Comparando as duas colunas do tipo datetime, temos que o tempo do failover autom\u00e1tico foi de <strong>6.4 segundos<\/strong>.<\/p>\n<p>Tentando fazer esse tempo aumentar, foram executados 10 loops com inserts infinitos ao inv\u00e9s de 5.<\/p>\n<p>Segue o resultado encontrado:<\/p>\n<p style=\"text-align: center;\"><a href=\"https:\/\/www.fabriciolima.net\/blog\/wp-content\/uploads\/2012\/10\/Figura-3.png\" target=\"_blank\"><img loading=\"lazy\" decoding=\"async\" class=\"aligncenter size-full wp-image-1867\" title=\"Figura 3\" src=\"https:\/\/www.fabriciolima.net\/blog\/wp-content\/uploads\/2012\/10\/Figura-3.png\" alt=\"\" width=\"575\" height=\"167\" srcset=\"https:\/\/fabriciolima.net\/blog\/wp-content\/uploads\/2012\/10\/Figura-3.png 617w, https:\/\/fabriciolima.net\/blog\/wp-content\/uploads\/2012\/10\/Figura-3-300x87.png 300w, https:\/\/fabriciolima.net\/blog\/wp-content\/uploads\/2012\/10\/Figura-3-410x119.png 410w, https:\/\/fabriciolima.net\/blog\/wp-content\/uploads\/2012\/10\/Figura-3-100x29.png 100w, https:\/\/fabriciolima.net\/blog\/wp-content\/uploads\/2012\/10\/Figura-3-275x80.png 275w, https:\/\/fabriciolima.net\/blog\/wp-content\/uploads\/2012\/10\/Figura-3-20x6.png 20w\" sizes=\"auto, (max-width: 575px) 100vw, 575px\" \/><\/a><\/p>\n<p>Comparando as duas colunas do tipo datetime, temos que o tempo do failover autom\u00e1tico foi de <strong>2.9 segundos<\/strong>.<\/p>\n<p>Conclus\u00e3o: Acredito que a primeira execu\u00e7\u00e3o demorou mais, pois meu notebook devia estar mais sobrecarregado com outros processos. Com isso, n\u00e3o consegui aumentar o tempo de failover aumentando a carga nesse servidor.<\/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><a href=\"https:\/\/www.fabriciolima.net\/blog\/2012\/05\/31\/database-mirroring-operation-mode-high-performance-parte-3\/\" target=\"_blank\">Database Mirroring &#8211; Operation Mode High Performance &#8211; Parte 3<\/a><\/p>\n<p><a rel=\"bookmark\" href=\"https:\/\/www.fabriciolima.net\/blog\/2012\/06\/27\/database-mirroring-operation-mode-high-safety-without-failover-parte-1\/\" target=\"_blank\">Database Mirroring \u2013 Operation Mode High Safety Without Failover \u2013  Parte 1<\/a><\/p>\n<p><a rel=\"bookmark\" href=\"https:\/\/www.fabriciolima.net\/blog\/2012\/06\/29\/database-mirroring-operation-mode-high-safety-without-failover-parte-2\/\" target=\"_blank\">Database Mirroring \u2013 Operation Mode High Safety Without Failover \u2013  Parte 2<br \/>\n<\/a><\/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, A ideia desse teste \u00e9 verificar o tempo que o Database Mirroring leva para fazer um failover autom\u00e1tico de um servidor para o outro utilizando esse Operation mode. Inst\u00e2ncias participantes dos testes: 1 &#8211; Instancia5\u00a0\u00a0\u00a0\u00a0\u00a0\u00a0\u00a0\u00a0\u00a0\u00a0\u00a0\u00a0\u00a0 &#8211; Servidor Principal, referenciado no texto por Servidor A 2 &#8211; Instancia5\\INST1\u00a0\u00a0\u00a0 &#8211; Servidor Mirror, referenciado no texto [&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-1629","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\/1629","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=1629"}],"version-history":[{"count":0,"href":"https:\/\/fabriciolima.net\/blog\/wp-json\/wp\/v2\/posts\/1629\/revisions"}],"wp:attachment":[{"href":"https:\/\/fabriciolima.net\/blog\/wp-json\/wp\/v2\/media?parent=1629"}],"wp:term":[{"taxonomy":"category","embeddable":true,"href":"https:\/\/fabriciolima.net\/blog\/wp-json\/wp\/v2\/categories?post=1629"},{"taxonomy":"post_tag","embeddable":true,"href":"https:\/\/fabriciolima.net\/blog\/wp-json\/wp\/v2\/tags?post=1629"}],"curies":[{"name":"wp","href":"https:\/\/api.w.org\/{rel}","templated":true}]}}