开发环境:ubuntu系统,python3环境

django项目目录: fast_foot 为项目根目录,app为项目应用

现在,我们登陆远程服务器

安装Nginx

安装好了,我们看一下nginx的配置目录

打开nginx.conf这个文件,可以看到以下代码我们nginx配置他是包括了sites-enabled这个文件下的所有文件,所以我们只需在sites-enabled下增加一个我们自己的配置文件就可以使用了。

我们进入sites-enabled目录,复制一份default名字为xxx,名字随意。

然后我们进入我们刚复制的文件进行修改,我们只需修改server里面的内容即可,如下图

然后保存退出,重启一下nginx

nginx配置好了,我们可以运行一下我们的django项目

现在我们通过浏览器访问http://fast-food.zengjielin.top/,结果来了个无法访问

我们都知道浏览器默认的端口是80,我们现在用的是阿里云服务器,还记得有个叫安全组的东西吧,好现在我们来配置一个安全组

然后我们重新访问我们的网址http://fast-food.zengjielin.top/,发现有东西出来了

成功配好nginx,接下来我们来测试我们写出来的接口

先看一下我写的简单的接口

fast-food/app/views.py

fast-food/app/urls.py是这样的

在我们根目录下的fast_food/fast_food/urls.py是这样的

所以我们可以通过这样来访问我们的接口,不出意外会返回{'code': 0}

没想到竟然报错了

不急,我们可以看下报错信息,我们可以看到红色框框的信息,得知,我们缺少一个 HTTP_HOST header

现在我们只需修改fast_food/settinsg.py文件即可,内容如下,保存退出。

重新在浏览器访问我们的接口

发现成功得到我们的结果了。

现在我们项目中可能会出现高并发的情况,所以我们可以用Uwsgi来解决这个问题

首先安装Uwsgi

然后在我们项目的根目录下新建一个fast_food_uwsgi.ini配置文件

保存退出后,我们运行一下我们的uwsgi

然后我们通过浏览器继续访问我们的接口

报了个502,出现报错我们先别紧张,先看下报错信息

红色框框为报错信息,这个问题一定是我们的fast_food_uwsgi.ini配置错误了,我们重新打开在仔细阅读一下我们的代码

发现真的有问题,看到红色框框了没有,nginx把请求发送给uwsgi是用tcp协议的,而我们现在是用浏览器访问我们的uwsgi接口,是要通过http协议的,所以我们只需把socket改成http即可

保存退出,重新运行我们的fast_food_uwsgi.ini文件

uwsgi --inin fast_food_uwsgi.ini

重新在浏览器访问我们的接口

发现我们熟悉的{'code': 0},又出现了。到现在为止我们已经完成nginx+uwsgi+django项目的部署。有什么问题可以在下方留言。

