之前写了一篇Pycharm远程调试django项目的,只是完成了Django项目在服务器上的运行。而且当时是用的虚拟机,有些坑并没有遇到。前几天买了阿里云的Linux服务器ubuntu16.04,一路搭建环境和部署过程搞了2天多,可以说是神坑无数,最有意思的网上的很多博客是叫踩坑记录,结果照着这些方式去搞出现了很多奇怪的问题,估计也和版本不同有关。这里为了避免少走一些弯路,我就来记录一下整个过程(这里都是默认root用户远程登录下进行操作,项目名为DjangoTest)。
Python环境的配置
因为Python环境都是Linux系统上面自带的,我这里项目用的设Python3.6,安装的过程就不多说了,这里基本没什么问题,安装好后只需把安装目录链接到系统自带的python3(系统自带的是Python3.5)即可。本来这里应该没什么问题的,但刚这个项目需要请求https的链接,因为在本地的时候会这里是不会出问题的,但是一旦放到服务器端,坑也就来了。请求时直接返回这么一句异常
1
| SSLError("Can`t connect to HTTTPS URL because the SSL module is not available"))
|
可以看到用到是python中的ssl模块不存在,直接去安装好相应的openssl模块后,还是抛出这个异常。于是不停的去Google和百度,过程中也是按照类似的答案,结果还是没能解决这个问题。最后我就卸载了Python3.6, 直接用3.5的环境去运行,这个问题才得以解决。
具体应该是因为系统默认的是加载已存在的ssl模块,用3.6版本的虽然也依赖了,但是并不会识别,发现不是来自默认Python环境中自带的,就无法加载。这里感觉也是能配置的,但事实就是我不知道多少次的卸载重装,按照各种方式去安装和依赖,还是出现同样的问题,好在3.6版本的项目在3.5上还是基本兼容的,虽然暴力,但不失为一种办法。(如果哪位有更好的解决办法,欢迎给我留言)
这里完成后就是Python虚拟环境容器的安装和环境变量的配置
1
| pip install virtualenvwrapper
|
这里的话,因为之前写过,就不多说了,可以参考我的之前的一篇博客Pycharm远程调试Django项目。
Mariadb的配置
本来不想写数据库的,但这里我也是第一次用Mariadb,并且在配置文件方面发生了一些变化,也踩了一些坑。
Mariadb是MySQL的一个分支,开发者也是MySQL的作者,所以Mariadb是完全兼容MySQL的基本命令的。
安装
1
| apt-get install mariadb-server
|
如果报本地不存在,就先更新下源
安装完成后直接启动服务
1 2 3
| /etc/init.d/mysql start /etc/init.d/mysql stop /etc/init.d/mysql restart
|
然后直接输入mysql进入数据库后
更改mysql密码
1
| update user set Password = PASSWORD('你的密码') where User ='root';
|
然后设置外部ip访问权限
1 2
| GRANT ALL PRIVILEGES ON *.* TO 'root'@'%' IDENTIFIED BY '你的密码' WITH GRANT OPTION; FLUSH PRIVILEGES;
|
这里完成后 重启一下 ,然后还需要修改一下配置文件中绑定的地址
1
| vim /etc/mysql/mariadb.conf.d/50-server.cnf
|
找到这一行
直接注释掉就可以了。最后需要注意一下,如果是用的阿里云的服务器就需要配置一下安全组规则,开放3306端口。
这样就能完成数据库的远程连接了。
注意:
如果Django项目中用到Mysql的话,需要在服务器端的Python虚拟环境下安装一下
可能会安装出错,因为缺少一些依赖包,安装一下
1
| apt-get install libmysqlclient-dev
|
然后重新安装mysqlclient,这样配置就完成了。
uwsgi的安装和配置
uwsgi也是一种web服务器,这里就不多介绍了,直接开始安装
可以先来测试一下
1
| uwsgi --http 0:80 --module DjangoTest.wsgi
|
然后使用配置文件的方式来启动django项目,可以直接在项目的目录下新建一个uwsgi.ini文件
1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22
| # mysite_uwsgi.ini file [uwsgi] # Django-related settings # 项目根目录的路径 chdir = /你的路径/DjangoTest # Django's wsgi file module = DjangoTest.wsgi # the virtualenv (full path) # process-related settings # master master = true # maximum number of worker processes processes = 10 # the socket (use the full path to be safe socket = :8000 # ... with appropriate permissions - may be needed # chmod-socket = 664 # clear environment on exit vacuum = true # 虚拟环境的目录 pythonpath = /你的虚拟环境的路径/lib/python3.6/site-packages/
|
配置文件写好后,其实我们是可以直接用uwsgi就能完成部署的,使用命令
如果端口号被占用,就直接使用命令查看占用情况
然后使用命令,销毁这些进程
但是为了提高扩展性,我们继续下面的步骤
Nginx的安装与配置
nginx是一个强大的中间件,我们直接把它作为对外的服务接口。
开始安装
然后看看启动、停止和重启命令
1 2 3
| /etc/init.d/nginx start /etc/init.d/nginx stop /etc/init.d/nginx reload
|
这里注意,其它配置文件不要乱改!如果安装完成不能正常启动的话可以重启服务器看看。没问题的话,我们可以在项目目录下新建一个nginx.conf文件,然后按照下面的方式配置
1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29 30 31 32 33
| # the upstream component nginx needs to connect to upstream django { #django项目的端口号 和uwsgi里面的端口号保存一致 server 0.0.0.0:8000; # for a web port socket (we'll use this first) } # configuration of the server server { # nginx服务的端口号 不用修改 listen 80; # the domain name it will serve for # 这里可以填写你的ip地址或者域名 server_name www.test.com; charset utf-8; # max upload size client_max_body_size 75M; # adjust to taste # Django media location /media { alias /你的路径/DjangoTest/media; # 指向django的media目录 } location /static { alias /你的路径/DjangoTest/static; # 指向django的static目录 } # Finally, send all non-media requests to the Django server. location / { uwsgi_pass django; include uwsgi_params; # the uwsgi_params file you installed } }
|
配置写好后,就需要把它链接到Nginx的启动配置文件中,
1
| ln -s /你的目录/DjangoTest/nginx.conf /etc/nginx/conf.d/
|
配置完成后,再去加载一下uwsgi文件。
总结
配置好后,直接输入IP地址或者解析到该IP的域名就能成功访问到Django项目了,这样你也会发现,通过nginx我们可以轻松地配置和部署多个环境不同的站点,只需要把配置文件写好后放入nginx的启动文件中。
最后来整理一下整个访问的过程
1 2 3 4
| 1.使用nginx作为外部接口,直接处理发送过来的请求,如果是静态请求,就直接根据配置的静态文件目录,返回相应的静态资源。 2.如果是动态请求,就通过配置文件将请求转移到uwsgi,uwsgi又会将接受到的请求传递给wsgi(Django项目默认通过wsgi启动服务的),wsgi就会根据请求来调用Django项目中的逻辑来处理请求。 3.处理完成后,又将结果返回给uwsgi,然后uwsgi又继续将结果返回给nginx 4.最后Nginx将处理后的结果返回给用户
|
虽然过程中遇到很多坑,但在多次的尝试中更能加深自己的经验和理解。
最后,祝大家在新的一年里,技术节节高升!!!