Ho un pacchetto SSIS che è piuttosto semplice, solo un'importazione di dati e un'attività SQL da eseguire in seguito. Voglio eseguire il rollback di tutte le parti del pacchetto in caso di errore, quindi inserisco queste attività in un contenitore di sequenza e imposta la proprietà TransactionOption del contenitore di sequenza su "Required" e imposta la proprietà FailPackageonFailure su "True". Questo ha funzionato bene quando stavo prendendo di mira il db locale. Tuttavia, quando provo a modificare la connessione OLE DB su un server remoto, le suddette impostazioni delle proprietà fanno sì che il pacchetto si blocchi e alla fine falliscono con un messaggio di "Impossibile acquisire connessione". Ho visto descrizioni simili di questo problema sul web ma il consiglio è sempre quello di verificare la connessione. Tuttavia, so che la connessione va bene perché quando cambio la proprietà TransactionOption al suo valore predefinito di 'Supportato' il pacchetto funziona correttamente.Contenitore di sequenza SSIS Opzione di transazione
Qualcuno sa perché questo potrebbe accadere? Suppongo che abbia qualcosa a che fare con diverse impostazioni sul server a cui sto cercando di connettermi. Qualcuno sa anche un modo diverso di garantire un rollback completo se qualsiasi parte del pacchetto dovesse fallire.
Grazie per aver letto
A meno che non stia facendo qualcosa di sbagliato, non è nemmeno necessario modificare la proprietà FailPackageonFailure. Potresti pubblicare il set completo di messaggi OnError, OnTaskFailed, OnInformation e OnWarning? Potrebbe essere utile vedere quali sono tutti i messaggi segnalati. – billinkc
grazie per la tua risposta. Hai ragione che il vero colpevole qui sembra essere l'opzione di transazione. ecco i due messaggi err visualizzati DTS_E_CANNOTACQUIRECONNECTIONFROMCONNECTIONMANAGER. "Impossibile arruolarsi nella transazione.". In questo momento sto pensando che questo abbia a che fare con le configurazioni di sicurezza MSDTC sul server (dopo aver verificato con le stesse impostazioni locali) –
MSDTC, ottimo quando funziona; OMFGKILLMENOW quando non lo fa – billinkc