| title | Installation guidance for SQL Server on Linux | Microsoft Docs |
|---|---|
| description | Install, update, and uninstall SQL Server on Linux. This article covers online, offline, and unattended scenarios. |
| author | rothja |
| ms.author | jroth |
| manager | craigg |
| ms.date | 04/07/2018 |
| ms.topic | conceptual |
| ms.prod | sql |
| ms.custom | sql-linux |
| ms.technology | linux |
| ms.assetid | 565156c3-7256-4e63-aaf0-884522ef2a52 |
[!INCLUDEappliesto-ss-xxxx-xxxx-xxx-md-linuxonly]
This article provides guidance for installing, updating, and uninstalling SQL Server 2017 and SQL Server 2019 preview on Linux.
Tip
This guide coves several deployment scenarios. If you are only looking for step-by-step installation instructions, jump to one of the quickstarts:
For answers to frequently asked questions, see the SQL Server on Linux FAQ.
SQL Server 2017 is supported on Red Hat Enterprise Linux (RHEL), SUSE Linux Enterprise Server (SLES), and Ubuntu. It is also supported as a Docker image, which can run on Docker Engine on Linux or Docker for Windows/Mac.
| Platform | Supported version(s) | Get |
|---|---|---|
| Red Hat Enterprise Linux | 7.3, 7.4, 7.5, 7.6 | Get RHEL 7.6 |
| SUSE Linux Enterprise Server | v12 SP2 | Get SLES v12 SP2 |
| Ubuntu | 16.04 | Get Ubuntu 16.04 |
| Docker Engine | 1.8+ | Get Docker |
Microsoft also supports deploying and managing SQL Server containers by using OpenShift and Kubernetes.
Note
SQL Server is tested and supported on Linux for the previously listed distributions. If you choose to install SQL Server on an unsupported operating system, please review the Support policy section of the Technical support policy for Microsoft SQL Server to understand the support implications.
SQL Server 2017 has the following system requirements for Linux:
| Memory | 2 GB |
| File System | XFS or EXT4 (other file systems, such as BTRFS, are unsupported) |
| Disk space | 6 GB | Processor speed | 2 GHz |
| Processor cores | 2 cores |
| Processor type | x64-compatible only |
If you use Network File System (NFS) remote shares in production, note the following support requirements:
- Use NFS version 4.2 or higher. Older versions of NFS do not support required features, such as fallocate and sparse file creation, common to modern file systems.
- Locate only the /var/opt/mssql directories on the NFS mount. Other files, such as the SQL Server system binaries, are not supported.
- Ensure that NFS clients use the 'nolock' option when mounting the remote share.
When you install or upgrade SQL Server, you get the latest version of SQL Server from your configured Microsoft repository. The quickstarts use the SQL Server 2017 Cumulative Update CU repository. But you can instead configure the GDR repository or the Preview (vNext) repository. For more information on repositories and how to configure them, see Configure repositories for SQL Server on Linux.
Important
If you previously installed a CTP or RC version of SQL Server 2017, you must remove the preview repository and register a General Availability (GA) one. For more information, see Configure repositories for SQL Server on Linux.
You can install SQL Server 2017 on Linux from the command line. For step-by-step instructions, see one of the following quickstarts:
- Install on Red Hat Enterprise Linux
- Install on SUSE Linux Enterprise Server
- Install on Ubuntu
- Run on Docker
- Provision a SQL VM in Azure
You can install SQL Server 2019 preview on Linux using the same quickstart links in the previous section. However, you must register the Preview (vNext) repository instead of the CU repository. The quickstarts provide instructions on how to do this.
After installing, consider making additional configuration changes for optimal performance. For more information, see Performance best practices and configuration guidelines for SQL Server on Linux.
To update the mssql-server package to the latest release, use one of the following commands based on your platform:
| Platform | Package update command(s) |
|---|---|
| RHEL | sudo yum update mssql-server |
| SLES | sudo zypper update mssql-server |
| Ubuntu | sudo apt-get updatesudo apt-get install mssql-server |
These commands download the newest package and replace the binaries located under /opt/mssql/. The user generated databases and system databases are not affected by this operation.
Tip
If you first change your configured repository, it is possible for the update command to upgrade your version of SQL Server. This is only the case if the upgrade path is supported between the two repositories.
To rollback or downgrade SQL Server to a previous release, use the following steps:
-
Identify the version number for the SQL Server package you want to downgrade to. For a list of package numbers, see the Release notes.
-
Downgrade to a previous version of SQL Server. In the following commands, replace
<version_number>with the SQL Server version number you identified in step one.Platform Package update command(s) RHEL sudo yum downgrade mssql-server-<version_number>.x86_64SLES sudo zypper install --oldpackage mssql-server=<version_number>Ubuntu sudo apt-get install mssql-server=<version_number>sudo systemctl start mssql-server
Note
It is only supported to downgrade to a release within the same major version, such as SQL Server 2017.
To verify your current version and edition of SQL Server on Linux, use the following procedure:
-
If not already installed, install the SQL Server command-line tools.
-
Use sqlcmd to run a Transact-SQL command that displays your SQL Server version and edition.
sqlcmd -S localhost -U SA -Q 'select @@VERSION'
To remove the mssql-server package on Linux, use one of the following commands based on your platform:
| Platform | Package removal command(s) |
|---|---|
| RHEL | sudo yum remove mssql-server |
| SLES | sudo zypper remove mssql-server |
| Ubuntu | sudo apt-get remove mssql-server |
Removing the package does not delete the generated database files. If you want to delete the database files, use the following command:
sudo rm -rf /var/opt/mssql/You can perform an unattended installation in the following way:
- Follow the initial steps in the quickstarts to register the repositories and install SQL Server.
- When you run
mssql-conf setup, set environment variables and use the-n(no prompt) option.
The following example configures the Developer edition of SQL Server with the MSSQL_PID environment variable. It also accepts the EULA (ACCEPT_EULA) and sets the SA user password (MSSQL_SA_PASSWORD). The -n parameter performs an unprompted installation where the configuration values are pulled from the environment variables.
sudo MSSQL_PID=Developer ACCEPT_EULA=Y MSSQL_SA_PASSWORD='<YourStrong!Passw0rd>' /opt/mssql/bin/mssql-conf -n setupYou can also create a script that performs other actions. For example, you could install other SQL Server packages.
For a more detailed sample script, see the following examples:
- Red Hat unattended installation script
- SUSE unattended installation script
- Ubuntu unattended installation script
If your Linux machine does not have access to the online repositories used in the quick starts, you can download the package files directly. These packages are located in the Microsoft repository, https://packages.microsoft.com.
Tip
If you successfully installed with the steps in the quick starts, you do not need to download or manually install the SQL Server package(s). This section is only for the offline scenario.
-
Download the database engine package for your platform. Find package download links in the package details section of the Release Notes.
-
Move the downloaded package to your Linux machine. If you used a different machine to download the packages, one way to move the packages to your Linux machine is with the scp command.
-
Install the database engine package. Use one of the following commands based on your platform. Replace the package file name in this example with the exact name you downloaded.
Platform Package install command RHEL sudo yum localinstall mssql-server_versionnumber.x86_64.rpmSLES sudo zypper install mssql-server_versionnumber.x86_64.rpmUbuntu sudo dpkg -i mssql-server_versionnumber_amd64.deb[!NOTE] You can also install the RPM packages (RHEL and SLES) with the
rpm -ivhcommand, but the commands in the previous table automatically install dependencies if available from approved repositories. -
Resolve missing dependencies: You might have missing dependencies at this point. If not, you can skip this step. On Ubuntu, if you have access to approved repositories containing those dependencies, the easiest solution is to use the
apt-get -f installcommand. This command also completes the installation of SQL Server. To manually inspect dependencies, use the following commands:Platform List dependencies command RHEL rpm -qpR mssql-server_versionnumber.x86_64.rpmSLES rpm -qpR mssql-server_versionnumber.x86_64.rpmUbuntu dpkg -I mssql-server_versionnumber_amd64.debAfter resolving the missing dependencies, attempt to install the mssql-server package again.
-
Complete the SQL Server setup. Use mssql-conf to complete the SQL Server setup:
sudo /opt/mssql/bin/mssql-conf setup
SQL Server is licensed the same for Linux and Windows. For more information about SQL Server licensing and pricing, see How to license SQL Server.
After installation, you can also install or enable optional SQL Server features.
- SQL Server command-line tools
- SQL Server Agent
- SQL Server Full Text Search
- SQL Server Integration Services
[!INCLUDEGet Help Options]
Tip
For answers to frequently asked questions, see the SQL Server on Linux FAQ.