Migrazione da PostgreSQL ad Aurora SQL - Amazon Aurora DSQL

Le traduzioni sono generate tramite traduzione automatica. In caso di conflitto tra il contenuto di una traduzione e la versione originale in Inglese, quest'ultima prevarrà.

Migrazione da PostgreSQL ad Aurora SQL

Aurora DSQL è progettata per essere compatibile con PostgreSQL e supporta funzionalità relazionali di base come transazioni ACID, indici secondari, join e operazioni DML standard. La maggior parte delle applicazioni PostgreSQL esistenti può migrare ad Aurora DSQL con modifiche minime.

Questa sezione fornisce linee guida pratiche per la migrazione dell'applicazione ad Aurora DSQL, tra cui compatibilità del framework, modelli di migrazione e considerazioni sull'architettura.

Compatibilità con framework e ORM

Aurora DSQL utilizza il protocollo wire PostgreSQL standard, garantendo la compatibilità con i driver e i framework PostgreSQL. I più diffusi ORMs funzionano con Aurora DSQL con modifiche minime o nulle. Vedi Adattatori e dialetti di Aurora DSQL per le implementazioni di riferimento e le integrazioni ORM disponibili.

Modelli di migrazione comuni

Durante la migrazione da PostgreSQL ad Aurora DSQL, alcune funzionalità funzionano in modo diverso o hanno una sintassi alternativa. Questa sezione fornisce indicazioni sugli scenari di migrazione più comuni.

Alternative operative DDL

Aurora DSQL offre alternative moderne alle tradizionali operazioni DDL PostgreSQL:

Creazione di indici

Utilizzatelo CREATE INDEX ASYNC al posto di quello CREATE INDEX per la creazione di indici non bloccanti.

Vantaggio: creazione di indici senza tempi di inattività su tabelle di grandi dimensioni.

Rimozione dei dati

Usa DELETE FROM table_name invece diTRUNCATE.

Alternativa: per una completa ricreazione a tavola, utilizzare DROP TABLE seguito daCREATE TABLE.

Configurazione del sistema

Aurora DSQL è completamente gestito, quindi la configurazione viene gestita automaticamente in base ai modelli di carico di lavoro. Utilizza la console di AWS gestione o l'API per gestire le impostazioni del cluster.

Vantaggio: non è necessario ottimizzare il database o gestire i parametri.

Modelli di progettazione dello schema

Adatta questi modelli PostgreSQL comuni per la compatibilità con Aurora SQL:

Modelli di integrità referenziale

Aurora DSQL supporta le relazioni e le operazioni tra tabelle. JOIN Per l'integrità referenziale, implementate la convalida a livello di applicazione. Questo design è in linea con i moderni modelli di database distribuiti in cui la convalida a livello di applicazione offre maggiore flessibilità ed evita i colli di bottiglia delle prestazioni dovuti alle operazioni a cascata.

Modello: implementa i controlli di integrità referenziale a livello di applicazione utilizzando convenzioni di denominazione, logica di convalida e limiti di transazione coerenti. Molte applicazioni su larga scala preferiscono questo approccio per un migliore controllo sulla gestione degli errori e sulle prestazioni.

Gestione temporanea dei dati

Utilizza CTEs sottoquery o tabelle normali con logica di pulizia anziché tabelle temporanee.

Alternativa: crea tabelle con nomi specifici della sessione e puliscile nell'applicazione.

Comprendere le differenze architettoniche

L'architettura distribuita e serverless di Aurora DSQL si differenzia intenzionalmente da PostgreSQL tradizionale in diverse aree. Queste differenze consentono i principali vantaggi di semplicità e scalabilità di Aurora DSQL.

Modello di database semplificato

Database singolo per cluster

Aurora DSQL fornisce un database integrato denominato postgres per cluster.

Suggerimento per la migrazione: se l'applicazione utilizza più database, create cluster Aurora DSQL separati per la separazione logica o utilizzate schemi all'interno di un singolo cluster.

Nessuna tabella temporanea

Per la gestione temporanea dei dati, DOVRESTI usare espressioni di tabella (CTEs) e sottoquery comuni, che forniscono alternative flessibili per query complesse.

Alternativa: da utilizzare CTEs con WITH clausole per set di risultati temporanei o tabelle normali con denominazione univoca per dati specifici della sessione.

Gestione automatica dello storage

Aurora DSQL elimina i tablespace e la gestione manuale dello storage. Lo storage si ridimensiona e si ottimizza automaticamente in base ai modelli di dati.

Vantaggio: non è necessario monitorare lo spazio su disco, pianificare l'allocazione dello storage o gestire le configurazioni dei tablespace.

Modelli di applicazione moderni

Aurora DSQL incoraggia modelli di sviluppo di applicazioni moderni che migliorano la manutenibilità e le prestazioni:

Logica a livello di applicazione anziché trigger di database

Per funzionalità simili a quelle dei trigger, implementa la logica basata sugli eventi nel livello dell'applicazione.

Strategia di migrazione: sposta la logica di attivazione nel codice dell'applicazione, utilizza architetture basate sugli eventi con AWS servizi come EventBridge o implementa gli audit trail utilizzando la registrazione delle applicazioni.

Funzioni SQL per l'elaborazione dei dati

Aurora DSQL supporta funzioni basate su SQL ma non linguaggi procedurali come PL/pgSQL.

Alternativa: utilizza le funzioni SQL per le trasformazioni dei dati o sposta la logica complessa sul livello dell'applicazione o sulle funzioni AWS Lambda.

Controllo ottimistico della concorrenza anziché blocco pessimistico