ubuntu服务器上用Nginx和Uwsgi部署django项目的更多相关文章

  1. linux上使用nginx、uwsgi部署django项目

    参考:CentOS7下部署Django项目详细操作步骤 注意事项: 在虚拟环境中操作,虚拟环境中安装nginx.uwsgi,虚拟环境外需安装uwsgi -- 临时关闭防火墙:systemctl sto ...

  2. nginx + uwsgi 部署django项目

    因项目需求,需要部署django项目,这里是基础的nginx配合uwsgi部署django,后续会采用docker部署的方式 环境: centos7 python3.5.4 django2.1.4 u ...

  3. Nginx 和 Gunicorn 部署 Django项目

    目录 Nginx 和 Gunicorn 部署 Django项目 配置Nginx 安装配置Gunicorn 通过命令行直接启动 Gunicorn 与 uwsgi 的区别,用哪个好呢 Gunicorn u ...

  4. nginx+uwsgi部署Django项目到Ubuntu服务器全过程,以及那些坑!!!

    前言:自己在windows上用PyCharm编写的Django项目,编写完后在windows上运行一点问题都没有,但是部署到服务器上时却Bug百出.百度,CSDN,sf,各种搜索寻求解决方案在历时3天 ...

  5. 将树莓派变成一个web服务器(2):Nginx+Flask+uWSGI部署全过程

    1)安装Flask,uwsgi,nginx sudo apt-get update sudo apt-get install python-flask #Flask sudo apt-get inst ...

  6. Nginx + uWSGI 部署Django 项目,并实现负载均衡

    一.uWSGI服务器 uWSGI是一个Web服务器,它实现了WSGI协议.uwsgi.http等协议.Nginx中HttpUwsgiModule的作用是与uWSGI服务器进行交换. 要注意 WSGI ...

  7. 使用Nginx和uwsgi部署Flask项目

    前言   之前用Flask框架开发了一个Python的Web项目,使用Nginx和uWSGI部署起来感觉挺麻烦,过程中还因为对Flask框架的不熟悉,花了好长时间才把应用完全部署起来.下面分享部署成功 ...

  8. 使用Nginx+uWSGI部署Django项目

    1.linux安装python3环境 参考链接:https://www.cnblogs.com/zzqit/p/10087680.html 2.安装uwsgi pip3 install uwsgi l ...

  9. 使用uWSGI部署django项目

    先说说什么是uWSGI吧,他是实现了WSGI协议.uwsgi.http等协议的一个web服务器,那什么是WSGI呢? WSGI是一种Web服务器网关接口.它是一个Web服务器(如nginx)与应用服务 ...

随机推荐

  1. python--AutoPy库

    包括用于控制键盘和鼠标,在屏幕上查找颜色和位图以及显示警报的功能 - 所有这些都是以跨平台,高效和简单的方式进行的.适用于Mac OS X,Windows和X11 中文文档:https://blog. ...

  2. 解决微信小程序textarea 里输入的文字或者是placeholder里的值,飘到弹出view上

    在uniapp微信小程序开发中使用textarea,结果发现输入框的问题浮动起来,view无法把他覆盖,设法设置index的值也不生效,所以只能是通过条件v-if或者v-show使其隐藏就可以了

  3. 第一篇【Zabbix服务端的完整布署】

    1.环境准备 服务器版本: [root@filestore-v2 ~]# cat /etc/redhat-release CentOS Linux release (Core) 内核版本: [root ...

  4. Lyft 基于 Flink 的大规模准实时数据分析平台(附FFA大会视频)

    摘要:如何基于 Flink 搭建大规模准实时数据分析平台?在 Flink Forward Asia 2019 上,来自 Lyft 公司实时数据平台的徐赢博士和计算数据平台的高立博士分享了 Lyft 基 ...

  5. abd常用命令

    1.adb install -r 包名       ----------安装包,-r 替换原有apk安装 2.adb uninstall -k 包名       ---------------卸载包, ...

  6. vue 项目实战之小坑坑

    1. Vue 多个元素动画 ,需要使用 transition-group 标签,并且需要赋值 唯一 key 值. 2. 用ajax 获取到数据赋值给data 后 ,再手动向data里添加的属性无效. ...

  7. sh_19_字符串拆分和拼接

    sh_19_字符串拆分和拼接 # 假设:以下内容是从网络上抓取的 # 要求: # 1. 将字符串中的空白字符全部去掉 # 2. 再使用 " " 作为分隔符,拼接成一个整齐的字符串 ...

  8. 文件操作(stat函数)

    stat函数可以获取文件信息 /*** stat.c ***/ #include<stdio.h> #include<string.h> #include<sys/sta ...

  9. 【知识库】-数据库_MySQL之高级数据查询:去重复、组合查询、连接查询、虚拟表

    简书作者:seay 文章出处: 关系数据库SQL之高级数据查询:去重复.组合查询.连接查询.虚拟表 回顾:[知识库]-数据库_MySQL之基本数据查询:子查询.分组查询.模糊查询 Learn [已经过 ...

  10. C++中void和void*指针的含义 (指针类型的含义)

    转载自:http://blog.csdn.net/lee_shuai 指针有两个属性:指向变量/对象的地址和长度,但是指针只存储地址,长度则取决于指针的类型:编译器根据指针的类型从指针指向的地址向后寻 ...