Note sulla versione di SQL Server 2017 in Linux

Si applica a: SQL Server 2017 (14.x) - Linux

Le note sulla versione seguenti si applicano a SQL Server 2017 (14.x) in esecuzione in Linux. Questo articolo è suddiviso in sezioni corrispondenti a ogni versione. La versione disponibile a livello generale include informazioni dettagliate sul supporto e sui problemi noti elencati. Ogni aggiornamento cumulativo (CU, Cumulative Update) o aggiornamento pubblico (GDR, General Distribution Release) ha un collegamento a un articolo del supporto che descrive le modifiche dell'aggiornamento cumulativo, oltre ai collegamenti dei download dei pacchetti Linux.

Queste note sulla versione sono specifiche delle versioni di SQL Server 2017 (14.x). Per le note sulla versione su altre edizioni, vedere gli articoli seguenti:

Piattaforme supportate

Piattaforma File system Guida all'installazione
Red Hat Enterprise Linux 7.7 - 7.9 o 8.0 - 8.5 Server XFS o EXT4 Guida all'installazione
SUSE Enterprise Linux Server v12 SP3 - SP5 XFS o EXT4 Guida all'installazione
Ubuntu 16.04 LTS 1, 18.04 LTS XFS o EXT4 Guida all'installazione
Docker Engine 1.8+ in Linux N/D Guida all'installazione

1 Il supporto per SQL Server in Ubuntu 16.04 è limitato. Alla fine di aprile 2021, Ubuntu 16.04 è passato dalla finestra di manutenzione standard di cinque anni per le versioni con supporto a lungo termine (LTS) al supporto Extended Security Maintenance (ESM). Per altre informazioni, vedere Transizioni dal supporto LTS di Ubuntu 16.04 al supporto ESM (Extended Security Maintenance) | Ubuntu.

Suggerimento

Per altre informazioni, vedere i requisiti di sistema per SQL Server in Linux. Per i criteri di supporto tecnico più recenti per SQL Server, vedere Criteri di supporto tecnico per Microsoft SQL Server.

Strumenti

La maggior parte degli strumenti client esistenti per SQL Server può essere facilmente usata per SQL Server in esecuzione in Linux. Per usare in modo efficiente alcuni strumenti in Linux, potrebbe essere richiesta una versione specifica. Per un elenco completo di strumenti di SQL Server, vedere Strumenti e utilità SQL per SQL Server.

Versioni più recenti per tutti i pacchetti

Questa sezione elenca le versioni più recenti di ogni pacchetto per distribuzione, per SQL Server 2017. La tabella seguente mostra la versione più recente, ovvero CU 31. Per la cronologia completa della versione, vedere Cronologia delle versioni per SQL Server 2017.

Versione Versione Data Compilare articolo KB
SQL Server 2017 (14.x) CU 31 2022-09-20 14.0.3456.2 KB 5016884

Importante

Si tratta dell'aggiornamento cumulativo finale per SQL Server 2017 (14.x).

  • A partire da CU 4, SQL Server Agent non è più installato come pacchetto separato. Viene installato con il pacchetto motore di database e deve essere abilitato per l'uso.
  • In questa versione il pacchetto mssql-server-is non è supportato in SUSE. Per altre informazioni, vedere SQL Server Integration Services (SSIS).
Distribuzione Nome del pacchetto Versione pacchetto Scarica
Red Hat Enterprise Linux
RHEL 8 Motore di database 14.0.3456.2-3 Pacchetto RPM del motore di database
RHEL 8 Ricerca full-text 14.0.3456.2-3 Pacchetto RPM ricerca full-text
RHEL 8 Disponibilità elevata 14.0.3456.2-3 Pacchetto RPM a disponibilità elevata
RHEL 7 SSIS 14.0.3015.40-1 Pacchetto RPM SSIS
SUSE Linux Enterprise Server
SLES 12 Motore di database 14.0.3456.2-3 Pacchetto RPM del motore di database
SLES 12 Ricerca full-text 14.0.3456.2-3 Pacchetto RPM ricerca full-text
SLES 12 Disponibilità elevata 14.0.3456.2-3 Pacchetto RPM a disponibilità elevata
Ubuntu
Ubuntu 18.04 Motore di database 14.0.3456.2-3 Pacchetto Debian del motore di database
Ubuntu 18.04 Ricerca full-text 14.0.3456.2-3 Pacchetto Debian di ricerca full-text
Ubuntu 18.04 Disponibilità elevata 14.0.3456.2-3 Pacchetto Debian a disponibilità elevata
Ubuntu 16.04 SSIS 14.0.3015.40-1 Pacchetto Debian SSIS

