这一篇教程,我们一起来了解如何在Ubuntu系统中将Django2的Web项目部署到Apache服务器。
这里环境搭建的内容包括:
在进行正式操作之前,我先做下总结。
就这样一个组合,整整虐待了我三天半的时间,大大小小的坑层出不穷。
不过,正是因为有坑才能学到本领。
想学会跑,就不能怕摔倒,而且还要有勇气爬起来。
在这三天半的时间里,我参照网上的各种相关资料,几乎没有一个行得通。
不是使用的Python或Django版本较低,就是缺乏实践验证的抄袭之作。
特别是有些错误,根本没有资料可查,全靠自己分析。
在接下来的教程中,我会对各种坑给出说明,希望能够为初学者以及开发人员提供帮助。
好了!接下来,进入正题。
首先,我们先来看一下使用的系统以及相关的软件程序。
在上图中,包含了我们要安装的所有系统支持程序和应用程序。
注意:橘黄色线段指出的是安装顺序,不按照顺序安装就会掉到坑里。
然后,我们分五个步骤来完成Django的部署。
提示:我会边做边写,所以可以保证这篇教程的有效性!
这一篇教程,我们先完成前两个步骤。
一、添加系统支持
1、安装系统
关于如何安装系统,这里省略,大家可以参考网上的一些资料,基本上都能安装完成。
安装系统有几种方式:
提示:腾讯云和阿里云都提供了面向个人用户的免费体验云主机(有时限)。
我用的是腾讯云服务器,安装完系统就能够进入命令行模式的界面了。
2、基本命令
既然是命令行模式,我们就要掌握一些基本命令:
了解了这些基础的操作指令,对于我们完成任务已经够用了。
3、安装启动程序
安装命令:
sudo apt install xinit
命令中的apt是指高级软件包工具(Advanced Package Tool),本身集成了大量软件程序,能够快速帮助我们完成软件程序的安装。(也可以使用apt-get代替apt,但是不建议这样做,apt是友好版的apt-get,提供进度条和彩色字符等功能)
而安装的“Xinit”通常用在启动 X (图形架构)时执行窗口管理器 和其他程序。
第1个坑:这个如果不安装,后面的有些程序会安装失败。
4、安装图形界面
有些操作还是在图形界面中比较方便。
这里我选择安装的是Xubuntu-desktop。
这个桌面环境基于桌面环境Xfce,主要面向旧式电脑的用户和寻求更快捷的桌面环境的用户。
因为毕竟是服务器,图形界面会带来大量的资源消耗,没有必要使用比较华丽的界面。
另外,Ubuntu16.04集成了LightDM(桌面显示管理器),可以很好的支持Xubuntu-desktop,所以就省略了安装与之对应的桌面显示管理器XDM。
安装命令:
sudo apt-get install xubuntu-desktop
安装过程中会提示:Do you want to continue? [Y/n]
输入“y”并按下回车键继续安装程序。
提示:很多安装程序都会出现这个提示,照此操作就可以了,后文不再赘述。
等到命令行再次出现光标闪烁,安装过程就结束了。
5、安装远程登录
安装远程登录是想通过Windows的远程桌面连接工具连接云主机,方便进行一些图形界面下的操作,如果是本机或虚拟机中安装的Ubuntu系统可以略过此步骤。
第2个坑:这里最好不要用“apt”,会出现“Sub-process /usr/bin/dpkg returned an error code (1)”错误。
安装命令:
sudo apt-get install xrdp
sudo apt-get install vnc4server tightvncserver
完成安装之后,就可以打开Windows的远程桌面连接工具,输入云服务器的公网IP进行远程连接了。
第3个坑:如果远程登录输入密码后提示“xrdp_mm_process_login_response: login failed”,可以通过命令“sudo service xrdp restart
”尝试重新启动xrdp来解决。
在打开的连接界面中,输入Ubuntu系统的用户名和密码,就进入到了云服务器主机的桌面中。
因为是第一次登录图形界面,会有一个提示,点击蓝色的按钮(使用默认配置)即可,另外一个按钮是创建一个空界面。
假如还有另外一个错误提示,不用管它,取消勾选后,点继续按钮即可。
图形界面支持中文,在桌面左上角所有应用程序【Applications】的设置【Settings】中,找到语言支持【Language Support】选项,此时会提示安装语言,点击安装按钮(Install),输入系统密码后,按回车键进行安装。安装后即可在设置界面中安装/卸载语言【Install/Remove Languages】,右侧列表中找到简体中文【Chinese(simplified)】后勾选,并点击应用【Apply】。
此时,又会提示输入系统密码,输入密码并生效按钮【Authenticate】后,开始应用过程,简体中文语言名称【汉语(中国)】就会出现在语言列表中,用鼠标指针点住名称,拖动到默认的英文【English】上方后松开,然后点击应用到系统【Apply System-Wide】。
最后,在所有应用程序【Applications】菜单中选择注销【Log Out】,再选择重启系统【Restart】就能够使用中文图形界面了。
当然,也可以使用命令行重启。
执行命令:
sudo reboot
6、更新高级软件包工具
提示:如果使用的云主机,接下来的操作建议在远程连接界面中使用命令行终端执行(桌面下方有命令行终端的图标)。
高级软件包工具包含了很多常用的软件程序,但是很多都已经不是新版本,或者有些我们需要的程序不在其中。
所以,我们要进行更新操作。
不过,我们后面再需要使用到的Python3.6-dev并不在已集成的程序中,所以我们需要添加软件更新源的地址。
执行命令:
sudo vi /etc/apt/sources.list
此时会在命令行终端通过vi编辑器打开文件“sources.list”,我们按“i”键(注意别按多了)进入编辑模式,在文件的开始我们添加一行软件源的地址:deb http://cz.archive.ubuntu.com/ubuntu bionic main
第4个坑:添加这个软件源地址,是因为这个软件源中包含我们需要的软件包“python3.6-dev”,系统中没有集成,自带软件源中也没有,所以要添加这个软件源并同步更新高级软件包工具。
添加完毕后,按“ESC”键退出编辑模式,然后输入“:wq”(屏幕左下角会出现输入的内容)保存退出。
如果编辑错了,或者不想保留编辑的内容,想要退出的话可以输入“:q!”强制退出。
如果只是查看即关闭的话,命令是“:q”。
完成了软件更新源的设置,我们升级高级软件包工具。
第5个坑:这里最好不要用“apt”,会出现一个Python3-aptdaemon不完整程序包的错误,还是使用“apt-get”比较稳妥。
先同步一下更新源。
执行命令:
sudo apt-get update
然后进行程序更新。
执行命令:
sudo apt-get upgrade
提示:安装过程漫长,但不要离开,因为有些选项提示需要输入“y”或者“n”或者提示中的其他字母或数字。
第6个坑:在执行上方命令过程中,如果意外退出命令行终端,可能会导致执行其它apt执行命令无效,提示被锁定以及其他进程正在使用。
解决办法:
sudo ps -A | grep apt
sudo kill [进程数字编号]
sudo dpkg --configure -a
到这里需要的系统支持就操作完成了。
二、添加软件包支持
1、安装依赖文件
sudo apt install openssl
sudo apt install libssl.dev
sudo apt install zlib*
第7个坑:如果不安装“openssl”和“libssl.dev”,在线安装一些第三方库(例如Django)时,“https://”开头的下载地址无法连接,提示“SSL”相关的错误。
第8个坑:如果不安装“zlib*”,在安装之后的一些软件包时,软件包中的一些文件无法解压释放,导致安装失败。
2、安装Sqlite3和依赖
第9个坑:如果不先安装Sqlite3,而是先安装Python3.6,会导致找不到“_sqlite3”模块的错误。
安装命令:
sudo apt install sqlite3
sudo apt install libsqlite3-dev
第10个坑:如果不安装Sqlite3的依赖包“libsqlite3-dev”,在Python代码中导入“sqlite3”模块,会出现错误“ModuleNotFoundError: No module named ‘_sqlite3’”。特别注意软件包名称是“libsqlite3-dev”不是“libsqlite-dev”,后者也能安装,但不支持Python3.6。
3、安装Apache2.4和依赖
安装命令:
sudo apt install apache2
sudo apt install apache2-dev
第11个坑:如果不安装Apache2的依赖包“apache2-dev”,后面安装“mod_wsgi”时会出现“apxs: not found”的错误。
4、安装Python3.6和依赖
首先,下载Python3.6的安装包(这里是Python-3.6.5rc1.tgz),这里是放在/home/ubuntu/Downloads/目录中。
如果是远程连接云主机,可以在本地下载后,使用软件WinSCP上传到云主机的/home/ubuntu/Downloads/目录下。
如果是在图形界面中,可以在安装包上点击右键,选择解压缩到当前文件夹(Extract Here)。
也使用命令行。
执行命令:
cd /home/ubuntu/Downloads/
sudo tar xfz Python-3.6.5rc1.tgz
这里使用xfz命令,因为使用-xvzf命令释放的文件夹需要root权限才可以更改或者删除。
释放完成后,进入解压后的文件夹。
执行命令:
cd /home/ubuntu/Downloads/Python-3.6.5rc1
然后,就能进行安装了。
首先,进行安装配置。
执行命令:
sudo ./configure --enable-shared --with-ssl=openssl
第12个坑:此命令后面的参数一定要带上,如果不带“--enable-shared
”参数,将导致“mod_wsgi”安装失败,如果不带“--with-ssl=openssl
”,会导致使用pip命令在线安装下载地址为“https://”开头的第三方库时,无法连接的错误(SSL错误)。
然后,创建安装文件。
执行命令:
sudo make
第13个坑:如果之前已经进行过安装过程,这里可能会提示错误,可以通过执行“sudo make clean
”先清空之前的安装残留,再执行“sudo make
”命令。
最后,开始执行安装。
执行命令:
sudo make install
接下来,安装依赖。
执行命令:
sudo apt install python3.6-dev
第14个坑:如果没有安装这个依赖,下一步安装“mod_wdgi”,会出现“src/server/wsgi_python.h:24:20: fatal error: Python.h: No such file or directory”的错误。
5、安装mod_wdgi建立python与apache的连接
第15个坑:不能用pip命令安装mod_wdgi,原因见下一个坑。
下载安装包mod_wsgi-4.6.2.tar.gz,这个版本支持Python3.6,解压后进入文件夹。
执行命令:
cd /home/ubuntu/Downloads/mod_wsgi-4.6.2
然后,进行安装配置。
执行命令:
sudo ./configure --with-python=python3.6
第16个坑:如果不加参数“--with-python=python3.6
”,后果就是wsgi会连接系统默认的python2.7,导致错误,错误提示中有“include python2.7”的内容。这是最大的一个坑,网上很难查到资料,我是尝试使用“./configure --with-python3.6
”产生的帮助提示中找到的答案。
接下来,创建安装文件并进行安装。
执行命令:
sudo make
sudo make install
也可以写成:
sudo make && sudo make install
第17个坑:这样写有时候会执行会出错,特别注意第二个“sudo”别漏写。
6、安装Django2
可以使用pip命令安装。
第18个坑:不能直接执行pip命令,因为系统中自带Python2.7和Python3.5分别占用了“python”和“python3”这两个命令,如果想给Python3.6安装Django(也只有Python3.6才能装Django2),必须先进入Python3.6的“site-packages”目录。
执行命令:
cd /usr/local/lib/python3.6/site-packages/
pip install django
在线安装有些复杂,其实我们也可以通过安装包进行安装。
下载安装包Django-2.0.3.tar.gz,解压后进入文件夹。
执行命令:
cd /home/ubuntu/Downloads/Django-2.0.3
sudo python3.6 setup.py install
第19个坑:pytz是Django的依赖,在执行Django的安装时也会自动在线安装,但是有可能导致安装停止。可以参考在线安装的方法,先安装pytz。
再次:为Python3.6安装第三方库,一定要先进入“/usr/local/lib/python3.6/site-packages/”目录,再执行pip安装命令。
最后,我们做一下测试,看一下是否一切正常。
执行命令:
python3.6
>>>import django
>>>import sqlite3
如果没有任何错误出现,我们就完成了所需软件包的安装。
本文链接:http://so.lmcjl.com/news/20736/