问题原因
引起这个问题的表面问题就如问题里报道的一样,我们系统中的的sqlite3的版本有问题。
我的环境
我遇到这个问题是因为我想将我的django程序配置在docker镜像中,docker镜像中使用的基础镜像为centos7里面所用的sqlite3的版本比较低导致的。
解决办法
删除原来的版本并且安装新的版本
步骤:
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版本有问题,此时就是因为旧版的程序的库文件没有更新,重新将旧版的库文件备份并且将新版库文件拷贝过去即可