Come installare gli aggiornamenti

Se è stato configurato il repository di aggiornamenti cumulativi (mssql-server-2017), quando si eseguono nuove installazioni si otterrà l'aggiornamento cumulativo più recente dei pacchetti di SQL Server. Se sono necessarie immagini del contenitore Docker, vedere le immagini ufficiali per Microsoft SQL Server in Linux per il motore Docker. Per altre informazioni sulla configurazione del repository, vedere Configurare i repository per SQL Server in Linux.

Se si aggiornano pacchetti di SQL Server esistenti, eseguire il comando di aggiornamento appropriato per ogni pacchetto per ottenere l'aggiornamento cumulativo più recente. Per istruzioni dettagliate sull'aggiornamento per ogni pacchetto, vedere le guide all'installazione seguenti:

Cronologia delle versioni

La tabella seguente elenca la cronologia delle versioni di SQL Server 2017 (14.x).

Versione Versione Data di rilascio
CU 31 14.0.3456.2 2022-09-20
CU 30 14.0.3451.2 2022-07-13
CU 29 GDR 14.0.3445.2 2022-06-14
CU 29 14.0.3436.1 2022-03-30
CU 28 14.0.3430.2 2022-01-13
CU 27 14.0.3421.10 2021-10-27
CU 26 14.0.3411.3 2021-09-14
CU 25 14.0.3401.7 2021-07-12
CU 24 14.0.3391.2 10-05-2021
CU 23 14.0.3381.3 2021-02-24
CU 22 GDR 14.0.3370.1 2021-01-12
GDR 3 14.0.2037.2 2021-01-12
CU 22 14.0.3356.20 2020-09-10
CU 21 14.0.3335.7 2020-07-01
CU 20 14.0.3294.2 2020-04-10
CU 19 14.0.3281.6 2020-02-05
CU 18 14.0.3257.3 2019-12-09
CU 17 14.0.3238.1 2019-10-08
CU 16 14.0.3223.3 2019-08-01
CU 15 GDR 14.0.3192.2 2019-07-09
CU 15 14.0.3162.1 23/05/2019
CU 14 14.0.3076.1 25/03/2019
CU 13 14.0.3048.4 18/12/2018
CU 12 14.0.3045.24 24/10/2018
CU 11 14.0.3038.14 20/09/2018
CU 10 14.0.3037.1 27/08/2018
CU 9 GDR 14.0.3035.2 18/08/2018
GDR 2 14.0.2002.14 18/08/2018
CU 9 14.0.3030.27 18/07/2018
CU 8 14.0.3029.16 21/06/2018
CU 7 14.0.3026.27 24/05/2018
CU 6 14.0.3025.34 19/04/2018
CU 5 14.0.3023.8 20/03/2018
CU 4 14.0.3022.28 20/02/2018
CU 3 14.0.3015.40 03/01/2018
GDR 1 14.0.2000.63 03/01/2018
CU 2 14.0.3008.27 28/11/2017
CU 1 14.0.3006.16 24/10/2017
GA 14.0.1000.169 02/10/2017

Problemi noti

Le sezioni seguenti descrivono i problemi noti di SQL Server 2017 (14.x) in Linux.

Generale

  • La lunghezza del nome host in cui è installato SQL Server non deve superare i 15 caratteri.

    • Soluzione: sostituire il nome in /etc/hostname con un nome di 15 caratteri o meno.
  • Portando manualmente indietro l'ora di sistema, SQL Server smetterà di aggiornare l'ora del sistema interno di SQL Server.

    • Soluzione: riavviare SQL Server.
  • Sono supportate solo le installazioni a istanza singola.

    • Soluzione: Se si vuole avere più di un'istanza in un determinato host, è consigliabile usare le macchine virtuali o i contenitori Docker.
  • Gestione configurazione SQL Server non è in grado di connettersi a SQL Server in Linux.

  • La lingua predefinita dell'account di accesso sa è l'inglese.

    • Soluzione: Cambiare la lingua dell'account di accesso sa con l'istruzione ALTER LOGIN.

