Nginx概述

Nginx是一款轻量级的HTTP服务器,采用事件驱动和异步非阻塞处理方式框架,这让其具有极好的IO性能,市场用于服务端的反向代理和负载均衡

Nginx优点

  • 高并发连接:官方测试Nginx能够支撑5万并发连接,实际生产环境中更可以支撑2~4万并发连接数。

  • 内存消耗少:在主流的服务器中Nginx目前是内存消耗最小

  • 免费使用可以商业化:开源

  • 配置文件简单:网络和程序配置通俗易懂

环境搭建

Ubuntu下载nginx配置(下载最新版nginx)

http://nginx.org/en/linux_packages.html#stable (nginx官网)

  • 对于Ubuntu,请将以下内容追加到/etc/apt/source.list文件的末尾

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

codename为Ubuntu版本

Version codename Supported Platforms
16.04 xenial x86_64, i386, ppc64el, aarch64/arm64
17.10 artful x86_64, i386
18.04 bionic x86_64
  • 下载nginx

apt-get update
apt-get install nginx 推荐:http://nginx.org/en/download.html 选择Stable version稳定版下载
  • 下载所需密钥,在/etc/apt目录下

wget http://nginx.org/keys/nginx_signing.key
sudo apt-key add nginx_signing.key
  • 在同级目录下解压安装其他扩展库,然后配置,编译安装:

    pcre,用于解析正则

    https://nchc.dl.sourceforge.net/project/pcre/pcre/8.42/pcre-8.42.tar.gz

    zlib,用于压缩文件

    http://www.zlib.net/zlib-1.2.11.tar.gz

    openssl,用于支持https协议(这个是github的源码,在他releases已发布版本中找一个旧一点的版本如1.01右键复制链接)

    https://github.com/openssl/openssl

    进入nginx目录,进行编译配置

    ./configure 
    --prefix=/usr/local/nginx
    --with-http_ssl_module
    --with-http_flv_module
    --with-http_stub_status_module
    --with-http_gzip_static_module
    --with-pcre=../pcre-8.42
    --with-zlib=../zlib-1.2.
    --with-openssl=../openssl-OpenSSL_1_0_1r

    安装

    make && sudo make install

    打开浏览器访问此机器的 IP,如果浏览器出现 Welcome to nginx! 则表示 Nginx 已经安装并运行成功

    sudo /usr/local/nginx/sbin/nginx

nginx命令

sudu apt-get update
# 更新

sudo apt-get install nginx
# 下载
sudo apt-get remove nginx nginx-common
# 卸载删除除了配置文件以外的所有文件。

sudo apt-get purge nginx nginx-common
# 卸载所有东东,包括删除配置文件。

sudo apt-get autoremove
# 在上面命令结束后执行,主要是卸载删除Nginx的不再被使用的依赖包。

sudo apt-get remove nginx-full nginx-common
#卸载删除两个主要的包。
nginx -V
# 查看版本 .14稳定版
nginx
# 运行
killall nginx
# 终止运行

此时浏览器打开 服务器公网ip 可以看到nginx欢迎页面

uwsgi概述

web服务器和web框架

web服务器是用来接收客户端请求,建立连接,转发响应的程序 web框架是处理业务逻辑 举例: web服务器:nginx web框架:flask

uWSGI和WSGI

WSGI:通信协议 uWSGI:属于WSGI协议的web服务器(nginx、nginx都是web服务器)

为什么需要nginx+uWSGI

利用nginx可以实现反向代理的能力,可以实现分布式服务器功能可以解决网络访问量过大的问题。

安装 pip

一般默认Ubuntu服务器自带python3.5但是却没有自带pip

sudo apt-get install python3-pip

安装 uwsgi

pip3 install uwsgi

Django自带wsgi为什么不直接使用,Django自带wsgi只是为了开发使用的是单进程的,不适合上线使用。

在项目根目录(manage.py同目录)下创建 uwsgi.ini 文件

uwsgi官网

[uwsgi]
socket = 127.0.0.1:
chdir = /home/foobar/myproject/
wsgi-file = myproject/wsgi.py
processes =
threads =
stats = 127.0.0.1:

在etc/nginx/conf.d/default.conf 配置nginx

将其中如下代码注释

#location / {
# root /usr/share/nginx/html;
# index index.html index.htm;
#}

替换为

location / {
include uwsgi_params;
uwsgi_pass 127.0.0.1:;
}
运行Django程序
  • 检查项目异常

python3 manage.py runserver
  • 下载项目所依赖包裹

  • 安装数据库

sudo apt-get install mysql-server
#期间设置数据库密码
DEBUG = FALSE
ALLOWED_HOSTS = ['*']
+ static(settings.MEDIA_URL, document_root=settings.MEDIA_ROOT)

数据库常用命令

mysql -u root -p
# 登录数据库
show databases;
# 查看数据库
CREATE DATABASE db_name DEFAULT CHARACTER SET utf8 COLLATE utf8_general_ci;
# 创建数据库
quit;
# 退出数据库

执行迁移

python manage.py migrate

uwsgi运行

uwsgi uwsgi.ini

到此服务器部署成功,接下来就是设置静态文件了。

设置静态文件

因为此时服务器路由统一由nginx管理,所以我们需要进行配置nginx,etc/nginx/conf.d/default.conf

location  /static {
autoindex on;
alias /home/ydh/<项目根目录>/static;
}

