这里我们采用动静分离的方式来部署美多商城项目。

动态请求:采用uwsgi与Django进行通信处理动态业务。

静态请求:采用Ngins通过socket与uwsgi进行通信处理静态业务。

第一步:实现uwsgi与Django通信。

1.在Django程序中,项目根路径创建uwsgi.ini文件,用来编写配置文件。

[uwsgi]
# 使用Nginx连接时使用,Django程序所在服务器地址
# socket=192.168.0.105:8001
# 直接做web服务器使用,Django程序所在服务器地址
http=192.168.0.105:8001
# 项目目录
chdir=/home/python/Desktop/meiduo_rest/meiduo_mall
# 项目中wsgi.py文件的目录,相对于项目目录
wsgi-file=meiduo_mall/wsgi.py
# 进程数
processes=4
# 线程数
threads=2
# uwsgi服务器的角色
master=True
# 存放进程编号的文件
pidfile=uwsgi.pid
# 日志文件
daemonize=uwsgi.log
# 指定依赖的虚拟环境
virtualenv=/home/python/.virtualenvs/Py3_Django1.11

2. 启动uwsgi

uwsgi:遵循wsgi协议的程序,需要使用http协议进行通信。

# 启动
uwsgi --ini uwsgi.ini # 停止
uwsgi --stop uwsgi.pid

日志文件中出现以下信息即为启动成功。

3. 测试uwsgi是否能够和Django程序进行通信。

利用浏览器向配置文件中的HTTP属性信息发送请求即可。

通过浏览器发送请求,能够获取到响应则表示uwsgi和Django程序能够正常进行通信了。

接来下,就是实现Nginx和uwsgi之间的通信。

1. 修改uwsgi配置文件。

将uwsgi中的配置属性HTTP注释掉,启用socket属性。

[uwsgi]
# 使用Nginx连接时使用,Django程序所在服务器地址
socket=192.168.0.105:8001
# 直接做web服务器使用,Django程序所在服务器地址
# http=192.168.0.105:8001
# 项目目录
chdir=/home/python/Desktop/meiduo_rest/meiduo_mall
# 项目中wsgi.py文件的目录,相对于项目目录
wsgi-file=meiduo_mall/wsgi.py
# 进程数
processes=4
# 线程数
threads=2
# uwsgi服务器的角色
master=True
# 存放进程编号的文件
pidfile=uwsgi.pid
# 日志文件
daemonize=uwsgi.log
# 指定依赖的虚拟环境
virtualenv=/home/python/.virtualenvs/Py3_Django1.11

2. 配置Nginx

通过编写Nginx的配置文件,实现Nginx与uwsgi进行通信。

# 跳转到配置文件目录
cd /etc/nginx/sites-enabled/ # 创建一个配置文件
sudo vim meiduo

编写配置文件代码:

