第一次安装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里面设置了一下。
果然好了!
整件事情耗时了我一晚上加一个半夜,头顶快秃了。好在最后搞定了这个东西。
~\(≧▽≦)/~