Condividi tramite


Rilevamento dei conflitti nella replica peer-to-peer

La replica transazionale peer-to-peer consente di inserire, aggiornare o eliminare dati in qualsiasi nodo di una topologia e di propagare le modifiche agli altri nodi. Poiché è possibile modificare i dati in qualsiasi nodo, si potrebbe verificare un conflitto tra le modifiche apportate ai dati in nodi diversi. Se una riga viene modificata in più nodi, può causare un conflitto o persino la perdita di un aggiornamento quando viene propagata in altri nodi.

Con la replica peer-to-peer in SQL Server 2008 viene introdotta l'opzione che consente di abilitare il rilevamento dei conflitti in una topologia peer-to-peer. Questa opzione consente di evitare problemi causati da conflitti non rilevati, tra cui il comportamento incoerente dell'applicazione e la perdita di aggiornamenti. Se questa opzione è abilitata, per impostazione predefinita una modifica in conflitto viene considerata come un errore critico che impedisce il corretto funzionamento dell'agente di distribuzione. In caso di conflitto, la topologia rimane in uno stato incoerente finché il conflitto non viene risolto e i dati non vengono resi coerenti nell'intera topologia.

[!NOTA]

Per prevenire potenziali incoerenze dei dati, evitare che si verifichino conflitti in una topologia peer-to-peer, anche quando il rilevamento dei conflitti è abilitato. Per garantire che le operazioni di scrittura relative a una determinata riga vengano eseguite in un unico nodo, le applicazioni che accedono e modificano i dati devono partizionare le operazioni di inserimento, aggiornamento ed eliminazione. Tale partizionamento assicura che le modifiche apportate a una determinata riga in un singolo nodo vengano sincronizzate con tutti gli altri nodi della topologia prima che la riga venga modificata da un nodo diverso. Se un'applicazione richiede funzionalità avanzate di rilevamento e risoluzione dei conflitti, utilizzare la replica di tipo merge. Per ulteriori informazioni, vedere Panoramica della replica di tipo merge e Rilevamento e risoluzione di conflitti tra repliche di tipo merge.

Informazioni sui conflitti e sul relativo rilevamento

In un singolo database le modifiche apportate alla stessa riga da applicazioni diverse non generano un conflitto, in quanto le transazioni sono serializzate e vengono utilizzati blocchi per gestire le modifiche simultanee. In un sistema distribuito asincrono, ad esempio la replica peer-to-peer, le transazioni agiscono in modo indipendente su ogni nodo e non sono presenti meccanismi per serializzarle tra più nodi. È possibile utilizzare un protocollo come il commit 2PC, che tuttavia influisce in modo significativo sulle prestazioni.

Nei sistemi come la replica peer-to-peer i conflitti non vengono rilevati quando viene eseguito il commit delle modifiche nei singoli peer. Vengono invece rilevati quando queste modifiche vengono replicate e applicate in altri peer. Nella replica peer-to-peer i conflitti vengono rilevati dalle stored procedure che applicano le modifiche a ogni nodo, in base a una colonna nascosta in ogni tabella pubblicata. Questa colonna nascosta archivia un ID costituito dalla combinazione tra un ID origine specificato per ogni nodo e la versione della riga. Durante la sincronizzazione, l'agente di distribuzione esegue le procedure per ogni tabella. Queste procedure applicano le operazioni di inserimento, aggiornamento ed eliminazione da altri peer. Se una delle procedure rileva un conflitto quando legge il valore della colonna nascosta, genera l'errore 22815 con un livello di gravità 16:

Conflitto di tipo '%s' rilevato nel peer %d tra il peer %d (in entrata) con ID transazione %s e il peer %d (su disco) con ID transazione %s

Per impostazione predefinita, a causa di questo errore l'agente di distribuzione interrompe l'applicazione di modifiche a tale nodo. Per informazioni su come gestire i conflitti rilevati, vedere "Gestione dei conflitti" più avanti in questo argomento.

[!NOTA]

Alla colonna nascosta può accedere solo un utente connesso tramite la connessione amministrativa dedicata (DAC, Dedicated Administrator Connection). Per informazioni su DAC, vedere Utilizzo di una connessione amministrativa dedicata.

