Amazon ec2インスタンスからDigitalOceanドロップレットに移行しました。 python app、WSGI、Apache2を構成するときにSSLの問題が発生するまで、すべてが正常に機能しているようです。
ドロップレット:Ubuntu 16.04 Python=バージョン:2.7.12
VirtualHostファイル
WSGISocketPrefix /var/run/wsgi
<VirtualHost *:80>
ServerName c123456.com
#translatr.varunmalhotra.xyz
#DocumentRoot /var/www/html
#ErrorDocument 404 /notFound404.html
ErrorLog /var/log/translatr.error.log
CustomLog /var/log/translatr.access.log combined
WSGIDaemonProcess translatrapp python-path=/var/www/html/translatr:/var/www/html/translatr/ENV/lib/python2.7/site-packages
WSGIScriptAlias / /var/www/html/translatr/translatrapp.wsgi
<Directory /var/www/html/translatr>
WSGIProcessGroup translatrapp
WSGIApplicationGroup %{GLOBAL}
Order deny,allow
Allow from all
</Directory>
`` `
私のアプリはpython requests
モジュールを使用してGETリクエストを作成します。リクエストは500
を返します。ログを確認すると、
[Sat Jan 28 10:46:23.754636 2017] [wsgi:error] [pid 6627:tid 139754554279680] request
= requests.get(link, headers=agents, verify=False)
[Sat Jan 28 10:46:23.754641 2017] [wsgi:error] [pid 6627:tid 139754554279680] File "/va
r/www/html/translatr/ENV/lib/python2.7/site-packages/requests/api.py", line 69, in get
[Sat Jan 28 10:46:23.754645 2017] [wsgi:error] [pid 6627:tid 139754554279680] return
request('get', url, params=params, **kwargs)
[Sat Jan 28 10:46:23.754650 2017] [wsgi:error] [pid 6627:tid 139754554279680] File "/va
r/www/html/translatr/ENV/lib/python2.7/site-packages/requests/api.py", line 50, in reques
t
[Sat Jan 28 10:46:23.754655 2017] [wsgi:error] [pid 6627:tid 139754554279680] respons
e = session.request(method=method, url=url, **kwargs)
[Sat Jan 28 10:46:23.754659 2017] [wsgi:error] [pid 6627:tid 139754554279680] File "/va
r/www/html/translatr/ENV/lib/python2.7/site-packages/requests/sessions.py", line 468, in
request
[Sat Jan 28 10:46:23.754664 2017] [wsgi:error] [pid 6627:tid 139754554279680] resp =
self.send(prep, **send_kwargs)
[Sat Jan 28 10:46:23.754669 2017] [wsgi:error] [pid 6627:tid 139754554279680] File "/va
r/www/html/translatr/ENV/lib/python2.7/site-packages/requests/sessions.py", line 597, in
send
[Sat Jan 28 10:46:23.754673 2017] [wsgi:error] [pid 6627:tid 139754554279680] history
= [resp for resp in gen] if allow_redirects else []
[Sat Jan 28 10:46:23.754678 2017] [wsgi:error] [pid 6627:tid 139754554279680] File "/va
r/www/html/translatr/ENV/lib/python2.7/site-packages/requests/sessions.py", line 195, in
resolve_redirects
[Sat Jan 28 10:46:23.754683 2017] [wsgi:error] [pid 6627:tid 139754554279680] **adapt
er_kwargs
[Sat Jan 28 10:46:23.754687 2017] [wsgi:error] [pid 6627:tid 139754554279680] File "/va
r/www/html/translatr/ENV/lib/python2.7/site-packages/requests/sessions.py", line 576, in
send
[Sat Jan 28 10:46:23.754692 2017] [wsgi:error] [pid 6627:tid 139754554279680] r = ada
pter.send(request, **kwargs)
[Sat Jan 28 10:46:23.754697 2017] [wsgi:error] [pid 6627:tid 139754554279680] File "/va
r/www/html/translatr/ENV/lib/python2.7/site-packages/requests/adapters.py", line 433, in
send
[Sat Jan 28 10:46:23.754702 2017] [wsgi:error] [pid 6627:tid 139754554279680] raise S
SLError(e, request=request) │
[Sat Jan 28 10:46:23.754706 2017] [wsgi:error] [pid 6627:tid 139754554279680] SSLError: C│
an't connect to HTTPS URL because the SSL module is not available.
私はたくさん検索しました。 openssl
、その他の設定をインストールしようとしましたが、本当にイライラしました。 Amazon ec2ではどのようにスムーズに機能するのかわかりませんが、Dropletでは機能しません。
良い方向に助けをいただければ幸いです。ありがとう
pythonバージョンのインストールに問題があったと思います。複数のpythonバージョンがインストールされているか、ビルドが正しくビルドされていません。私はUbuntu 16.04 digitalOcean machine
はpython
インストールなしで提供されます。そのため、手動でインストールする必要がありました。私は https://askubuntu.com/questions/101591/how-do-i-install-python-2-7-2-on-ubunt で与えられた答えに従いました
しかし、何も機能していないようです。
最後に、新しいマシンを作成しましたが、今回はUbuntu 14.04
にはpython
がすでにインストールされています。依存関係をインストールして私のFlaskアプリをデプロイしたところ、正しく動作しました。
Ubuntu 16.04(Pythonなし)をUbuntu 14.04(pythonインストール済み)に変更しました)
ソースからPythonをインストールした場合、再実行する必要があります
./configure
make
Sudo checkinstall
Opensslをインストールした後(Sudo apt install openssl
)。
私は時間の地獄がありました(Ubuntu 14.04、Python 3.7))が、最終的にそれを動作させることができました:
apt install libssl libssl-dev
# compile Python from source:
wget https://www.python.org/ftp/python/3.7.5/Python-3.7.5.tgz
tar -xf Python-3.7.5.tgz
./configure --with-openssl=/openssl/ # make sure that this is where x509_vfy.h sits
make && make altinstall