linux上部署Django项目
使用自动生成的这个数据库

压缩上传
解压运行,不可以
把虚拟环境也打包上传
不行啊,解释器操作系统不一致,不能用
编译部分过程
已编译安装好并且能进入
将现有的site-package备份,用windows传上来的直接替换
现在有Djongo了,但是还报错
从这里下载一个sqlite源码包:https://www.sqlite.org/download.html
编译安装到sqlite3目录下
[root@mcw1 /opt]$ ls sqlite
sqlite3/ sqlite-autoconf-3370000/ sqlite-autoconf-3370000.tar.gz
备份并修改python源码包中的setup文件
[root@mcw1 /opt]$ grep sqlite -C 5 Python-3.6.6/setup.py
if db_setup_debug: print("db: no appropriate library found")
在setup文件中添加sqlite编译安装的目录文件信息。然后重新编译安装python3.6
重新编译安装python3.6之后,继续运行任务
报错:
解决方法:将刚刚编译安装好的python3.6.6的site-package目录备份,然后用windows的pycharm项目使用的解释器中的site-package目录,直接复制过去替代原来的
运行程序
访问页面
安装上面的报错信息提示,修改添加项目配置,允许本机ip访问
然后再次运行项目
至少能访问到页面了
将编译安装在/opt/下的python环境,sqlite3,以及我们的项目目录都传到mcw02主机上。看复制文件是否就能实现djonge项目在其它主机运行。
将项目复制到其它主机,修改主机ip配置,但是无法运行起项目来
sqlie数据库,貌似是不用起进程的,这里编译安装好就行,连接的库也不是这里。而且项目已经连接的数据库,是从pycharm那里运行项目时自动生成的那个sqlite3数据库。还在项目的根目录下,并且能正常使用。
之前上面那个问题解决方法:备份源码,并修改源码,支持当前版本sqlite
查看到报错位置有个检查版本的函数,原来是3,9,0比较。而我的sqlite版本是3.7的,所以我就改了版本比较数为3,3,0.这样就不会因为版本低而无法运行项目了。或许你可以去重新编译安装sqlite版本为3.9以上,但是不只是花时间,而且我自己也没有在官网找到这个版本的包,我3.7已经是下载的最新版本sqlite了。
修改以后,在mcw02主机上重新运行项目,正常运行
然后页面访问迁移到mcw02主机的项目,成功访问。至此,完成了将项目从windows上移到linux上,又从linux上移到到其它linux上。至于为什么要再从linux上移到其它linux上,这是因为生产环境我们尽量不弄乱它的环境。而这里我们可用在windows上开发,在虚拟机上调试好三个目录,能正常运行,然后可以打包直接去生产上解压运行,只是占三个目录,并不会影响到其它目录或者部署的东西到其它目录下。互不干扰。如果python是用虚拟环境的方式,那么需要使用命令创建虚拟环境,暂时对这个没深入研究,害怕创建虚拟环境影响到其它程序使用python,或者自己弄自己的虚拟环境,不小心把其它的虚拟环境也弄坏了,而这个编译安装的python,独自有自己的目录,修改啥的也对其它程序影响小很多;如果sqlite使用的是mysql,那么需要起一个mysql进程,这样会占用资源比较多,而sqlie却没有起进程,就在那个目录下,对其它程序影响小
如果是编译安装的python和 sqlite等,编译安装指定某个目录后,直接打包目录,不只是能跨主机,也是能跨目录的,不是非要在编译安装的目录才能使用
比如下面这个,python3和sqlite都是编译安装到/opt目录下的,但是直接打包放到别的目录或者别的主机,照样可以运行程序