一、首先先安装nginx静态服务

1.安装gcc g++的依赖库
sudo apt-get install build-essential && sudo apt-get install libtool

2.安装pcre依赖库
sudo apt-get install libpcre3 libpcre3-dev

3.安装zlib依赖库
sudo apt-get install zlib1g-dev

4.安装ssl依赖库
sudo apt-get install openssl

安装nginx

# 下载
sudo wget http://nginx.org/download/nginx-1.11.3.tar.gz

# 解压
sudo tar -zxvf nginx-1.11.3.tar.gz

# 在 /usr/local/ 目录下创建nginx目录,然后把解压好的放到 /usr/local/nginx 下
sudo mkdir nginx
sudo mv nginx-1.11.3 /usr/local/nginx

# 编译nginx
cd /usr/local/nginx/nginx-1.11.3
#配置:
sudo ./configure
#编译
sudo make

在编译步骤出现如下错误:

解决办法

找到对应的Maakefile文件,将gcc参数中的-Werror去掉。

我上面显示的是objs/Makefile文件,我打开看了下,将第三行的-Werror去掉就可以

修改保存之后重新运行sudo make进行编译

#安装nginx:
sudo make install
#启动nginx:

cd /usr/local/nginx

sudo sbin/nginx

#关闭nginx命令:

sudo sbin/nginx -s stop

ps aux|grep nginx 查看nginx进程状态


配置nginx

cd /usr/local/nginx/conf/

使用vim或gedit编辑器在该目录下新建一个ihasy.conf文件输入以下内容:

upstream ihasy  {
server 127.0.0.1:9001; #Tornado
} ## Start www.ihasy.com ##
server {
listen 80;
server_name www.ihasy.com ihasy.com; #root html;
#index index.html index.htm index.py index; ## send request back to Tornado ##
location / {
proxy_pass http://ihasy; #Proxy Settings
proxy_redirect off;
proxy_set_header Host $host;
proxy_set_header X-Real-IP $remote_addr;
proxy_set_header X-Forwarded-For $proxy_add_x_forwarded_for;
proxy_next_upstream error timeout invalid_header http_500 http_502 http_503 http_504;
proxy_max_temp_file_size 0;
proxy_connect_timeout 90;
proxy_send_timeout 90;
proxy_read_timeout 90;
proxy_buffer_size 4k;
proxy_buffers 4 32k;
proxy_busy_buffers_size 64k;
proxy_temp_file_write_size 64k;
}
}
## End www.ihasy.com ##

再使用vim或gedit打开 /usr/local/nginx/conf/nginx.conf

sudo gedit /usr/local/nginx/conf/nginx.conf

在http下添加一行

include ihasy.conf

保存,重启nginx,即可实现反向代理。

之后 再重新编辑/usr/local/nginx/conf/nginx.conf文件 配置项目前后端

# 动态url设置地址设置
server {
listen 8000;
# 只是给ip取个名字,也可以用ip:port的方式
# server_name 127.0.0.1;

location / {
uwsgi_pass 127.0.0.1:3309;
include uwsgi_params;
}

}

# 静态文件地址设置
server {
listen 80;
# 只是给ip取个名字,也可以用ip:port的方式
server_name 127.0.0.1;
#charset koi8-r;

#access_log logs/host.access.log main;

location / {
root /home/zx/Desktop/meiduo_mall/front_end_pc;
index index.html index.htm;
}

}

保存退出之后需要在项目配置文件中添加生成前端静态文件:

将  DEBUG = True  改为 DEBUG = False

然后添加

STATIC_ROOT = os.path.join(os.path.dirname(os.path.dirname(BASE_DIR)),'front_end/static')

然后在项目下运行命令

python manage.py collectstatic

生成静态文件。

这样再启动nginx服务,前端页面就可以运行成功。

二 、接下来配置动态后端服务:

在python环境下 直接 pip install uwsgi

在后端项目目录下新建  uwsgi.ini文件

配置uwsgi.ini文件如下:

[uwsgi]

#使用nginx连接时使用,Django程序所在服务器地址

socket=127.0.0.1:3309

#直接做web服务器使用,Django程序所在服务器地址

#http=127.0.0.1:8000

#项目目录

chdir=/home/python/Desktop/meiduo/meiduo_mall

#项目中wsgi.py文件的目录,相对于项目目录

wsgi-file=meiduo_mall/wsgi.py

# 进程数

processes=4

# 线程数

threads=2

# uwsgi服务器的角色

master=True

# 存放进程编号的文件

pidfile=uwsgi.pid

# 日志文件,因为uwsgi可以脱离终端在后台运行,日志看不见。我们以前的runserver是依赖终端的

daemonize=uwsgi.log

# 指定依赖的虚拟环境

virtualenv=/home/python/.virtualenvs/xxx(虚拟环境名称)

