Partilhar via


Replication Merge Agent

O Replication Merge Agent é um executável que aplica o instantâneo inicial contido nas tabelas do banco de dados aos Assinantes. Ele também mescla as alterações incrementais de dados que ocorreram no Publicador depois que o instantâneo inicial foi criado e reconcilia conflitos de acordo com as regras que você configura ou usando um resolvedor personalizado que você cria.

ObservaçãoObservação

Os parâmetros podem ser especificados em qualquer ordem. Quando não são especificados parâmetros opcionais, são usados valores de configurações de registro predefinidos no computador local.

Sintaxe

replmerg [-?] 
-Publisher server_name[\instance_name]
-PublisherDB publisher_database
-Publication publication
-Subscriber server_name[\instance_name]
-SubscriberDB subscriber_database
[-AltSnapshotFolder alt_snapshot_folder_path]
[-Continuous]
[-DefinitionFile def_path_and_file_name]
[-DestThreads number_of_destination_threads]
[-Distributor server_name[\instance_name]]
[-DistributorLogin distributor_login]
[-DistributorPassword distributor_password]
[-DistributorSecurityMode [0|1]]
[-DownloadGenerationsPerBatch download_generations_per_batch]
[-DownloadReadChangesPerBatch download_read_changes_per_batch]
[-DownloadWriteChangesPerBatch download_write_changes_per_batch]
[-DynamicSnapshotLocation dynamic_snapshot_location]
[-EncryptionLevel [0|1|2]]
[-ExchangeType [1|2|3]]
[-FastRowCount [0|1]]
[-FileTransferType [0|1]]
[-ForceConvergenceLevel [0|1|2 (Publisher|Subscriber|Both)]]
[-FtpAddress ftp_address]
[-FtpPassword ftp_password]
[-FtpPort ftp_port]
[-FtpUserNameftp_user_name]
[-HistoryVerboseLevel [0|1|2|3]]
[-Hostname host_name]
[-InteractiveResolution [0|1]]
[-InternetLogin internet_login]
[-InternetPassword internet_password]
[-InternetProxyLogin internet_proxy_login]
[–InternetProxyPassword internet_proxy_password]
[-InternetProxyServer internet_proxy_server]
[-InternetSecurityMode [0|1]]
[-InternetTimeout internet_timeout]
[-InternetURL internet_url]
[-KeepAliveMessageInterval keep_alive_message_interval_seconds]
[-LoginTimeOut login_time_out_seconds]
[-MakeGenerationInterval make_generation_interval_seconds]
[-MaxBcpThreads number_of_threads]
[-MaxDownloadChanges number_of_download_changes]
[-MaxUploadChanges number_of_upload_changes]
[-MetadataRetentionCleanup [0|1]]
[-Output]
[-OutputVerboseLevel [0|1|2]]
[-ParallelUploadDownload [0|1]]
[-PacketSize packet_size]
[-PollingInterval polling_interval] 
[-ProfileName profile_name]
[-PublisherFailoverPartner server_name[\instance_name] ]
[-PublisherLogin publisher_login]
[-PublisherPassword publisher_password]
[-PublisherSecurityMode [0|1]]
[-QueryTimeOut query_time_out_seconds]
[-SrcThreads number_of_source_threads]
[-StartQueueTimeout start_queue_timeout_seconds]
[-SubscriberConflictClean [0|1]]
[-SubscriberDatabasePath subscriber_path]
[-SubscriberDBAddOption [0|1|2|3]]
[-SubscriberLogin subscriber_login]
[-SubscriberPassword subscriber_password 
[-SubscriberSecurityMode [0|1]]
[-SubscriberType [0|1|2|3|4|5|6|7|8|9]]
[-SubscriptionType [0|1|2]]
[-SyncToAlternate [0|1]
[-UploadGenerationsPerBatch upload_generations_per_batch]
[-UploadReadChangesPerBatch upload_read_changes_per_batch]
[-UploadWriteChangesPerBatch upload_write_changes_per_batch]
[-UseInprocLoader]
[-Validate [0|1|2|3]]
[-ValidateInterval validate_interval]

Argumentos

  • -?
    Imprime todos os parâmetros disponíveis.

  • -Publisherserver_name[**\instance_name]
    É o nome do Publicador. Especifica server_name para a instância padrão do Microsoft SQL Server naquele servidor. Especifica server_name
    \**instance_name para uma instância nomeada do SQL Server naquele servidor.

  • -PublisherDBpublisher_database
    É o nome do banco de dados Publicador.

  • -Publicationpublication
    É o nome da publicação. Esse parâmetro só é válido se a publicação estiver definida para ter sempre um instantâneo disponível para assinaturas novas ou reiniciadas.

  • -Subscriberserver_name[**\instance_name]
    É o nome do Assinante. Especifica server_name para a instância padrão do SQL Server naquele servidor. Especifica server_name
    \**instance_name para uma instância nomeada do SQL Server naquele servidor.

  • -SubscriberDBsubscriber_database
    É o nome do banco de dados do Assinante.

  • -AltSnapshotFolderalt_snapshot_folder_path
    É o caminho para a pasta que contém o instantâneo inicial para uma assinatura.

  • -Continuous
    Especifica se o agente tenta sondar transações replicadas continuamente. Se especificado, o agente sondará as transações replicadas da origem em intervalos de sondagem, mesmo que não haja transações pendentes.

  • -DestThreadsnumber_of_destination_threads
    Especifica o número de threads de destino que o Merge Agent usa para aplicar alterações ao destino. O destino é o Publicador durante o carregamento e o Assinante durante o download. O padrão é 4.

  • -DefinitionFiledef_path_and_file_name
    É o caminho do arquivo de definição do agente. Um arquivo de definição de agente contém argumentos de prompt de comando para o agente. O conteúdo do arquivo é analisado como um arquivo executável. Use aspas duplas (") para especificar valores de argumentos que contêm caracteres arbitrários.

  • -Distributorserver_name[**\instance_name]
    É o nome do Distribuidor. Especifica server_name para a instância padrão do SQL Server naquele servidor. Especifica server_name
    \**instance_name para uma instância nomeada do SQL Server naquele servidor. Para distribuição (push) do Distribuidor, o nome assumirá o padrão do nome da instância do SQL Server no computador local.

  • -DistributorLogindistributor_login
    É o nome de logon do Distribuidor.

  • -DistributorPassworddistributor_password
    É a senha do Distribuidor.

  • -DistributorSecurityMode [ 0| 1]
    Especifica o modo de segurança do Distribuidor. Um valor de 0 indica Modo (padrão) de Autenticação do SQL Server e um valor de 1 indica Modo de Autenticação do Windows.

  • -DownloadGenerationsPerBatchdownload_generations_per_batch
    É o número de gerações a ser processado em um único lote durante o download de alterações do Publicador para o Assinante. Uma geração está definida como um grupo lógico de alterações por artigo. O padrão para um vínculo de comunicação confiável é 100. O padrão para um vínculo de comunicação não confiável é 10.

  • -DownloadReadChangesPerBatchdownload_read_changes_per_batch
    É o número de alterações a ser lido em um único lote durante o download de alterações do Publicador para o Assinante. O padrão é 100.

  • -DownloadWriteChangesPerBatchdownload_write_changes_per_batch
    É o número de alterações a ser aplicado em um único lote durante o download de alterações do Publicador para o Assinante. O padrão é 100.

  • -DynamicSnapshotLocationdynamic_snapshot_location
    É o local dos arquivos de instantâneo de dados filtrados quando a publicação usa filtros de linha com parâmetros.

  • -EncryptionLevel [ 0 | 1 | 2 ]
    É o nível da criptografia SSL (Secure Sockets Layer) usada pelo Merge Agent ao fazer conexões.

    Valor EncryptionLevel

    Descrição

    0

    Especifica que o SSL não é usado.

    1

    Especifica que o SSL é usado, mas o agente não verifica se o certificado de servidor SSL é assinado por um emissor confiável.

    2

    Especifica que o SSL é usado e que o certificado é verificado.

    Para obter mais informações, consulte Visão geral de segurança (Replicação).

  • -ExchangeType [ 1| 2| 3]
    Especifica o tipo de troca de dados durante a sincronização, que pode ser um dos seguintes:

    Valor ExchangeType

    Descrição

    1

    O agente deve carregar alterações de dados do Assinante para o Publicador.

    2

    O agente deve baixar alterações de dados do Publicador para o Assinante.

    3 (padrão)

    A agente deve primeiro carregar alterações de dados do Assinante ao Publicador e em seguida baixar alterações de dados do Publicador para o Assinante. Você deve usar essa opção com sincronização da Web.

    Artigos somente download permitem controlar o comportamento da sincronização de artigos individuais em uma publicação e podem beneficiar o desempenho. Para obter mais informações, consulte Otimizando o desempenho de replicação de mesclagem com artigos de somente download.

  • -FastRowCount [0|1]
    Especifica que tipo de método de cálculo de número de linhas deve ser usado para validação de número de linhas. Um valor de 1 (padrão) indica o método rápido. Um valor de 0 indica o método de número de linhas completo.

  • -FileTransferType [0|1]
    Especifica o tipo de transferência de arquivo. Um valor 0 indica UNC (convenção de nomenclatura universal) e um valor 1 indica FTP (File Transfer Protocol).

  • -ForceConvergenceLevel [0|1|2 ( Publisher| Subscriber| Both)]
    Especifica o nível de convergência que o Merge Agent deve usar e pode ser um dos seguintes:

    Valor ForceConvergenceLevel

    Descrição

    0 (padrão)

    Padrão. Executa uma mesclagem padrão sem convergência adicional.

    1

    Impõe convergência para todas as gerações.

    2

    Impõe convergência para todas as gerações e linhagens corruptas corretas. Ao especificar esse valor, especifique onde as linhagens devem ser corrigidas: no Publicador, no Assinante ou em ambos.

  • -FtpAddressftp_address
    É o endereço de rede do serviço FTP para o Distribuidor. Quando não especificado, Distributor é usado.

  • -FtpPasswordftp_password
    É a senha de usuário usada para se conectar ao serviço FTP.

  • -FtpPortftp_port
    É o número da porta do serviço FTP para o Distribuidor. Quando não especificado, o número da porta padrão para serviço de FTP (21) é usado.

  • -FtpUserNameftp_user_name
    É o nome de usuário usado para se conectar ao serviço FTP. Quando não especificado, anônimo é usado.

  • -HistoryVerboseLevel [1|2|3]
    Especifica a quantidade de histórico registrada durante uma operação de mesclagem. Você pode minimizar o efeito de registro de histórico no desempenho selecionando 1.

    Valor HistoryVerboseLevel

    Descrição

    0

    Registre a mensagem de status de agente final, detalhes finais da sessão e qualquer erro.

    1

    Registre detalhes incrementais da sessão em cada status da sessão, incluindo porcentagem concluída, além da mensagem de status final do agente, detalhes finais da sessão e qualquer erro.

    2

    Padrão. Registre detalhes incrementais da sessão em cada status da sessão e detalhes da sessão no nível do artigo, incluindo porcentagem concluída, além da mensagem de status final do agente, detalhes finais da sessão e qualquer erro. Mensagens de status de agente também são registradas.

    3

    O mesmo que - HistoryVerboseLevel = 2, exceto que mais mensagens de progresso de agente são registradas.

  • -Hostnamehost_name
    É o nome de rede do computador local. O padrão é o nome do computador local .

  • -InteractiveResolution [0|1]
    Especifica se resolução de conflito interativa é usada quando um conflito ocorre durante a sincronização. O padrão é 0, indicando que resolução de conflito interativa não é usada.

  • -InternetLogininternet_login
    Especifica o nome de logon usado ao conectar a um SQL Server Replication Listener ISAPI DLL que requer autenticação.

  • -InternetPasswordinternet_password
    Especifica a senha usada ao conectar a um SQL Server Replication Listener ISAPI DLL que requer autenticação.

  • -InternetProxyLogin internet_proxy_login
    Especifica o nome de logon usado ao conectar a um servidor proxy, definido em internet_proxy_server, que requer autenticação.

  • –InternetProxyPassword internet_proxy_password
    Especifica a senha usado ao conectar a um servidor proxy, definido em internet_proxy_server, que requer autenticação.

  • -InternetProxyServer internet_proxy_server
    Especifica o servidor proxy a ser usado ao acessar o recurso HTTP especificado em internet_url.

  • -InternetSecurityMode [0|1]
    Especifica o modo de segurança IIS usado ao conectar ao servidor Web durante sincronização da Web. Um valor de 0 indica Autenticação Básica e um valor de 1 indica Autenticação Integrada do Windows (padrão).

  • -InternetTimeoutinternet_timeout
    É o número de segundos antes que uma conexão para o SQL Server Replication Listener ISAPI DLL expire.

  • -InternetURLinternet_url
    Especifica o URL usado para se conectar ao SQL Server Replication Listener ISAPI DLL. Essa propriedade deve ser especificada.

  • -KeepAliveMessageIntervalkeep_alive_message_interval_seconds
    É o número de segundos antes que o thread de histórico verifique se alguma das conexões existentes está esperando por uma resposta do servidor. Esse valor pode ser diminuído para evitar que o agente de verificação marque o Merge Agent como suspeito ao executar um lote de execução longa. O padrão é 300 segundos.

  • -LoginTimeOutlogin_time_out_seconds
    É o número de segundos antes que o logon expire. O padrão é 15 segundos.

  • -MakeGenerationIntervalmake_generation_interval_seconds
    É o número de segundos a aguardar entre a criação de gerações ou lotes de alterações, para baixar ao cliente. O padrão é 1 segundo.

    Makegeneration é o processo que prepara as alterações do Publicador para download para os assinantes e pode ser um gargalo de desempenho durante os downloads. Se o processo makegeneration já foi executado no intervalo especificado por -MakeGenerationInterval, esse processo será ignorado para a sessão de sincronização atual. Isso poderá beneficiar a simultaneidade de sincronização e poderá ser especialmente útil se os Assinantes não esperarem baixar alterações.

  • -MaxBcpThreadsnumber_of_threads
    Especifica o número de operações de cópia em massa que podem ser executadas em paralelo. O número máximo de threads e conexões ODBC que existe simultaneamente no menor dos MaxBcpThreads ou o número de solicitações de cópia em massa que aparece na tabela do sistema sysmergeschemachange no banco de dados de publicação. MaxBcpThreads deve ter um valor maior que 0 e não tem um limite superior embutido em código. O padrão é 1.

  • -MaxDownloadChangesnumber_of_download_changes
    Especifica o número máximo de linhas alteradas que deveria ser baixado do Publicador para o Assinante. O número de linhas baixado deve ser maior do que o máximo especificado porque as gerações concluídas são processadas e os threads de destino paralelos podem executar, cada um processando no mínimo 100 alterações na primeira passagem. Por padrão, todas as alterações que estão prontas serem baixadas são enviadas.

  • -MaxUploadChangesnumber_of_upload_changes
    Especifica o número máximo de linhas alteradas que deve ser carregado do Assinante para o Publicador. O número de linhas carregado deve ser maior do que o máximo especificado porque as gerações concluídas são processadas e os threads de destino paralelos podem executar, cada um processando no mínimo 100 alterações na primeira passagem. Por padrão, todas as alterações que estão prontas serem carregadas são enviadas.

  • -MetadataRetentionCleanup [0|1]
    Especifica se os metadados são removidos de MSmerge_genhistory, MSmerge_contents, MSmerge_tombstone, MSmerge_past_partition_mappings e MSmerge_current_partition_mappings com base no período de retenção da publicação. O padrão é 1, indicando que deve ocorrer limpeza total. Um valor de 0 indica que não deve ocorrer limpeza total automaticamente. Para obter mais informações sobre limpeza de metadados, consulte Como a replicação de mesclagem funciona.

  • -Outputoutput_path_and_file_name
    É o caminho do arquivo de saída do agente. Se o nome de arquivo não for fornecido, a saída será enviada ao console. Se o nome do arquivo especificado existir, a saída será anexada ao arquivo.

  • -OutputVerboseLevel [0|1|2]
    Especifica se a saída deve ser detalhada. Se o nível detalhado for 0, só mensagens de erro serão impressas. Se o nível detalhado for 1, todas as mensagens de relatório de progresso serão impressas. Se o nível detalhado for 2 (padrão), todas as mensagens de erro e de relatório de progresso serão impressas, o que é útil na depuração.

  • -ParallelUploadDownload [0|1]
    Especifica se o Merge Agent deve processar em paralelo as alterações carregadas para o Publicador e as baixadas no Assinante, que são úteis em ambientes de grandes volumes com alta largura de banda de rede. Se ParallelUploadDownload for 1, o processamento paralelo será habilitado.

  • -PacketSize
    É o tamanho do pacote, em bytes. O padrão é 4096 (bytes).

  • -PollingIntervalpolling_interval
    É a frequência, em segundos, de consulta no Publicador ou no Assinante por alterações de dados. O padrão é 60 segundos.

  • -ProfileNameprofile_name
    Especifica um perfil de agente a ser usado para parâmetros de agente. Se ProfileName for NULL, o perfil de agente será desabilitado. Se ProfileName não for especificado, o perfil padrão de tipo de agente será usado. Para obter informações, consulte Perfis do Replication Agent.

  • -PublisherFailoverPartnerserver_name[**\**instance_name]
    Especifica a instância de parceiro de failover do SQL Server que participa de uma sessão de espelhamento de banco de dados com o banco de dados de publicação. Para obter mais informações, consulte Replicação e espelhamento do banco de dados.

  • -PublisherLoginpublisher_login
    É o nome de logon do Publicador. Se PublisherSecurityMode for 0 (para Autenticação do SQL Server), esse parâmetro deve ser especificado.

  • -PublisherPasswordpublisher_password
    É a senha do Publicador. Se PublisherSecurityMode for 0 (para Autenticação do SQL Server), esse parâmetro deve ser especificado.

  • -PublisherSecurityMode [0|1]
    Especifica o modo de segurança do Publicador. Um valor de 0 indica Autenticação do SQL Server (padrão), e um valor de 1 indica Modo de Autenticação do Windows.

  • -QueryTimeOutquery_time_out_seconds
    É o número de segundos antes que a consulta expire. O padrão é 300 segundos. O Merge Agent também usa o valor de QueryTimeout para determinar o tempo de espera para a geração de um instantâneo particionado, quando seu valor é maior do que 1800.

  • -SrcThreadsnumber_of_source_threads
    Especifica o número de threads de origem que o Merge Agent usa para enumerar alterações da origem. A origem é o Publicador durante o carregamento e o Assinante durante o download. O padrão é 3.

  • -StartQueueTimeoutstart_queue_timeout_seconds
    É o número máximo de segundos que o Merge Agent aguarda quando o número de processos de mesclagem simultâneos em execução está no limite definido pela propriedade @max_concurrent_merge de sp_addmergepublication. Se o número máximo de segundos for alcançado e o Merge Agent ainda estiver esperando, será fechado. Um valor de 0 significa que o agente espera indefinidamente, embora possa ser cancelado.

  • -SubscriberDatabasePathsubscriber_database_path
    É o caminho para o banco de dados Jet (arquivo .mdb) se SubscriberType for 2 (permite uma conexão com o banco de dados Jet sem o DSN (Nome da Fonte de Dados) ODBC ).

  • -SubscriberDBAddOption [0| 1| 2| 3]
    Especifica se existe um banco de dados do Assinante.

    Valor SubscriberDBAddOption

    Descrição

    0

    Use o banco de dados existente (padrão).

    1

    Crie um banco de dados de Assinante novo, vazio.

    2

    Crie um novo banco de dados e anexe-o ao arquivo especificado.

    3

    Crie um novo banco de dados, anexe o banco de dados e habilite todas as assinaturas que possam existir no arquivo.

    ObservaçãoObservação

    Quando você usa os valores 2 e 3, o caminho do banco de dados para o Assinante deve ser especificado na opção SubscriberDatabasePath .

  • -SubscriberLoginsubscriber_login
    É o nome de logon do Assinante. Se SubscriberSecurityMode for 0 (para Autenticação do SQL Server), esse parâmetro deverá ser especificado.

  • -SubscriberPasswordsubscriber_password
    É a senha de Assinante. Se SubscriberSecurityMode for 0 (para Autenticação do SQL Server), esse parâmetro deverá ser especificado.

  • -SubscriberSecurityMode [ 0| 1]
    Especifica o modo de segurança do Assinante. Um valor de 0 indica Autenticação do SQL Server (padrão), e um valor de 1 indica Modo de Autenticação do Windows.

  • -SubscriberConflictClean [ 0| 1]
    Se as tabelas de conflitos são limpas no Assinante durante o processo de sincronização, onde um valor de 1 indica que as tabelas de conflitos são limpas no Assinante. Esse parâmetro só é usado para assinaturas de publicações com log de conflitos descentralizado.

  • -SubscriberType [ 0| 1| 3| 4| 5| 6| 7| 8]
    Especifica o tipo de conexão de Assinante usado pelo Merge Agent. Somente o valor padrão de 0 tem suporte para esse parâmetro.

  • -SubscriptionType[ 0| 1| 2]
    Especifica o tipo de assinatura para distribuição. Um valor 0 indica uma assinatura push (padrão), um valor 1 indica uma assinatura pull e um valor 2 indica uma assinatura anônima.

  • -SyncToAlternate [ 0|1]
    Especifica se o Merge Agent está sincronizando entre um Assinante e um Publicador alternativo. Um valor de 1 indica que é um Publicador alternativo. O padrão é 0.

  • -UploadGenerationsPerBatchupload_generations_per_batch
    É o número de gerações a ser processado em um único lote durante o carregamento de alterações do Assinante para o Publicador. Uma geração está definida como um grupo lógico de alterações por artigo. O padrão para um vínculo de comunicação confiável é 100. O padrão para um vínculo de comunicação não confiável é 1.

  • -UploadReadChangesPerBatchupload_read_changes_per_batch
    É o número de alterações a ser lido em um único lote durante o carregamento de alterações do Assinante para o Publicador. O padrão é 100.

  • -UploadWriteChangesPerBatchupload_write_changes_per_batch
    É o número de alterações a ser aplicado em um único lote durante o carregamento de alterações do Assinante para o Publicador. O padrão é 100.

  • -UseInprocLoader
    Aprimora o desempenho do instantâneo inicial fazendo com que o Merge Agent use o comando BULK INSERT ao aplicar arquivos de instantâneo no Assinante. Esse parâmetro é preterido porque não é compatível com o tipo de dados de XML. Se você não estiver replicando dados XML, esse parâmetro poderá ser usado. Esse parâmetro não pode ser usado com instantâneos de modo de caractere. Se você usar esse parâmetro, a conta de serviço do SQL Server no Assinante deverá ter permissões de leitura no diretório onde os arquivos de dados .bcp de instantâneo estão localizados. Quando esse parâmetro não é usado, o driver ODBC carregado pelo agente lê a partir dos arquivos, portanto o contexto de segurança da conta de serviço do SQL Server não é usado.

  • -Validate [0|1|2|3]
    Especifica se a validação deve ser feita no final da mensagem de mesclagem e, se for, o tipo de validação. O valor 3 é o valor recomendado.

    Valor de validação

    Descrição

    0 (padrão)

    Nenhuma validação.

    1

    Validação só de número de linhas.

    2

    Validação de número de linhas e soma de verificação.

    3

    Validação de número de linhas e soma de verificação binária.

    ObservaçãoObservação

    A validação com o uso de soma de verificação binária ou soma de verificação pode reportar incorretamente uma falha se os tipos de dados forem diferentes no Assinante e no Publicador. Para obter mais informações, consulte a seção "Considerações para validação de dados" em Validando os dados replicados.

  • -ValidateIntervalvalidate_interval
    É a frequência, em minutos, com que a assinatura é validada em modo contínuo. O padrão é 60 minutos.

Comentários

Observação importanteImportante

   Se você instalou o SQL Server Agent para executar com uma conta Sistema Local em vez de uma conta de usuário de domínio (o padrão), o serviço só poderá acessar o computador local. Se o Merge Agent executado no SQL Server Agent for configurado para usar o Modo de Autenticação do Windows ao fazer logon no SQL Server, o Merge Agent falhará. A configuração padrão é Autenticação do SQL Server.

Para iniciar o Merge Agent, execute replmerg.exe no prompt de comando. Para obter informações, consulte Executáveis do agente de replicação.

Consulte também

Conceitos