pyodb c ошибка: использование django в docker контейнере - PullRequest
0 голосов
/ 09 апреля 2020

Я использую docker контейнер с приложением django.

T выдает приведенную ниже ошибку всякий раз, когда я пытаюсь запустить функцию, которая манипулирует данными в 2 отдельных базах данных:

ошибка: [Microsoft] [ODB C Драйвер 17 для SQL Сервер] Поставщик SSL: [ошибка: 1425F102: подпрограммы SSL: ssl_choose_client_version: неподдерживаемый протокол] (-1) (SQLDriverConnect) ')

Это функция, которую я запускаю

def preStepBtn3(request):
    sourcePE = request.GET.get('sourcePE')
    targetPE = request.GET.get('targetPE')
    inputFTID = request.session['username']
    datetime_object = datetime.datetime.now()
    step_name = "preStepBtn3"
    table_name = "null"
    Action_taken = "change router status to MIG"
    MassivePortalSessionID = request.session['MassivePortalSessionID']

    try:
        with connections['DataAdmin'].cursor() as cursor:
            sql = """DECLARE @out nvarchar(max); exec DTA.mig_sop_ce_status2mig_django 0, %s, @param_out = @out OUTPUT; SELECT @out AS the_output; """
            params = [sourcePE]
            cursor.execute(sql, params)            
            rows = cursor.fetchall()
            result = []
            result.append(rows)
            logDB_sql(MassivePortalSessionID, inputFTID, sourcePE, targetPE,
                      table_name, step_name, datetime_object, Action_taken)
            print("data inserted in log DB")
            while rows:
                print(rows)
                if cursor.nextset():
                    result.append(cursor.fetchall())
                else:
                    print(result)
                    return JsonResponse(result,  safe=False)
    except Exception as ex:
        error = ex
        print(error)
        context = {'text': error}
        logDB_sql(MassivePortalSessionID, inputFTID, sourcePE, targetPE,
                  table_name, step_name, datetime_object, Action_taken)
        print("data inserted in log DB during exception")
        return render(request, 'posts/textArea.html', context)

Всякий раз, когда я удаляю logDB_ sql, он работает отлично. Это код для logDB_ sql

def logDB_sql(MassivePortalSessionID, inputFTID, sourcePE, targetPE, table_name, step_name, datetime_object, Action_taken):
    params = [MassivePortalSessionID, inputFTID, sourcePE, targetPE,
              table_name, step_name, datetime_object, Action_taken]
    print(targetPE)
    print(sourcePE)
    print(MassivePortalSessionID)
    print(inputFTID)
    if sourcePE != None and MassivePortalSessionID != None and targetPE != None and inputFTID != None:
        sql = " insert into MASSIVE_MIGRATION_PORTAL_LOGS values (%s,%s,%s,%s,%s,%s,%s,%s )"
        print(sql)
        print(params)
        with connections['logDB'].cursor() as cursor:
            cursor.execute(sql, params)
            cursor.close()
            print("data inserted")

Это информация о соединении в settings.py. обратите внимание, что это разные хосты

    'logDB': {
        'ENGINE': 'sql_server.pyodbc',
        'NAME': 'log_db',
        'HOST': 'xx.xx.xx.xx',
        'USER': 'user1',
        'PASSWORD': 'password1',

        'OPTIONS': {
            'driver': 'ODBC Driver 17 for SQL Server',
            'timeout': 1000,
        }

    },

    'DataAdmin': {
        'ENGINE': 'sql_server.pyodbc',
        'NAME': 'another_db',
        'HOST': 'xx.xx.xx.xx',
        'USER': 'user1,
        'PASSWORD': 'password1',

        'OPTIONS': {
            'driver': 'ODBC Driver 17 for SQL Server',
            'timeout': 1000,
        }
    },

}

И это сообщение об ошибке

 File "/app/posts/views.py", line 387, in preStepBtn2
    table_name, step_name, datetime_object, Action_taken)
  File "/app/posts/views.py", line 90, in logDB_sql
    with connections['logDB'].cursor() as cursor:
  File "/usr/local/lib/python3.6/site-packages/django/db/backends/base/base.py", line 255, in cursor
    return self._cursor()
  File "/usr/local/lib/python3.6/site-packages/django/db/backends/base/base.py", line 232, in _cursor
    self.ensure_connection()
  File "/usr/local/lib/python3.6/site-packages/django/db/backends/base/base.py", line 216, in ensure_connection
    self.connect()
  File "/usr/local/lib/python3.6/site-packages/django/db/utils.py", line 89, in __exit__
    raise dj_exc_value.with_traceback(traceback) from exc_value
  File "/usr/local/lib/python3.6/site-packages/django/db/backends/base/base.py", line 216, in ensure_connection
    self.connect()
  File "/usr/local/lib/python3.6/site-packages/django/db/backends/base/base.py", line 194, in connect
    self.connection = self.get_new_connection(conn_params)
  File "/usr/local/lib/python3.6/site-packages/sql_server/pyodbc/base.py", line 307, in get_new_connection
    timeout=timeout)
django.db.utils.OperationalError: ('08001', '[08001] [Microsoft][ODBC Driver 17 for SQL Server]SSL Provider: [error:1425F102:SSL routines:ssl_choose_client_version:unsupported protocol] (-1) (SQLDriverConnect)')

Я попробовал его локально на моей машине windows, и он работает без проблем, не уверен почему он не работает, когда я перемещаю его в docker контейнер.

Есть идеи?

1 Ответ

0 голосов
/ 15 апреля 2020

Я решил эту проблему, обновив файл openssl.cnf в /etc/ssl/

Изменен MinProtocol = TLSv1.2 на MinProtocol = TLSv1.0 & CipherString = DEFAULT@SECLEVEL=2 на CipherString = DEFAULT@SECLEVEL=1

Надеюсь, это поможет ,

Добро пожаловать на сайт PullRequest, где вы можете задавать вопросы и получать ответы от других членов сообщества.
...