Database

  • Non è possibile spostare il database master con l'utilità mssql-conf. Si possono invece spostare altri database di sistema con mssql-conf.

  • Quando si ripristina un database di cui è stato eseguito un backup in SQL Server in Windows, è necessario usare la clausola WITH MOVE nell'istruzione Transact-SQL.

  • Alcuni algoritmi (pacchetti di crittografia) per Transport Layer Security (TLS) non funzionano correttamente con SQL Server in Linux. Ne derivano errori di connessione quando si prova a connettersi a SQL Server, oltre a problemi a stabilire connessioni tra repliche nei gruppi di disponibilità elevata.

    • Soluzione: modificare lo script di configurazione mssql.conf per MSSQL in Linux per disabilitare i pacchetti di crittografia problematici, seguendo questa procedura:

      1. Aggiungere il codice seguente a /var/opt/mssql/mssql.conf.

        [network]
        tlsciphers=AES256-GCM-SHA384:AES128-GCM-SHA256:AES256-SHA256:AES128-SHA256:AES256-SHA:AES128-SHA:!ECDHE-RSA-AES128-GCM-SHA256:!ECDHE-RSA-AES256-GCM-SHA384:!ECDHE-ECDSA-AES256-GCM-SHA384:!ECDHE-ECDSA-AES128-GCM-SHA256:!ECDHE-ECDSA-AES256-SHA384:!ECDHE-ECDSA-AES128-SHA256:!ECDHE-ECDSA-AES256-SHA:!ECDHE-ECDSA-AES128-SHA:!ECDHE-RSA-AES256-SHA384:!ECDHE-RSA-AES128-SHA256:!ECDHE-RSA-AES256-SHA:!ECDHE-RSA-AES128-SHA:!DHE-RSA-AES256-GCM-SHA384:!DHE-RSA-AES128-GCM-SHA256:!DHE-RSA-AES256-SHA:!DHE-RSA-AES128-SHA:!DHE-DSS-AES256-SHA256:!DHE-DSS-AES128-SHA256:!DHE-DSS-AES256-SHA:!DHE-DSS-AES128-SHA:!DHE-DSS-DES-CBC3-SHA:!NULL-SHA256:!NULL-SHA
        

        Nota

        Nel codice precedente ! nega l'espressione. Questo indica a OpenSSL di non usare il pacchetto di crittografia seguente.

      2. Riavviare SQL Server con il comando seguente.

        sudo systemctl restart mssql-server
        
  • I database di SQL Server 2014 (12.x) in Windows che usano OLTP in memoria non possono essere ripristinati in SQL Server in Linux. Per ripristinare un database di SQL Server 2014 (12.x) che usa OLTP in memoria, aggiornare i database a una versione più recente di SQL Server in Windows prima di spostarli in SQL Server in Linux tramite backup/ripristino o scollegamento/collegamento.

  • L'autorizzazione utente ADMINISTER BULK OPERATIONS per il momento non è supportata in Linux.

Rete

Le funzionalità che coinvolgono le connessioni TCP in uscita dal processo sqlservr, ad esempio i server collegati o i gruppi di disponibilità, potrebbero non funzionare se vengono soddisfatte entrambe le condizioni seguenti:

  1. Il server di destinazione è specificato come nome host e non come indirizzo IP.

  2. L'istanza di origine ha IPv6 disabilitato nel kernel. Per verificare se il sistema ha IPv6 abilitato nel kernel, è necessario che vengano superati tutti i test seguenti:

    • cat /proc/cmdline visualizzerà la riga di comando di avvio del kernel corrente. L'output non deve contenere ipv6.disable=1.
    • La directory /proc/sys/net/ipv6/ deve esistere.
    • Un programma C che chiama socket(AF_INET6, SOCK_STREAM, IPPROTO_IP) deve avere esito positivo. Syscall deve restituire fd != -1 e non deve verificarsi l'errore EAFNOSUPPORT.

L'errore esatto dipende dalla funzionalità. Per i server collegati, viene presentato come errore di timeout di accesso. Per i gruppi di disponibilità, il DDL ALTER AVAILABILITY GROUP JOIN nel database secondario avrà esito negativo dopo 5 minuti con un errore download configuration timeout.

Per ovviare al problema, effettuare una delle seguenti operazioni:

  1. Usare gli IP invece dei nomi host per specificare la destinazione della connessione TCP.

  2. Abilitare IPv6 nel kernel rimuovendo ipv6.disable=1 dalla riga di comando di avvio. La modalità di esecuzione di questa operazione dipende dalla distribuzione di Linux e dal bootloader, ad esempio grub. Se si vuole disabilitare IPv6, si può comunque farlo impostando net.ipv6.conf.all.disable_ipv6 = 1 nella configurazione sysctl (ad esempio, /etc/sysctl.conf). Questa operazione impedirà sempre alla scheda di rete del sistema di ottenere un indirizzo IPv6, ma consentirà di usare le funzionalità di sqlservr.

