A apresentação está carregando. Por favor, espere

A apresentação está carregando. Por favor, espere

Recursos de Gerenciamento de SQL Server Wandenkolk T. Neto Consultor MCS Microsoft Brasil

Apresentações semelhantes


Apresentação em tema: "Recursos de Gerenciamento de SQL Server Wandenkolk T. Neto Consultor MCS Microsoft Brasil"— Transcrição da apresentação:

1 Recursos de Gerenciamento de SQL Server Wandenkolk T. Neto Consultor MCS Microsoft Brasil wandent@microsoft.com

2 Objetivos Como tornar a sua vida mais fácil com relação ao gerenciamento de SQL Server 2008 R2 e Denali para situações de alto volume e otimizações Quais os próximos passos... O que mais há lá fora de interessante para novos projetos com SQL Server

3 SQL 2008 R2 Multi Core Suporte melhorado Unicode Compression Data Tier Applications Virtualização Data Center Edition … Denali Management Studio Debugger Distributed Replay Contained Databases …

4 Multi Core Suporte (2008 R2) Suporte a até 256 processadores lógicos rodando em Windows 2008 R2 Suporte a até 15K Partições, também suportado em SQL Server 2008 SP2 exec sp_db_increased_partitions' ','ON' Como tirar proveito ? Paralelismo intra-query (famoso MAXDOP hint) Espalhando o backup em multiplos discos, cria-se multiplas threads Distribuição de arquivos do banco, tempdb etc em multiplos discos

5 Unicode Compression Entenda data compression primeiro SPARSE columns : A idéia é comprimir dados nulos, para cada nulo, gasta-se um espaço para dizer ao sql server que aquela posição é nula ROW Compression PAGE Compression – Método mais eficiente, comprime o dado no nível de página Unicode Compression – SCSU (Standard compression scheme for Unicode) Ativada compressão especifica para unicode em ROW ou Page Compression (preferencialmente PAGE compression) Avalie o beneficio da compressão com sp_estimate_data_compression_savings Não aplicável a nvarchar(max) Na prática a mudança ocorre sob o capô, o sql server define automaticamente o algorítmo apropriado para a compressão

6 Demo Compressão

7 Pacote de instalação Schema Logins Outros Elementos Mapa da Mina Extraír o Data Tier Application, criando um DACPAC em desenvolvimento/homologação De posse do DACPAC, pode se importá-lo em produção bem como compará-lo com o schema de um outro database ja operando DACPAC contém apenas schema e a criação de demais objetos. Não contem dados. Ferramentas para o gerenciamento de Dacpacs (importaçao exportacao com inclusão de dados) DACImportExportClient

8 Deploy Upgrade Import Build Extract Export DACPAC DAC database model DAC database model

9

10

11

12

13

14

15 Baseado em WPF Suporte a multiplos monitores Mais atalhos de teclado Debugger Melhorado Watch / Quick Watch Data Tip Permite debug de SQL 2005 SP2 ou superior

16

17

18

19 Instalar o Controller e Client para Distributed Replay em conjunto com o client tools do SQL Server (pré-requisito) 2.Capturar o Workload como se fosse executar o replay via profiler 3.Pré-processar o arquivo dreplay preprocess -m SERVER1 -i c:\replay\replay.trc -d C:\replay\work\ -m – controller -I – arquivo de input a ser consumido -d – diretório onde o dispatch será gerado

20 Executar o Replay Dreplay replay -m SERVER1.denali.lab -d C:\Replay\Work\ -s SERVER3\SQLC -w SERVER1.denali.lab - m – servidor controller -d – working folder com o dispatch file -s – servidor target -w – servidores client * ferramentas localizadas em c:\Program Files(x86)\Microsoft SQL Server\110\Tools\Binn

21 Problema: Mover bancos de dados entre servers, espcecialmente em cenários com alto número de bancos de dados, e alta criticidade para aplicações; Impactos Mover databases entre servers é trabalhoso Depende do dba acertar detalhes de segurança – logins com users Precisa-se mapear todas as dependencias que o database possui para funcionar E sempre durante qualquer movimentação uma depencia não mapeada aparece Contained Databases Feature do Denali que permite que um db seja até certo ponto indepentente do server onde está localizado. Ainda implementado parcialmente ou seja, a feature atual endereça aspectos fundamentais, mas não todos