没有虚拟环境的可以删除最后两行,这样后端配置文件写好之后,启动uwsgi服务

uwsgi --ini uwsgi.ini

关闭命令   uwsgi --stop uwsgi.pid

到此,一个简单的Django项目部署就完成了!!!

Ubuntu18.04或者Deepin15.8 部署Django项目的更多相关文章

  1. ubuntu18+uwsgi+nginx部署django项目

    更新系统软件源 sudo apt-get update pip3安装 sudo apt install python3-pip 安装virtualenvwrapper pip3 install vir ...

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

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

  3. k8s-生产环境部署django项目k8s-dashboard管理系统

    1. k8s-生产环境部署django项目k8s-dashboard管理系统 gitee地址: https://gitee.com/scajy/django-k8s-dashboard.git 部署架 ...

  4. 打造专属测试平台4-使用Docker部署Django项目

    编写完项目代码后,为了稳定的运行,需要将其部署至服务器.这里我选择了Docker去部署Django后端代码. 首先来看看Runoob对Docker的介绍: Docker 是一个开源的应用容器引擎,基于 ...

  5. mac osx 上面部署Django项目 apache+mysql+mod_wsgi

    1.安装Xcode command line tools 首先,编译mysql和Homebrew需要用到Xcode command line tools,所以首先安装command line tool ...

  6. 使用uWSGI+nginx部署Django项目

    最近使用django写了一些项目,不过部署到服务器上碰到一些问题,还有静态文件什么的一堆问题,这里总结一下碰到的问题和解决方案,总体思路是按照官方文档走的. 原文地址:http://uwsgi-doc ...

  7. Docker 部署Django项目

    使用docker部署django项目也很简单,挺不错,分享下 环境 默认你已安装好docker环境 django项目大概结构 (p3s) [root@opsweb]# tree opsweb opsw ...

  8. CentOS 6.8 部署django项目二

    CentOS 6.8 部署django项目一 1.项目部署后发现部分页面的样式丢失,是因为在nginx中配置的static路径中未包含. 解决:在settinfs.py中添加: STATIC_ROOT ...

  9. CentOS 6.8 部署django项目一

    CentOS 6.8 部署django项目二 1.安装python3.5(默认是2.6) 参考:http://blog.csdn.net/shaobingj126/article/details/50 ...

随机推荐

  1. Div+CSS+JQuery实现选项卡,即通过点击不同的li跳转到不同的div中显示不同的内容或者执行不同的操作。

    1.代码 <!DOCTYPE HTML PUBLIC "-//W3C//DTD HTML 4.01 Transitional//EN"> <html>   ...

  2. vuex中store保存的数据,刷新页面会清空

    用vuex,项目中需要记录一些状态,来判断页面是否为登录状态和页面是否可被编辑,此时用到了vuex中的store来存储一个状态. //首先 安装vuex npm install vuex --save ...

  3. 为什么text的值改变后onchange没有反应?

    onchange发生在元素失去焦点后,而不是想象中的元素的值发生改变的时候.其实它的作用就跟onblur(失去焦点事件)差不多,只不过onchange是失去焦点且值发生了改变.要想实现目的,可以改用o ...

  4. CSRedisCore 在net core中的使用

    背景:与net core配套的StackExchange.Redis客户端总是间歇性的发生timeout异常. 由complexer单例对象创建的IDatabase对象,在产生Timeout异常后会导 ...

  5. css3(display)

    实现下拉 <!DOCTYPE html><html><head> <meta charset="utf-8"> <style ...

  6. UI行业发展预测 & 系列规划的调整

    又双叒叕拖更了,上一篇还是1月22号更新的,这都3月9号了…… 前面几期把职业规划.能力分析.几个分析用的设计理论都写完了,当然实际工作中用到的方法论不止上面这些,后续会接着学习: 如果你的目标是一线 ...

  7. 【第一次作业】&&软件工程大一班---甘昀

    这个作业属于哪个课程: <课程的链接点这里>  这个作业要求在哪里: <作业要求的链接点这里> 我在这个课程的目标是:  学会软件开发的流程和思想 这个作业在哪个具体方面帮助我 ...

  8. 第二阶段第十次spring会议

    昨天我对宠物信息进行了添加和调整. 今天我将继续对宠物信息添加保存按钮. private void button2_Click(object sender, EventArgs e) { Settin ...

  9. Python建立时间事件引擎原理剖析

    作为python小白,学习量化交易的曲线是非常陡峭的,唯一好的办法就是一点点啃代码.以下代码案例来自vnpy的引擎代码. # encoding: UTF-8 #定义时间事件 EVENT_TIMER = ...

  10. 分享一个mac for redis-desktop-manager破解版安装包

    链接: https://pan.baidu.com/s/1BDndGmBlWoSr4hVLpF3FVw  提取码: wwir