Django之nginx+wsgi后台部署(最新版)
0-部署准备
1.要使用安全组打开腾讯云的80端口
以实际项目部署为例
项目名称api_learn;
Python版本:python 3.6.6;
虚拟环境名字:djangoEnv;
端口:80;
服务器托管:腾讯云;
服务器版本:ubuntu 16.04;
2.SCP上传项目
scp -r "本地文件目录地址" ubunt@公网IP地址:/"目标地址"
例子
scp -r /Users/lhj/Downloads/api_learn ubuntu@IP:/home/ubuntu
3.本地项目上传之后的配置
1.目录结构问题
我的Django项目中只有一个主要的app名为Inquire,该app有自己的静态文件夹static。在正常的Django项目中,不同的app也应该有各自的static文件夹,但是在之后的nginx配置过程中,我们需要提供项目的一个静态目录地址,这就需要把Django项目所有app的static文件整合到一个文件夹中。此时setting.py文件中关于静态目录的设置如下:
STATIC_URL = '/static/'
# 添加app的静态文件地址,绝对地址和相对地址都可以
STATICFILES_DIRS = [
"/home/ubuntu/api_learn/static"
]
# 统一的静态文件地址
STATIC_ROOT = os.path.join(BASE_DIR, "static/")
配置好后,我们在服务器终端命令行中的/home/ubuntu/HelloWorld目录下执行以下语句完成整合:
python manage.py collectstatic
2.1 数据库配置
2.1.1 数据库安装和配置
青空琉璃:ubuntu18.04下远程连接MySQL数据库zhuanlan.zhihu.com
2.2.2 数据库表新建
青空琉璃:MySQL使用命令行创建数据库zhuanlan.zhihu.com
对应数据库,django项目的setting.py文件
DATABASES = {
'default': {
'ENGINE': 'django.db.backends.mysql',
'NAME': '数据库名称',
'USER': '使用者',
'PASSWORD': '数据库密码',
'HOST': '127.0.0.1',
}
}
# 我们需要一个第三方库用来与MySQL交互,Python3已经不再使用mysqldb,所以我们下载pymysql:
pip install pymysql
#同时在Django项目中的__init__.py中引用:
import pymysql
pymysql.install_as_MySQLdb()
用Mysql建好项目的数据库,然后进入HelloWord目录,用django应用数据模型:
(python使用虚拟环境)
python manage.py makemigrations
python manage.py migrate
建立后台超级用户:
python manage.py createsuperuser
3. 公网访问配置
DEBUG = False
ALLOWED_HOSTS = ['*']
测试
注意到以上两点后,我们可以进行测试了,在项目目录
python manage.py runserver 0.0.0.0:8000
由于在命令行的界面,所以我们可以先将命令放到后台运行
python manage.py runserver 0.0.0.0:8000 &
那么我们也可以将前台运行的转到后台去
# ctrl+z暂停任务
# jobs 查看暂停任务
# bg %[序号] 将任务放到后台继续执行
# fg %[序号] 将任务放到前台继续执行
1-环境安装
简单介绍一下:uWSGI是一个Web服务器,而uwsgi是一种线路协议而不是通信协议,在此常用于在uWSGI服务器与其他网络服务器的数据通信。由于uWSGI是C语言应用程序,所以需要一个C编译器(gcc或clang)和Python开发头文件,所以输入以下语句:
sudo apt-get install build-essential python-dev
build-essential提供编译程序必须软件包的列表信息。python-dev就可以让我们安装一个源外的,内含需要编译的调用python api的c/c++文件的python类库。然后输入以下指令安装uwsgi:
sudo pip install uwsgi # 安装
安装后进行简单的测试,在本地写好如下的测试代码命名为 test.py,把文件传到云主机任意目录下:
def application(env, start_response):
start_response('200 OK', [('Content-Type','text/html')])
return ["success!"]
该目录下输入以下命令:
>> uwsgi --http :8000 --wsgi-file test.py
访问8000端口
curl 127.0.0.1:8000
# 成功返回success
配置uWSGI, 在项目路径下创建uwsgi.ini 文件, 配置如下:
[uwsgi]
#使用nginx连接时使用
#socket=127.0.0.1:8080
#直接做web服务器使用
http=127.0.0.1:8080
#项目目录
chdir=/home/ubuntu/test
#项目中wsgi.py文件的目录,相对于项目目录
wsgi-file=test/wsgi.py
processes=4
threads=2
master=True
pidfile=uwsgi.pid
daemonize=uswgi.log
在uwsgi.ini文件所在目录下, 启动uwsgi 命令:
uwsgi --ini uwsgi.ini
检查是否运行成功
curl 127.0.0.1:8000
# 成功返回首页界面
至此, uwsgi配置完成.
安装 nginx
1.安装并运行
sudo apt-get install nginx
service nginx start
查看是否启动成功:
curl 127.0.0.1
nginx安装成功.
配置nginx
现在就可以在项目根目录下面创建项目名_nginx.conf的文件,然后编写下面文件。
# configuration of the server
server {
# the port your site will be served on
listen 80;
# the domain name it will serve for
server_name 127.0.0.1; # substitute your machine's IP address or FQDN
charset utf-8;
# max upload size
client_max_body_size 75M; # adjust to taste
# Django media
location /media {
alias /home/ubuntu/api_learn/media; # your Django project's media files - amend as required
}
location /static {
alias /home/ubuntu/api_learn/static; # your Django project's static files - amend as required
}
# Finally, send all non-media requests to the Django server.
location / {
uwsgi_pass 127.0.0.1:8080;
include uwsgi_params; # the uwsgi_params file you installed
}
}
此时将uwsgi.ini 文件里的http=127.0.0.1:8080注释掉, 启用上一行的socket=127.0.0.1:8080.
然后把这个配置文件链接到sites-enabled目录下:
sudo ln -s /etc/nginx/sites-available/HelloWorld /etc/nginx/sites-enabled/
检查一下配置文件的语法是否有问题,提示ok就可以
sudo service nginx configtest
重启服务:
service nginx restart
测试
curl 127.0.0.1
# 返回项目首页
至此, nginx 与 wsgi连接完成.
5. 遇到问题
我们可以查看端口号占用情况并杀掉进程
netstat -apn|grep 8000
kill -9 <pid>
Django之nginx+wsgi后台部署(最新版)的更多相关文章
- nginx,wsgi项目部署
1.一些重要概念 https://www.cnblogs.com/xiaonq/p/8932266.html 1.1web容器 什么是web容器 1.web容器是帮助我们部署java丶php丶pyth ...
- django+vue+nginx生产环境部署配置
部署环境: 1. linux redhat 7.1 2.python 3.6.3 3. vue 4. nginx 5. gunicorn 6. supervisord 安装: 一. 基础环境安装 1. ...
- Django + Uwsgi +Nginx生产环境部署
python manage.py runserver 0.0.0.0:80 ,一定不要用这个轻量级Server作为你的生产环境下的Server,因为它只能用于开发自测阶段.它既没有安全审计功能,而且又 ...
- 学习项目部署Django+uwsgi+Nginx生产环境部署
绪论 项目生产环境部署,是很重的一个知识点.第一,Django自带的服务器很简陋,由于测试和开发环境尚可,无法用于生产环境,保障安全性和可靠性.以及性能.此外,学习部署方式,还有利于了解生产部署后的项 ...
- Linux 集群概念 , wsgi , Nginx负载均衡实验 , 部署CRM(Django+uwsgi+nginx), 部署学城项目(vue+uwsgi+nginx)
Linux 集群概念 , wsgi , Nginx负载均衡实验 , 部署CRM(Django+uwsgi+nginx), 部署学城项目(vue+uwsgi+nginx) 一丶集群和Nginx反向代理 ...
- django自带wsgi server vs 部署uwsgi+nginx后的性能对比
一.下面先交代一下测试云主机 cpu: root@alexknight:/tmp/webbench-1.5# cat /proc/cpuinfo |grep model model : model n ...
- Django Linux环境下部署CentOS7+Python3+Django+uWSGI+Nginx(含Nginx返回400问题处理、防火墙管理)
本文将介绍如何在Linux系统上部署Django web项目,本次部署基于下面的架构: CentOS7+ Python3.5 + Django1.11 + uWSGI + Nginx 亲测可行!!按照 ...
- 使用 Nginx 和 Gunicorn 部署 Django 博客(转)
原文:http://zmrenwu.com/post/20/ http://www.siar.me/post/9/ 针对很多朋友反映按照教程的做法始终只能看到 Nginx 欢迎页面的问题,Tian ...
- Django + Gunicorn + Nginx 部署 Ubuntu 服务器
Django + Gunicorn + Nginx 部署服务器 获取腾讯云 root权限 本人的服务器使用的是腾讯云,腾讯云默认是没有开放 root 用户的,我们来创建 root 用户. 创建 roo ...
随机推荐
- 双系统正确卸载Ubuntu系统
双系统正确卸载Ubuntu系统 安装系统后由于显卡驱动问题,无法开机,从而只能卸载重装,重装过程如下. 第一步:下载需要的工具包,这里我用的是MBRfix, 可以直接从我分享的网盘链接下载,密码gw ...
- 浅谈spring配置定时任务的几种方式
网上看到好多关于定时任务的讲解,以前只简单使用过注解方式,今天项目中看到基于配置的方式实现定时任务,自己做个总结,作为备忘录吧. 基于注解方式的定时任务 首先spring-mvc.xml的配置文件中添 ...
- poj1284(欧拉函数+原根)
题目链接:https://vjudge.net/problem/POJ-1284 题意:给定奇素数p,求x的个数,x为满足{(xi mod p)|1<=i<=p-1}={1,2,...,p ...
- [转帖]SUN/Oracle JDK还是OpenJDK?
你安装的是 https://www.cnblogs.com/shoufeng/p/9719995.html 目录 1 如何查看你安装的JDK版本 1.1 要用到的命令行工具 1.2 查看JDK的版本 ...
- linux DTS介绍
一. 设备树的由来 1.1. 什么是设备树 1.1.1. Device Tree 可以描述的信息包括CPU的数量和类别,内存基地址和大小,总线和桥,外设连接,中断控制器和中断使用情况,Clock控制器 ...
- 解决 Intellij IDEA Cannot Resolve Symbol ‘BASE Decoder’ 问题
最近接盘了用springboot框架搭建的后台,第一次接触java的我就遇上了bug: 因为jdk更新而导致Cannot Resolve Symbol ‘BASE Decoder’ 问题 看了很多网上 ...
- rebtree学习
http://www.cnblogs.com/skywang12345/p/3245399.html http://www.cnblogs.com/skywang12345/p/3624177.htm ...
- Bug快到碗里来
Bug快到碗里来 python错误--'list' object is not callable 原因及解决方法1 你定义了一个变量的变量名和系统自带的关键字冲突,调用变量时关键字被传到调用的位置,就 ...
- 搜索专题:问题 E: 挑战ACM迷宫
这是往年校赛的一道题,最开始做这道题的时候还没有系统的学习过搜索,用了C语言学的回溯法尝试,毫无疑问的TLE: 学习了DFS之后,自己的剪枝功力不够,又是TLE,最后学了BFS之后,哇,终于做出来了, ...
- vue video.js使用
插件github地址:https://github.com/videojs/video.js 这边做一个切换视频vue url的解决记录 this.$nextTick(() => { let u ...