Ubuntu16.04+python3+django1.11+uWSGI+nginx部署django项目

Ubuntu16.04+python3+django1.11+uWSGI+nginx部署django项目

相信很多的小伙伴都和我遇到过同样的问题,我们学习django后写好项目后把代码放到服务器上肯定不能使用django自带的服务器给用户来使用我们的网站呀,因为django自带的服务器性能有限所以我们在真正部署的时候是不用它的,那怎么办呢?不用担心我教大家使用nginx服务器来解决这个问题。

nginx

nginx是什么东西,就是和Apache,Tomcat类似的一款服务器软件,如果你真的不知道这是什么鬼东西那就真的没得必要往下面看了,建议先去弄弄清楚这个软件是什么东西,再回过来看就行了。上百度,谷歌搜一搜就好了,其实很简单的。

uWSGI

其实着也是一个服务器软件啦,下面我提供了一个大佬写的文章快去学习学习了。
https://blog.csdn.net/mnszmlcd/article/details/78819237

搭建的原理示意图

我们的目的肯定是是打通浏览器访问我们django代码的通道,首先着条通道上我们要修建两座桥梁,首先是nginx,这是提供给我们浏览器访问的入口,通过nginx转发80端口进来的数据包到本地环回地址(127.0.0.1)的8010端口上(其他端口也是阔以的,这里只是拿8010举例子),然后我们通过uWSGI开启本地的8010供本地访问,这里不理解我可以举个例子,在这里相当于我们运行了

$ python manage.py runserver 127.0.0.1:8010

nginx则起到了一个转发端口的功能,说完了原理,接下来就正式开始我们的安装过程了

配置

安装nginx

首先进入/etc/apt目录下

$ cd /etc/apt

下载公钥

$ sudo wget http://nginx.org/keys/nginx_signing.key

(如果提示找不到命令wget,那就使用命令下载这个http工具:$ sudo apt-get install wget)

加载公钥

$ sudo apt-key add nginx_signing.key

然后把下载源添加在apt下载源的后面 如果你不会使用vim编辑器,也可以使用nano这个比较简单一些

$ sudo vim /etc/apt/sources.list

deb http://nginx.org/packages/ubuntu/ xenial nginx
deb-src http://nginx.org/packages/ubuntu/ xenial nginx

因为我使用的ubuntu系统是16.04版本的对应的发行版名称是xenial

  • Version codename Supported Platforms
  • 14.04 trusty x86_64, i386, aarch64/arm64
  • 16.04 xenial x86_64, i386, ppc64el, aarch64/arm64
  • 17.10 artful x86_64, i386
  • 18.04 bionic x86_64
    对应自己系统的版本选择对应的系统名
    配置好源以后就开始下载安装了安装

$ sudo apt-get update

$ sudo apt-get install nginx

安装完成后我们就启动它

$ sudo nginx

执行命令后没有任何回显 使用ps命令可以查看进程是否启动

$ ps aux | grep nginx

nginx启动后然后在浏览器中输入你服务器的ip地址,回车,只要不出下如下这样无法链接到服务器,说明你nginx是安装成功的

很多时候你可能是配置正确的,但是就是不知道为什么访问不了。很多情况都可能是你选择的云服务商有个安全规则给你关闭了端口,所以你必须手动打开你需要的端口。比如我在第一次用Azure的时候也是遇到了这个问题,而且Azure有个小坑的地方是它有入站规则和出站规则。

这个配置也是有点小坑的地方,我给大家看下我是怎么配置的:

特别是这个源端口范围,最好是使用*不要限制源端口,因为客户端的端口是操作系统随机给的。
下面是出站规则的配置:

我这里是为了开启80端口,如果你是为了开启其他的端口则只需要把我图中的80换成你想要的端口就行了。

安装 uWSGI

uWSGI是python的一个第三方包,首先我们选择用python的虚拟环境来运行我们的项目
但是ubuntu16.04默认的是python3.5,首先我们需要更换为python3.6
加装含有python3.6.4的PPA

$ sudo add-apt-repository ppa:deadsnakes/ppa

如果和我一样报错就可以运行如下命令,没有报错就可以不管了

$ sudo apt install software-properties-common

重新运行如下命令,如果你是root用户则不用加上sudo,否则会出错

$ add-apt-repository ppa:deadsnakes/ppa

$ sudo apt-get update

