Вот «современный» ответ на этот вопрос. Я успешно развернул Django 1.11 на рабочем сервере Ubuntu 16.04, который подключается к MS SQL Server 2017, работающему на другом сервере.
Сначала установите собственный драйвер MS ODBC «Драйвер ODBC 17 для SQL Server»:
# https://docs.microsoft.com/en-us/sql/connect/odbc/linux-mac/installing-the-microsoft-odbc-driver-for-sql-server#ubuntu-1404-1604-and-1710
sudo su
curl https://packages.microsoft.com/keys/microsoft.asc | apt-key add -
curl https://packages.microsoft.com/config/ubuntu/16.04/prod.list > /etc/apt/sources.list.d/mssql-release.list
apt-get update
ACCEPT_EULA=Y apt-get install msodbcsql
apt-get install unixodbc-dev
# test you can actually get to port 1433 on the server that is running MS SQL:
nc -z -v -w5 host.where.sql.server.is.running.com 1433
# add /opt/mssql-tools/bin to your PATH in .bash_profile, e.g.:
# PATH="$HOME/bin:$HOME/.local/bin:/opt/mssql-tools/bin:$PATH"
# source ~/.bash_profile
# now, test that you can actually connect to MS SQL Server:
sqlcmd -S host.where.sql.server.is.running.com -U db_username -P db_password
Во-вторых, убедитесь, что вы pip install
эти модули:
# https://github.com/michiya/django-pyodbc-azure
django-pyodbc-azure==1.11.9.0
# https://github.com/mkleehammer/pyodbc/wiki
pyodbc==4.0.22
В-третьих, измените запись DATABASES вашего Django settings.py
:
DATABASES = {
'default': {
'ENGINE': 'sql_server.pyodbc',
'NAME': 'db_name',
'USER': 'db_username',
'PASSWORD': 'db_password',
'HOST': 'host.where.sql.server.is.running.com',
'PORT': '1433',
'OPTIONS': {
'driver': 'ODBC Driver 17 for SQL Server',
'isolation_level': 'READ UNCOMMITTED', # prevent SELECT deadlocks
},
},
}
Я опускаю остальную часть моей конфигурации (nginx, Gunicorn, Django REST Framework и т. Д.), Но это выходит за рамки этого ответа.
Обновление: оно работает в производственной среде уже более 6 месяцев и не имеет никаких проблем, кроме специфичных для MS SQL Server взаимоблокировок, когда несколько подключений выполняют запросы SELECT для одной таблицы, что было исправлено с помощью isolation_level
установка. Система ежедневно получает около 2 000 новых пользователей.