2017-07-19 2 views
0

データベーストランザクションを実行するワーカープロセスを持つDjangoアプリケーションがあります。フードの下で、私はアプリケーションにAzure SQLデータベースを添付しています。次のようになりますMicrosoft SQL Server 2008:サーバーへの書き込みに失敗しました

[drive-consumer-1]2017-07-19T03:19:08.545128400Z Traceback (most recent call last): 
[drive-consumer-1]2017-07-19T03:19:08.545133000Z File "/code/miles/management/commands/drive_consumer_worker.py", line 28, in handle 
[drive-consumer-1]2017-07-19T03:19:08.545137900Z  drive_consumer.consume(json.loads(record.value)) 
[drive-consumer-1]2017-07-19T03:19:08.545142500Z File "/code/miles/workers/drive_consumer.py", line 35, in consume 
[drive-consumer-1]2017-07-19T03:19:08.545152200Z  self._on_create(message['calendar_id'], drive_payload, message['access_token']) 
[drive-consumer-1]2017-07-19T03:19:08.545156900Z File "/code/miles/workers/drive_consumer.py", line 46, in _on_create 
[drive-consumer-1]2017-07-19T03:19:08.545161500Z  DriveEvent.objects.create(event_id=response['Id'], drive_id=drive_payload['drive_id']) 
[drive-consumer-1]2017-07-19T03:19:08.545166500Z File "/usr/local/lib/python2.7/site-packages/django/db/models/manager.py", line 85, in manager_method 
[drive-consumer-1]2017-07-19T03:19:08.545171300Z  return getattr(self.get_queryset(), name)(*args, **kwargs) 
[drive-consumer-1]2017-07-19T03:19:08.545175900Z File "/usr/local/lib/python2.7/site-packages/django/db/models/query.py", line 399, in create 
[drive-consumer-1]2017-07-19T03:19:08.545180700Z  obj.save(force_insert=True, using=self.db) 
[drive-consumer-1]2017-07-19T03:19:08.545185400Z File "/usr/local/lib/python2.7/site-packages/django/db/models/base.py", line 796, in save 
[drive-consumer-1]2017-07-19T03:19:08.545190200Z  force_update=force_update, update_fields=update_fields) 
[drive-consumer-1]2017-07-19T03:19:08.545194800Z File "/usr/local/lib/python2.7/site-packages/django/db/models/base.py", line 821, in save_base 
[drive-consumer-1]2017-07-19T03:19:08.545211400Z  with transaction.atomic(using=using, savepoint=False): 
[drive-consumer-1]2017-07-19T03:19:08.545215800Z File "/usr/local/lib/python2.7/site-packages/django/db/transaction.py", line 184, in __enter__ 
[drive-consumer-1]2017-07-19T03:19:08.545220400Z  connection.set_autocommit(False, force_begin_transaction_with_broken_autocommit=True) 
[drive-consumer-1]2017-07-19T03:19:08.545224900Z File "/usr/local/lib/python2.7/site-packages/django/db/backends/base/base.py", line 391, in set_autocommit 
[drive-consumer-1]2017-07-19T03:19:08.545229600Z  self._set_autocommit(autocommit) 
[drive-consumer-1]2017-07-19T03:19:08.545234000Z File "/usr/local/lib/python2.7/site-packages/sql_server/pyodbc/base.py", line 453, in _set_autocommit 
[drive-consumer-1]2017-07-19T03:19:08.545238600Z  self.connection.autocommit = autocommit 
[drive-consumer-1]2017-07-19T03:19:08.545243100Z File "/usr/local/lib/python2.7/site-packages/django/db/utils.py", line 94, in __exit__ 
[drive-consumer-1]2017-07-19T03:19:08.545247700Z  six.reraise(dj_exc_type, dj_exc_value, traceback) 
[drive-consumer-1]2017-07-19T03:19:08.545252200Z File "/usr/local/lib/python2.7/site-packages/sql_server/pyodbc/base.py", line 453, in _set_autocommit 
[drive-consumer-1]2017-07-19T03:19:08.545256800Z  self.connection.autocommit = autocommit 
[drive-consumer-1]2017-07-19T03:19:08.545262600Z Error: ('08S01', '[08S01] [FreeTDS][SQL Server]Write to the server failed (20006) (SQLSetConnectAttr)') 

データベースのinit(settings.py中):DBオブジェクトの呼び出しが次のエラーで失敗し始める作成し、約20分後

class Command(BaseCommand): 
    def handle(self, *args, **kwargs): 
     os.environ.setdefault('DJANGO_SETTINGS_MODULE', 'project.settings') 
     django.setup() 
    consumer = Consumer() 

    logging.info('Booting drive consumer') 

    while True: 
     messages = consumer.poll() 

     for message in messages: 
      ... 
      DriveEvent.objects.create(event_id=response['Id'], drive_id=drive_payload['drive_id']) 
      ... 

:労働者のコードは次のようになります。私の経験パー

DATABASES = { 
     'default': { 
      'ENGINE': 'sql_server.pyodbc', 
      'NAME': os.environ.get('DB_NAME'), 
      'HOST': os.environ.get('DB_HOST'), 
      'PORT': '1433', 
      'USER': os.environ.get('DB_USER'), 
      'PASSWORD': os.environ.get('DB_PASSWORD'), 
      'OPTIONS': { 
       'host_is_server': True, 
       'driver_supports_utf8': True, 
       'extra_params': 'tds_version=7.2;' 
      } 
     } 
    } 

答えて

0

は、7.2バージョンはAzureのSQLデータベースをサポートしていませんtds_versionによって引き起こされているように見えます。他のSOスレッドpymssql: Connection to the database only works sometimesの私の答えは7.3に変更してください。

おそらく、GitHubのサードパーティープロジェクトmichiya/django-pyodbc-azureがあなたの詳細を知る手助けになるかもしれません。

希望します。

+0

TDSバージョン7.3のAzure SQLに接続できません: '(' 08001 '、' [08001] [unixODBC] [FreeTDS] [SQL Server]データソース(0)に接続できません(SQLDriverConnect) ') ' –

+0

@SakshamGupta' OPTIONS'に 'SQL ServerのODBCドライバ13 'という値の' driver'オプションを追加して、もう一度やり直してください。 –

+0

ありがとう、これは動作するようです。私はODBCドライバv13.1を以下の手順でセットアップしなければならなかった:https://docs.microsoft.com/en-us/sql/connect/odbc/linux-mac/installing-the-microsoft-odbc-driver-for -SQLサーバー –

関連する問題