一、sqlite版本问题
Centos自带的sqlite版本过低,安装官网最新的版本后,根据网上的大部分教程可以使Python中import sqlite3 为最新版本,并且使用django时,python manage.py运行时也不会报错。但是使用uwsgi启动,仍然会显示版本问题。
解决办法
删除原来的版本并且安装新的版本
步骤:
1.备份旧版程序
利用命令找出旧版本的位置,将原来的程序拷贝为sqlite3_back作为备份,
同时删除/usr/lib64/libsqlite3.so.0以及/usr/lib64/libsqlite3.so.0.8.6(也可以选择备份),
你的文件所在位置可能与我不同,可以利用find / -name sqlite3* 找到这两个文件,名称是一致的
2.安装新版程序
获取源码:wget https://www.sqlite.org/snapshot/sqlite-snapshot-202011020040.tar.gz
tar -zxvf sqlite-snapshot-202011020040.tar.gz&./configure &makemake install即可
3.库文件拷贝
cp /usr/local/lib/libsqlite3.so.0 /usr/lib64/
这里的目标位置就是我们刚才备份旧文件的位置
注意:
当利用uwsgi程序将django网站公布在公网上时,会发现环境变量中使用的sqlite3 --version以及python中import sqlite3;sqlite3.sqlite_version没问题都是新版的,但是在利用uwsgi --http :8000 --chdir xxxx -w xxx.wsgi命令的时候就会提示错误sqlite3版本有问题,此时就是因为旧版的程序的库文件没有更新,重新将旧版的库文件备份并且将新版库文件拷贝过去即可
原文链接:https://blog.csdn.net/weixin_43364556/article/details/109719370
二、uwsgi配置问题
#uwsgi 的配置中,不使用nginx的时候,需要注释掉socket,打开http
# socket=127.0.0.1:9001
#使用nginx的时候,需要注释掉http,打开socket
# http=0.0.0.0:8000
三、nginx配置问题
nginx的配置网上教程很多,使用腾讯云的话,需要把server_name改为公网ip即可。
server {
listen 80;
server_name 腾讯云服务器的公网ip;
location / {
include uwsgi_params;
uwsgi_pass 127.0.0.1:9001; # 必须和uwsgi中的设置一致
}
}