La replica peer-to-peer rileva i tipi seguenti di conflitti:

  • Inserimento-inserimento

    Tutte le righe di ogni tabella che partecipa alla replica peer-to-peer sono identificate in modo univoco tramite valori di chiave primaria. Un conflitto di tipo inserimento-inserimento si verifica quando viene inserita una riga con lo stesso valore di chiave in più di un nodo.

  • Aggiornamento-aggiornamento

    Si verifica quando la stessa riga viene aggiornata in più di un nodo.

  • Inserimento-aggiornamento

    Si verifica se una riga viene aggiornata in un nodo ma viene anche eliminata e quindi reinserita in un altro nodo.

  • Inserimento-eliminazione

    Si verifica se una riga viene eliminata in un nodo ma viene anche eliminata e quindi reinserita in un altro nodo.

  • Aggiornamento-eliminazione

    Si verifica se una riga viene aggiornata in un nodo ma viene anche eliminata in un altro nodo.

  • Eliminazione-eliminazione

    Si verifica quando una riga viene eliminata in più di un nodo.

Abilitazione del rilevamento dei conflitti

Per utilizzare il rilevamento dei conflitti, tutti i nodi devono eseguire SQL Server 2008 o una versione successiva e il rilevamento deve essere abilitato per tutti i nodi. In SQL Server 2008 e versioni successive il rilevamento dei conflitti è abilitato per impostazione predefinita in SQL Server Management Studio. Si consiglia di lasciare abilitato il rilevamento, anche negli scenari in cui non si prevedono conflitti. Per abilitare e disabilitare il rilevamento dei conflitti, è possibile utilizzare le stored procedure Management Studio o Transact-SQL:

Gestione dei conflitti

Quando si verifica un conflitto nella replica peer-to-peer, viene generato l'avviso di rilevamento dei conflitti peer-to-peer. Si consiglia di configurare questo avviso in modo da ricevere una notifica quando si verifica un conflitto. Per ulteriori informazioni sugli avvisi, vedere Utilizzo degli avvisi per gli eventi dell'agente di replica.

Dopo l'interruzione dell'agente di distribuzione e la generazione dell'avviso, utilizzare uno degli approcci seguenti per gestire i conflitti che si sono verificati:

  • Reinizializzare il nodo in cui è stato rilevato il conflitto dal backup di un nodo contenente i dati necessari (approccio consigliato). Questo metodo assicura che i dati siano in uno stato coerente. Per ulteriori informazioni, vedere la procedura per l'aggiunta di un nodo a una topologia in Procedura: Configurazione della replica transazionale peer-to-peer (programmazione Transact-SQL della replica).

  • Tentare di sincronizzare nuovamente il nodo consentendo all'agente di distribuzione di continuare ad applicare le modifiche:

    1. Eseguire sp_changepublication: specificare 'p2p_continue_onconflict' per il parametro @property e true per il parametro @value.

    2. Riavviare l'agente di distribuzione.

    3. Verificare i conflitti rilevati utilizzando il Visualizzatore conflitti e determinare le righe coinvolte, il tipo di conflitto e la riga in conflitto confermata. Il conflitto viene risolto in base al valore di ID origine specificato durante la configurazione: la riga che ha origine nel nodo con l'ID più alto è la riga in conflitto confermata. Per ulteriori informazioni, vedere Procedura: Visualizzazione di conflitti di dati per le pubblicazioni transazionali (SQL Server Management Studio).

    4. Eseguire la convalida per assicurare la corretta convergenza delle righe in conflitto. Per ulteriori informazioni, vedere Convalida dei dati replicati.

      [!NOTA]

      Se i dati sono incoerenti dopo questo passaggio, è necessario aggiornare manualmente le righe sul nodo con la massima priorità, quindi consentire la propagazione delle modifiche da questo nodo. Se non sono presenti ulteriori modifiche in conflitto nella topologia, tutti i nodi verranno portati in uno stato coerente.

    5. Eseguire sp_changepublication: specificare 'p2p_continue_onconflict' per il parametro @property e false per il parametro @value.

Vedere anche

Concetti