2017-04-11 83 views
0

我用Djano來構建一個簡單的restful API服務器。服務器和遠程數據庫之間的通信引入了SSL以強化安全性。當API服務器試圖寫入數據庫,我得到了以下錯誤:Django + SSL + mysql:TypeError:__init __()得到了一個意外的關鍵字參數'server_hostname'

File "/app/anaconda/lib/python2.7/site-packages/django/core/handlers/exception.py", line 39, in inner 
    response = get_response(request) 
File "/app/anaconda/lib/python2.7/site-packages/django/core/handlers/base.py", line 187, in _get_response 
    response = self.process_exception_by_middleware(e, request) 
File "/app/anaconda/lib/python2.7/site-packages/django/core/handlers/base.py", line 185, in _get_response 
    response = wrapped_callback(request, *callback_args, **callback_kwargs) 
File "/app/anaconda/lib/python2.7/site-packages/django/views/decorators/csrf.py", line 58, in wrapped_view 
    return view_func(*args, **kwargs) 
File "/app/anaconda/lib/python2.7/site-packages/django/views/generic/base.py", line 68, in view 
    return self.dispatch(request, *args, **kwargs) 
File "/app/anaconda/lib/python2.7/site-packages/rest_framework/views.py", line 474, in dispatch 
    response = self.handle_exception(exc) 
File "/app/anaconda/lib/python2.7/site-packages/rest_framework/views.py", line 434, in handle_exception 
    self.raise_uncaught_exception(exc) 
File "/app/anaconda/lib/python2.7/site-packages/rest_framework/views.py", line 471, in dispatch 
    response = handler(request, *args, **kwargs) 
File "/app/anaconda/lib/python2.7/site-packages/rest_framework/decorators.py", line 52, in handler 
    return func(*args, **kwargs) 
File "/app/mobile/mpq_backup_response/mpq_backup_response/backup_response/views.py", line 39, in sms 
    q.save() 
File "/app/anaconda/lib/python2.7/site-packages/django/db/models/base.py", line 796, in save 
    force_update=force_update, update_fields=update_fields) 
File "/app/anaconda/lib/python2.7/site-packages/django/db/models/base.py", line 821, in save_base 
    with transaction.atomic(using=using, savepoint=False): 
File "/app/anaconda/lib/python2.7/site-packages/django/db/transaction.py", line 158, in __enter__ 
    if not connection.get_autocommit(): 
File "/app/anaconda/lib/python2.7/site-packages/django/db/backends/base/base.py", line 365, in get_autocommit 
    self.ensure_connection() 
File "/app/anaconda/lib/python2.7/site-packages/django/db/backends/base/base.py", line 199, in ensure_connection 
    self.connect() 
File "/app/anaconda/lib/python2.7/site-packages/django/db/backends/base/base.py", line 171, in connect 
    self.connection = self.get_new_connection(conn_params) 
File "/app/anaconda/lib/python2.7/site-packages/django/db/backends/mysql/base.py", line 265, in get_new_connection 
    conn = Database.connect(**conn_params) 
File "/app/anaconda/lib/python2.7/site-packages/pymysql/__init__.py", line 90, in Connect 
    return Connection(*args, **kwargs) 
File "/app/anaconda/lib/python2.7/site-packages/pymysql/connections.py", line 688, in __init__ 
    self.connect() 
File "/app/anaconda/lib/python2.7/site-packages/pymysql/connections.py", line 906, in connect 
    self._request_authentication() 
File "/app/anaconda/lib/python2.7/site-packages/pymysql/connections.py", line 1086, in _request_authentication 
    self._sock = self.ctx.wrap_socket(self._sock, server_hostname=self.host) 
File "/app/anaconda/lib/python2.7/ssl.py", line 352, in wrap_socket 
    _context=self) 
TypeError: __init__() got an unexpected keyword argument 'server_hostname' 

但是,如果我走進Djangon的shell交互環境,直接寫進數據庫中,一切順利。我不知道這個問題發生的原因。

回答

0

這個問題似乎存在於python 2.7.10的OS X中,根據下面的鏈接,很可能會遇到CentOS 7和Python版本2.7.9或更高版本。

https://github.com/gevent/gevent/issues/477

更新GEVENT 1.2.1似乎解決了問題。

你可以在mac上運行「pip install --upgrade gevent」來解決這個問題。

相關問題