22

23 Application Model Todos os objetos que estão no âmbito da aplicação: Database system catalog views (sys.objects... ) Data Types T-SQL Criação de Objetos Direitos / Permissões SETs Funções built-in Stored procedures de usuário DBCC

24 Server Catalog Views (sys.databases) Compatilbility views (sysobjects, sysdatabases....) Alguns CREATE/ DROP/ ALTER FILESTREAM até porque acessa recursos externos, no caso o share com o blob Change Data Capture Server trace procedures Linked Server Full Text Search

25 Tabelas locais dentro de um partially contained são permitidas Objetos dentro de um modelo partially contained podem ser mapeados com sys.dm_db_uncontained_entities Tabelas temporárias não podem usar constraints nomeadas Tabelas temporárias não podem usar User Defined Types, User Defined Functions ou XML Schema Collection

26

27

28 Segurança em Contained databases Db_owners ou db_security admin tem automaticamente permissão de logar na instancia uma vez que o db tenha containment partial; Acesso a outros banco é permitido pelo usuário guest. Sem guest sem acesso Contained users tem senhas atribuidas a eles; AUTO_CLOSE sempre desligado; Master não pode ser contained Funciona com compatibility levels inferiores (90 – sql 2005 / 100 - 2008) Um banco em partial pode ser enviado de volta para none - Desde que caracteristicas especificas de contained databases sejam removidas (users com password por exemplo)

29 Problema: Para cenários de alto volume OLTP campos identity apresentam restrições de performance Cache limitado a 25 valores identity, mais complexo de fazer reseed Sequences Gerador de Números padrão ANSI Mais rápido que o identity, possui cache melhorado e configurável Uso como identity, mas possui a propriedade NEXT_VALUE é o que retorna o valor seguinte do sequence Na criação de tabelas o sequence é introduzido como uma default constraint

30 Sequences Suporta recycle automatico –não recomendado para chaves primárias Valores podem ficar em cache, resulta em melhora no desempenho, porém quanto maior o valor do cache, a perda de válores na sequencia é maior para cada restart da instancia MINVALUE MAXVALUE

31 CREATE SEQUENCE seq1 AS TINYINT | SMALLINT | INT | BIGINT START WITH 0 INCREMENT BY 1 MAXVALUE 2000000 CACHE 1000; Select NEXT_VALUE for dbo.seq1 CREATE TABLE Teste (cod int not null primary key DEFAULT NEXT VALUE for dbo.Seq1, …. );

32 CREATE SEQUENCE dbo.IdSeq AS int Start WITH 1000 increment by 1; GO Insert into employees(employeeID, name) values (NEXT VALUE FOR dbo.IdSeq, ‘teste’); SELECT * FROM sys.sequences WHERE name = ‘idseq' ; NEXT VALUE, Nao permitido em top, Where e order by entre outros lugares Nao permitido em subqueries

33 Novos server roles Permissoes aplicadas a: Endpoints Logins Servers Availability Groups ( Servidor virtual do Always on) Server Roles USE [master] GO CREATE SERVER ROLE [test_role] GO use [master] GO GRANT ALTER ANY DATABASE TO [test_role] WITH GRANT OPTION GO use [master] GO GRANT ADMINISTER BULK OPERATIONS TO [test_role] GO

34 Download de patches antes da instalação! Suporte a cluster georgráfico com multiplas subredes Suporte a mountpoints montados em discos locais em cluster Always On Mirror com suporte a virtual servers, como um cluster Redundancia de Data Center com logshipping integrado ao Always On

35 Microsoft SQL Server website http://www.microsoft.com/SQL SQL Server Customer Advisory Team http://www.sqlcat.com Documentação do SQL Server Denali no MSDN http://msdn.microsoft.com/en- us/library/bb418432(v=SQL.10).aspx


Carregar ppt "Recursos de Gerenciamento de SQL Server Wandenkolk T. Neto Consultor MCS Microsoft Brasil"

Apresentações semelhantes


Anúncios Google