File system di rete (NFS)

Se si usano condivisioni di rete NFS (Network File System, file system di rete) nell'ambiente di produzione, tenere presenti i requisiti di supporto seguenti:

  • Usare NFS versione 4.2 o successiva. Le versioni precedenti di NFS non supportano le funzionalità necessarie, come fallocate e la creazione di file sparse, comuni ai file system moderni.

  • Individuare solo le directory /var/opt/mssql nel montaggio NFS. Non sono supportati altri file, ad esempio i file binari di sistema di SQL Server.

  • Assicurarsi che i client NFS usino l'opzione nolock per il montaggio della condivisione remota.

Localizzazione

  • Se le impostazioni locali non sono in inglese (en_us) durante l'installazione, è necessario usare la codifica UTF-8 nella sessione o nel terminale Bash. Se si usa la codifica ASCII, potrebbe essere visualizzato un errore simile al seguente:

    UnicodeEncodeError: 'ascii' codec can't encode character u'\xf1' in position 8: ordinal not in range(128)
    

    Se non è possibile usare la codifica UTF-8, eseguire il programma di installazione usando la variabile di ambiente MSSQL_LCID per specificare la lingua scelta.

    sudo MSSQL_LCID=<LcidValue> /opt/mssql/bin/mssql-conf setup
    
  • Quando si eseguono mssql-conf setup e un'installazione non in inglese di SQL Server, vengono visualizzati caratteri estesi non corretti dopo il testo "Configurazione di SQL Server..." localizzato. Invece, per le installazioni non basate sull'alfabeto latino, la frase potrebbe mancare completamente. La frase mancante dovrebbe corrispondere alla stringa localizzata seguente:

    The licensing PID was successfully processed. The new edition is [<Name> edition].

    Questa stringa viene visualizzata solo a scopo informativo. Il problema verrà risolto nel successivo aggiornamento cumulativo di SQL Server per tutte le lingue. Il problema non influisce in alcun modo sull'installazione di SQL Server.

Non tutti i filtri sono disponibili con questa versione, inclusi i filtri per i documenti di Microsoft Office. Per un elenco di filtri supportati, vedere Installare la ricerca full-text di SQL Server in Linux.

SQL Server Integration Services (SSIS)

In questa versione il pacchetto mssql-server-is non è supportato in SUSE. È attualmente supportato in Ubuntu e in Red Hat Enterprise Linux (RHEL).

I pacchetti di Integration Services possono usare connessioni ODBC in Linux. Questa funzionalità è stata testata con i driver ODBC di SQL Server e MySQL, ma è previsto che funzioni anche con i driver ODBC Unicode che osservano la specifica ODBC. In fase di progettazione è possibile specificare un DSN o una stringa di connessione per la connessione ai dati ODBC. È anche possibile usare l'autenticazione di Windows. Per altre informazioni, vedere il post di blog che annuncia il supporto ODBC in Linux.

Le funzionalità seguenti non sono supportate in questa versione quando si eseguono pacchetti SSIS in Linux:

  • Database del catalogo di Integration Services
  • Esecuzione pianificata dei pacchetti tramite SQL Agent
  • Autenticazione di Windows
  • Componenti di terze parti
  • Change Data Capture (CDC)
  • Integration Services Scale Out
  • Feature Pack di Azure per SSIS
  • Supporto di Hadoop e HDFS
  • Microsoft Connector for SAP BW

Per un elenco di componenti SSIS predefiniti non attualmente supportati oppure supportati con limitazioni, vedere Limitazioni e problemi noti di SSIS in Linux.

Per altre informazioni su SSIS in Linux, vedere gli articoli seguenti:

SQL Server Management Studio (SSMS)

Le limitazioni seguenti si applicano a SQL Server Management Studio in Windows connesso a SQL Server in Linux.

  • I piani di manutenzione non sono supportati.

  • Il data warehouse di gestione e l'agente di raccolta dati in SQL Server Management Studio non sono supportati.

  • I componenti dell'interfaccia utente di SQL Server Management Studio con le opzioni Autenticazione di Windows o Registro eventi di Windows non funzionano con Linux. È comunque possibile usare queste funzionalità con altre opzioni, ad esempio gli account di accesso SQL.

  • Non è possibile modificare il numero di file di log da conservare.

Vedi anche

Passaggi successivi