sof*_*var 6 python ssl wsgi python-requests digital-ocean
我刚从Amazon ec2实例迁移到DigitalOcean droplet.在配置我的python应用程序,WSGI和apache2时遇到SSL问题,一切似乎都运行正常.
Droplet: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>
Run Code Online (Sandbox Code Playgroud)
```
我的应用程序使用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.
Run Code Online (Sandbox Code Playgroud)
我搜索了很多.我试过安装openssl,其他conf,但真的很沮丧.我不知道它如何在亚马逊ec2中顺利运行,但在Droplet中却不行.
任何有关良好方向的帮助都将受到赞赏.谢谢
如果您从源代码安装了Python,则必须重新运行
./configure
make
sudo checkinstall
Run Code Online (Sandbox Code Playgroud)
安装openssl之后(我正在假设sudo apt install openssl).
我认为我安装的 python 版本有问题。要么安装了多个 python 版本,要么构建未正确构建。我的是Ubuntu 16.04 digitalOcean machine没有python安装的。所以我必须手动安装它。我按照https://askubuntu.com/questions/101591/how-do-i-install-python-2-7-2-on-ubuntu上给出的答案进行操作
但是,似乎没有任何作用。
最后,我创建了一台全新的机器,但这一次,它Ubuntu 14.04已经python安装好了。当我安装依赖项并部署 Flask 应用程序时,它工作正常。
将 Ubuntu 16.04(不带 python)更改为 Ubuntu 14.04(安装了 python)。
| 归档时间: |
|
| 查看次数: |
20619 次 |
| 最近记录: |