$ sudo apt-get install python3.6

这里也可以直接把python3.5卸载掉,卸载的命令为:

$ sudo apt-get remove python3.5

然后再安装Python3.6

到了这里,因为源的问题,可能有点慢,,,,

查看新安装的python版本

$ python3.6 -V

我们使用python3命令会默认的访问python3.5的版本,接下来我们替换掉原先的软连接
列出系统当前存在的python版本及python默认的版本

$ ls -l /usr/bin | grep python

我们就是要替换掉途中的这个软连接

$ sudo rm /usr/bin/python3

$ sudo ln -s /usr/bin/python3.6 /usr/bin/python3

重新查看文件,发现多了图中的软连接,就说明成功了

然后我们再运行python3 就默认进入3.6

$ python3

接着安装python虚拟环境
首先安装python3的pip下载工具

$ sudo apt-get install python3-pip

$ python3 -m pip -V

$ sudo python3 -m pip install virtualenv

如果你在运行这天命令的时候出现了如下报错,

则在~/.bashrc 文件末尾加上
export PIP_REQUIRE_VIRTUALENV=false

$ sudo source ~/.bashrc

$ sudo python3 -m pip install virtualenvwrapper

这样便安装成功
并把:

export WORKON_HOME=$HOME/.virtualenvs
export VIRTUALENVWRAPPER_PYTHON=/usr/bin/python3
source /usr/local/bin/virtualenvwrapper.sh

添加在~/.bashrc文件末尾
然后重新读取配置文件使得配置生效

$ source ~/.bashrc

image.png

新建

$ mkvirtualenv py3.6

进入虚拟环境py3.5 前面出下(py3.6)表示已经进入虚拟环境 并安装django,uwsgi

$ workon py3.6

$ pip install django==1.11

$ pip install uwsgi

如果安装uwsgi出现了如下错误

则安装依赖如下

$ sudo apt-get install libpython3.6-dev

然后重新安装uwsgi

$ pip install uwsgi

知道这里我们就把需要的东西的下载安装好了

django hello world

接下来我们使用django写一个简单的helloworld

上传项目到服务器中, 如果不知道怎么上传可以试试pycharm的这个功能

并上传到/var/www目录中

配置nginx,uWSGI

配置文件 django.conf 并放到目录 /etc/nginx/conf.d/ 中

server{

    listen 8008;
    # 47.106.253.190是你的服务器ip
    server_name 47.106.253.190;
    
    charset utf-8;
    
    root /var/www/beike;
    
    index test.html;
    
    location / {
        include /etc/nginx/uwsgi_params;
        uwsgi_pass localhost:8010;
    }
    
    location /static {
        alias /var/www/beike/static/;
    }
    
    #location / {
    #   alias /var/www/beike/;
    #}
    
}

然后配置文件 uwsgi.ini 并放到/var/www/hello中

[uwsgi]
# 作为nginx连接时使用
socket=127.0.0.1:8010
# 直接作为web服务使用
# 配置工程目录
chdir=/var/www/beike
# 配置项目的wsgi目录,相对于工程目录
wsgi-file=beike/wsgi.py

#配置进程线程信息
processes=6
threads=2
enable-threads=True
master=True
pidfile=uwsgi.pid
daemonize=uwsgi.log

然后运行uwsgi

$ uwsgi --ini /var/www/hello/uwsgi.ini

$ nginx -s stop

$ nginx

然后便配置成功,可以访问了

uwsgi的操作命令

你在以后修改了django文件保存后应该重启uwsgi

$ uwsgi --reload uwsgi.pid

如果要停掉uwsgi用如下命令:

$ uwsgi --stop uwsgi.pid

uwsgi.pid文件是你在运行uwsgi --ini /var/www/hello/uwsgi.ini后在uwsgi.ini同级目录下生成的文件。

使用cat命令可以查看uwsgi.pid 文件的内容,在其实保存的就是运行的uwsgi主程序的pid

全部评论

相关推荐

不愿透露姓名的神秘牛友
11-20 19:57
已编辑
某大厂 golang工程师 23.0k*16.0, 2k房补,年终大概率能拿到
点赞 评论 收藏
分享
牛客101244697号:这个衣服和发型不去投偶像练习生?
点赞 评论 收藏
分享
点赞 收藏 评论
分享
牛客网
牛客企业服务