将项目中的文件同一管理

  • 在项目settion.py中设置STATIC_ROOT 静态文件根目录

STATIC_ROOT = os.path.join(BASE_DIR,'static')
  • 在项目根目录创建 static

  • 执行命令

python3 manage.py collectstatic
# 将静态文件收集到STATIC_ROOT

重启nginx

ubuntu16.4+nginx+uwsgi+Django 部署上线的更多相关文章

  1. Nginx+uWSGI+Django部署web服务器

    目录 Nginx+uWSGI+Django部署web服务器 环境说明 前言 搭建项目 Django部署 编辑luffy/luffy/settings.py 编辑luffy/app01/views.py ...

  2. nginx+uwsgi+django 部署原理

    python开发群里经常有同学问 nginx+uwsgi+django 着了教程部署,但是不知道他们之间怎么样的关系,于是我就google到了一个让我看起来很认同的图,大家看了也比较认同,于是就分享出 ...

  3. nginx+uwsgi+django部署流程

    当我们在用django开发的web项目时,开发测试过程中用到的是django自带的测试服务器,由于其安全及稳定等性能方面的局限性,django官方并不建议将测试服务器用在实际生产. nginx+uws ...

  4. 10、nginx+uwsgi+django部署(动静分离)

    10.1.说明: 1.介绍: 创建Django项目,可以通过 pyhon3 manage.py runserver 0.0.0.0:8080 & 命令更方便地调试程序,但是如果当一个项目完成了 ...

  5. 在ubuntu16上进行nginx+uwsgi+django部署的简要步骤

    网上有很多部署教程,说了一大堆,遇到坑还是要自己一个个解决,这里有几个比较重要的坑大家一定要注意. 1.首先要安装python和python-dev环境,如果没有安装python-dev后面安装有些依 ...

  6. Ubuntu-18.04.2系统 Nginx+uWSGI+Django 部署生产环境

    首先准备环境: 1.使用虚拟机 VMware Workstation Pro (也可以不用),安装Ubuntu-18.04.2系统 开始搭建环境 (因为ubuntu18.4.2集成了python3.6 ...

  7. ubantu+nginx+uwsgi+django部署

    1.更新ubantu的apt apt-get update 必要时候更新系统:      apt-get upgrade 2.远程连接服务器 ssh 用户名@ip 上传代码 :        scp ...

  8. 使用docker-compose+nginx+uwsgi+django部署项目

    (1)centos上下载docker + docker-compose (2)基础目录 (3)首先创建一个纯净的python+django+uwsgi的镜像,便于后期使用(也可不用创建,后期docke ...

  9. Nginx+uwsgi+django部署项目

    nginx把请求转发给uwsgi,然后把uwsgi处理得到的结果返回给浏览器. 安装nginx: yum -y install gcc pcre-devel openssl-devel #安装Ngin ...

随机推荐

  1. 利用Knockoutjs对电话号码进行验证

    问题来源 最近在项目中前端使用Knockoutjs,验证模块自然也是使用Knockoutjs来进行表单验证了,比较头痛,因为没有使用过Knockoutjs,更加别说要去用它做表单验证了,于是乎恶补了一 ...

  2. 修改ssh远程默认端口

    修改ssh远程默认端口 Linuxssh端口修改 1. 修改ssh配置文件 [root@distzabbix ~]# vim /etc/ssh/sshd_config 找到第17行附近#Port 22 ...

  3. mybatis四大接口之 StatementHandler

    1. 继承结构 StatementHandler:顶层接口 BaseStatementHandler : 实现顶层接口的抽象类,实现了部分接口,并定义了一个抽象方法 SimpleStatementHa ...

  4. D14——C语言基础学PYTHON

    C语言基础学习PYTHON——基础学习D14 20180919内容纲要: 1.html认识 2.常用标签 3.京东html 4.小结 5.练习(简易淘宝html) 1.html初识(HyperText ...

  5. 机器学习与Tensorflow(3)—— 机器学习及MNIST数据集分类优化

    一.二次代价函数 1. 形式: 其中,C为代价函数,X表示样本,Y表示实际值,a表示输出值,n为样本总数 2. 利用梯度下降法调整权值参数大小,推导过程如下图所示: 根据结果可得,权重w和偏置b的梯度 ...

  6. Django 模板相关

    Django 模板相关 视图函数只是直接返回文本,而在实际生产环境中其实很少这样用,因为实际的页面大多是带有样式的HTML代码,这可以让浏览器渲染出非常漂亮的页面.目前市面上有非常多的模板系统,其中最 ...

  7. (转)CentOS7安装Nginx1.14.2

    原文:https://blog.csdn.net/zhyfyz/article/details/84957381 https://blog.csdn.net/q85795362/article/det ...

  8. C# 多线程九之Timer类

    1.简介 相信写过定时任务的小伙伴都知道这个类,非常的轻量级,而且FCL中大量的类使用了这个方法,比如CancellationTokenSource的CancelAfter就是用Timer去做的. 当 ...

  9. SVM(支持向量机)简介与基础理解

    SVM(支持向量机)主要用于分类问题,主要的应用场景有字符识别.面部识别.行人检测.文本分类等领域.原文地址:https://zhuanlan.zhihu.com/p/21932911?refer=b ...

  10. JavaScript -- Screen

    -----041-Screen.html----- <!DOCTYPE html> <html> <head> <meta http-equiv=" ...