Aurora DSQL utilizza il controllo ottimistico della concorrenza (OCC), un approccio privo di blocchi che si differenzia dai tradizionali meccanismi di blocco del database. Invece di acquisire blocchi che bloccano altre transazioni, Aurora DSQL consente alle transazioni di procedere senza blocchi e rileva i conflitti al momento del commit. Ciò elimina le situazioni di stallo e impedisce che le transazioni lente blocchino altre operazioni.

Differenza fondamentale: quando si verificano conflitti, Aurora DSQL restituisce un errore di serializzazione anziché far attendere le transazioni per i blocchi. Ciò richiede che le applicazioni implementino una logica di ripetizione, simile alla gestione dei timeout di blocco nei database tradizionali, ma i conflitti vengono risolti immediatamente anziché causare attese di blocco.

Modello di progettazione: implementa una logica di transazione idempotente con meccanismi di ripetizione. Progetta schemi per ridurre al minimo i conflitti utilizzando chiavi primarie casuali e distribuendo gli aggiornamenti su tutta la gamma di chiavi. Per informazioni dettagliate, vedi Controllo della concorrenza in Aurora DSQL.

Relazioni e integrità referenziale

Aurora DSQL supporta le relazioni con chiavi esterne tra le tabelle, incluse le operazioni. JOIN Per l'integrità referenziale, implementate la convalida a livello di applicazione. Sebbene l'applicazione dell'integrità referenziale possa essere utile, le operazioni a cascata (come le eliminazioni a cascata) possono creare problemi di prestazioni imprevisti, ad esempio l'eliminazione di un ordine con 1.000 voci diventa una transazione di 1.001 righe. Per questo motivo, molti clienti evitano i vincoli relativi alle chiavi esterne.

Modello di progettazione: implementa i controlli di integrità referenziale a livello applicativo, utilizza eventuali modelli di coerenza o sfrutta AWS i servizi per la convalida dei dati.

Semplificazioni operative

Aurora DSQL elimina molte attività tradizionali di manutenzione del database, riducendo il sovraccarico operativo:

Non è richiesta alcuna manutenzione manuale

Aurora DSQL gestisce automaticamente l'ottimizzazione dello storage, la raccolta di statistiche e l'ottimizzazione delle prestazioni. I comandi di manutenzione tradizionali, ad esempio, VACUUM vengono gestiti dal sistema.

Vantaggio: elimina la necessità di finestre di manutenzione del database, pianificazione a vuoto e ottimizzazione dei parametri di sistema.

Partizionamento e scalabilità automatici

Aurora DSQL partiziona e distribuisce automaticamente i dati in base ai modelli di accesso. Utilizza UUIDs o generati dall'applicazione per una distribuzione ottimale IDs .

Suggerimento per la migrazione: rimuovete la logica di partizionamento manuale e lasciate che Aurora DSQL gestisca la distribuzione dei dati. Usa UUIDs o generato dall'applicazione per una distribuzione ottimale IDs . Se l'applicazione richiede identificatori sequenziali, vedere. Sequenze e colonne di identità

Considerazioni su Aurora DSQL rispetto alla compatibilità con PostgreSQL

Aurora DSQL presenta differenze nel supporto delle funzionalità rispetto a PostgreSQL autogestito che ne consentono l'architettura distribuita, il funzionamento senza server e la scalabilità automatica. La maggior parte delle applicazioni funziona entro queste differenze senza modifiche.

Per le considerazioni generali, consulta Considerazioni sull’utilizzo di Amazon Aurora DSQL. Per quote e limiti, consulta Quote di cluster e limiti del database in Amazon Aurora DSQL.

  • Aurora DSQL utilizza un unico database integrato denominato postgres per cluster. Per la separazione logica, crea cluster Aurora DSQL separati o utilizza schemi all'interno di un singolo cluster.

  • Il postgres database utilizza la codifica dei caratteri UTF-8, che fornisce un ampio supporto internazionale per i caratteri.

  • Il database utilizza solo le regole di confronto C.

  • Aurora DSQL utilizza UTC come fuso orario del sistema. Postgres memorizza internamente tutte le date e gli orari in base al fuso orario in UTC. È possibile impostare il parametro di TimeZone configurazione per convertire il modo in cui viene visualizzato al client e fungere da impostazione predefinita per l'input del client che il server utilizzerà per la conversione in UTC internamente.

  • Il livello di isolamento delle transazioni è fisso su PostgreSQL Repeatable Read.

  • Le transazioni sono soggette ai seguenti vincoli:

    • Le operazioni DDL e DML richiedono transazioni separate

    • Una transazione può includere solo 1 istruzione DDL

    • Una transazione può modificare fino a 3.000 righe, indipendentemente dal numero di indici secondari

    • Il limite di 3.000 righe si applica a tutte le istruzioni DML (INSERT, UPDATE, DELETE)

  • Le connessioni al database scadono dopo 1 ora.

  • Aurora DSQL gestisce le autorizzazioni tramite concessioni a livello di schema. Gli utenti amministratori creano schemi utilizzando e concedono l'accesso utilizzando. CREATE SCHEMA GRANT USAGE ON SCHEMA Gli utenti amministratori gestiscono gli oggetti nello schema pubblico, mentre gli utenti non amministratori creano oggetti in schemi creati dall'utente per chiarire i limiti di proprietà. Per ulteriori informazioni, consulta Autorizzazione dei ruoli del database a utilizzare SQL nel database.

Se riscontri funzionalità fondamentali per la migrazione ma attualmente non supportate in Aurora DSQL, consulta Fornire feedback su Amazon Aurora DSQL per informazioni su come condividere il feedback con AWS.