wsgi那些坑

第一次安装wsgi不懂,装到了系统默认的python3环境,然后pythonhome设置成了项目venv环境的python,错误代码:

```Fatal Python error: init_fs_encoding: failed to get the Python codec of the filesystem encoding Python runtime state: core initialized ModuleNotFoundError: No module named 'encodings'

就这,找了半天相关文章,发现问题就是出在compile的python和运行的python环境不是一个上,最后卸载了wsgi:删除"/usr/lib/apache2/modules/mod_wsgi.so" "/usr/lib/apache2/modules/mod_wsgi.so-3.6"文件,

以及配置文件"/etc/apache2/mods-enabled/wsgi.load"文件,然后make clean。

重新安装

进入到venv环境里:

sudo apt-get install apache2-dev
pip install mod_wsgi
sudo venv/bin/mod_wsgi-express install-module
## 安装完自己记一下so文件名,后面要用

然后找到安装的那个so文件,自己新建一个wsgi.load文件,放进去

cd /etc/apache2/mods-available
sudo vim wsgi.load
## 文件写入如下内容,这个文件名和地址就对应上面安装的
LoadModule wsgi_module /usr/lib/apache2/modules/mod_wsgi-py38.cpython-38-x86_64-linux-gnu.so

编辑一下之前就搞过的那个conf文件,其中WSGIDaemonProcess这么写的

WSGIDaemonProcess sxxxx python-path=/home/ubuntu/codes/backend/sxxxx python-home=/home/ubuntu/codes/backend/venv

enable这个wsgi,重启apache2,然后刷新页面看一下error.log

sudo a2enmod wsgi
sudo systemctl restart apache2
tail -f /var/log/apache2/error.log

又出错了,不过这次这个`Fatal Python error错误就没有了,取而代之的是读取权限的错误...orz

(13) Permission Denied: AH00035: access denied because search permissions are missing on a component of the path

在这里找到一些描述 https://cwiki.apache.org/confluence/display/HTTPD/13PermissionDenied

折腾了有两三个小时,又是查看selinux又是尝试chcon -R -t httpd_sys_content_t /home/ubuntu/codes/

没有鸟用。

然后一个一个文件夹看权限,发现这几个文件夹权限不足,没有---x---

sudo chmod +x /home
sudo chmod +x /home/ubuntu
sudo chmod +x /home/ubuntu/codes

再重启apache2,查看error log

这条过了,又出现新的error......

ERROR django.security.DisallowedHost Invalid HTTP_HOST header: 'api.xxxxxx.com'. You may need to add 'api.xxxxxx.com' to ALLOWED_HOSTS. [PID:18147:MainThread]

 

好在最后一个error就是缺少ALLOWED_HOSTS的设置,在项目的setting.py里面设置了一下。

果然好了!

 

整件事情耗时了我一晚上加一个半夜,头顶快秃了。好在最后搞定了这个东西。

~\(≧▽≦)/~

上一篇:20181334张怡杰《网络对抗技术》Exp7 网络欺诈防范


下一篇:linux 计划任务