upstream meiduo {
server 192.168.0.105:8001;
} server{
server_name www.meiduo.site;
listen 80;
location / {
# 导入uwsgi使用的变量
include uwsgi_params;
# 通过负载均衡设置uwsgi
uwsgi_pass meiduo;
}

测试并重新加载Nginx配置信息。

# 测试
sudo nginx -t # 重新加载
sudo nginx -s reload

3. 通过浏览器测试,是否能够使用Nginx实现部署。

通过以上步骤,已经初步实现了美多商城项目动态请求的部署。

美多商城部署进阶部分:静态请求部署

1. 实现主页静态文件请求

修改Nginx配置文件,即可实现。

upstream meiduo {
server 192.168.0.105:8001;
} server{
server_name www.meiduo.site;
listen 80;
location / {
include uwsgi_params;
uwsgi_pass meiduo;
}
location /static {
alias /home/python/Desktop/meiduo_rest/meiduo_mall/static/;
}
}

2. 实现商品详情页面静态化

upstream meiduo {
server 192.168.0.105:8001;
} server{
server_name www.meiduo.site;
listen 80;
location / {
include uwsgi_params;
uwsgi_pass meiduo;
}
# 主页静态文件:css、js等
location /static {
alias /home/python/Desktop/meiduo_rest/meiduo_mall/static/;
}
# 详情页面
location /detail {
alias /home/python/Desktop/meiduo_rest/meiduo_mall/static/detail/;
}
}

3. 实现主页静态化

upstream meiduo {
server 192.168.0.105:8001;
} server{
server_name www.meiduo.site;
listen 80;
location / {
include uwsgi_params;
uwsgi_pass meiduo;
}
# 首页路由
location = /{
root /home/python/Desktop/meiduo_rest/meiduo_mall/static;
index index.html;
}
# 首页静态化
location = /index.html{
root /home/python/Desktop/meiduo_rest/meiduo_mall/static;
index index.html;
}
# 主页静态文件:css、js等
location /static {
alias /home/python/Desktop/meiduo_rest/meiduo_mall/static/;
}
# 详情页面
location /detail {
alias /home/python/Desktop/meiduo_rest/meiduo_mall/static/detail/;
}
}

首页静态化配置,可以理解为当用户在浏览器输入www.meiduo.site时,浏览器会自动在url后拼接一个/,

Nginx进行路由匹配后,会将http://www.meiduo.site/地址,修改成http://www.meiduo.site/index.html地址并进行请求。

Nginx之美多商城前台部署的更多相关文章

  1. JAVAWEB贵美网上商城完整项目源码(SSH2)

    JAVAWEB贵美网上商城完整项目源码(SSH2) 贵美网上商城原是北大青鸟的一个内部项目,项目采用 struts2+spring4+hibernate4+MySQL等技术实现,数据库连接池采用c3p ...

  2. 刚写完的商城erp + 这个商城前台,新鲜出炉。自己1个人写, 包括php框架和前端html页面.

    刚写完的商城erp + 这个商城前台,新鲜出炉.自己1个人写, 包括php框架和前端html页面. 刚写完的商城erp + 这个商城前台,新鲜出炉.自己1个人写, 包括php框架和前端html页面.

  3. Nginx+Tomcat+Memcached 实现集群部署时Session共享

    Nginx+Tomcat+Memcached 实现集群部署时Session共享 一.简介 我们系统经常要保存用户登录信息,有Cookie和Session机制,Cookie客户端保存用户信息,Sessi ...

  4. Nginx 和 PHP 的两种部署方式比较

    2种部署方式简介 第一种 前置1台nginx服务器做HTTP反向代理和负载均衡 后面多态服务器部署Nginx Web服务和php-fpm提供的fast cgi服务 第二种 前置1台nginx服务器做W ...

  5. [转]Nginx反向代理和负载均衡部署指南

    Nginx反向代理和负载均衡部署指南   1.        安装 1)         从Nginx官网下载页面(http://nginx.org/en/download.html)下载Nginx最 ...

  6. (Nginx+PHP+MySQL)单机+Redis部署

    链接:Nginx+PHP+MySQL+Redis多机部署 1.lnmp+redis工作机制 2.lnmp+redis操作步骤(lnmp为单机部署) (1)lnmp+redis实战环境 lnmp服务器: ...

  7. django+uWSGI+nginx的工作原理流程与部署过程

    django+uWSGI+nginx的工作原理流程与部署过程 一.前言 知识的分享,不应该只是展示出来,还应该解释这样做是为什么... 献给和我一样懵懂中不断汲取知识,进步的人们. 授人与鱼,不如授人 ...

  8. 美多商城后台MIS系统部署之Nginx配置

    先进入Nginx的配置文件中,进行配置. Nginx配置文件夹的区别: cd /etc/nginx/conf.d/   创建.conf后缀的文件 /etc/nginx/sites-enabled  创 ...

  9. Nginx反向代理和负载均衡部署指南

    1.        安装 1)         从Nginx官网下载页面(http://nginx.org/en/download.html)下载Nginx最新版本(目前是1.5.13版本)安装包: ...

随机推荐

  1. AI——第四次工业革命

    历史上发生了三次工业革命:第一次是以蒸汽机的发明为代表,改变了长久以来的棉纺织业,人类进入"蒸汽时代":第二次是以汽车的发明和电学的发展为代表,人类的活动范围和时长都极大地扩展,人 ...

  2. Unity3d游戏角色描边

    本文发布于游戏程序员刘宇的个人博客,欢迎转载,请注明来源https://www.cnblogs.com/xiaohutu/p/10834491.html 游戏里经常需要在角色上做描边,这里总结一下平时 ...

  3. c# 一维数组和二维数组的几种定义方式<转>

    using System; using System.Collections.Generic; using System.Linq; using System.Text; namespace Cons ...

  4. Dynamics 365 CRM 在 Connected Field Service 中部署 IoT Central (三)- 发送 work order 和 booking 信息给 IoT Central

    首先, 我们可以打开IoT alert, 并且点击上的 create a flow. 接下来,我们使用微软准备好的模板:Sample Contoso- When a work order is cre ...

  5. 使用requests模块的网络编程

    python操作网络,也就是打开一个网站,或者请求一个http接口,本篇是介绍使用request模块的使用方式. 在使用requests模块之前需要先安装,在cmd中输入:pip install re ...

  6. Ubuntu 获取 root 用户权限并以 root权限登录

    操作步骤: 1.打开终端,使用 sudo passwd root 命令进行 Ubuntu 中密码的重置        2.切换到 /usr/share/lightdm/lightdm.conf.d 目 ...

  7. chrome 安装

    Centos7 yum安装chrome浏览器   跟着这个教程安装的:Centos7安装chrome浏览器 (点击) 1. 配置yum源 在目录 /etc/yum.repos.d/ 下新建文件 goo ...

  8. k8s概述

    k8s概述 概述 Kubernetes 使你在数以千计的电脑节点上运行软件时就像所有这些节点是单个大节点一样.它将底层基础设施抽象,这样做同时简化了应用的开发.部署, 以及对开发和运维团队的管理. K ...

  9. vscode打开文件,中文显示乱码(已解决)

    之前使用vscode打开keil的文件后,发现显示乱码,网上查找资料发现大多是这种方法:将files.autoGuessEncoding改为true,但是并没有用. 发现第二种方法为:在vscode中 ...

  10. Azure 认知服务概述

    背景知识 近些年随着机器学习.深度学习等技术的不断发展,人工智能在越来越多的场景得到了应用,如人脸识别.图像识别.语音识别.语音生成.自然语言处理.决策分析等等,让机器拥有了听.说.看和思考的能力,很 ...