重要概念 什么是web容器 Linux下安装部署njinx+uwsgi+django+vue

一些重要概念

  1. https://www.cnblogs.com/xiaonq/p/8932266.html

  2. web容器

    • 什么是web容器

      • 1.web容器是帮助我们部署java、php、python、vue等项目的
    • 作用(处理请求,返回数据)

    • 第一,帮助django服务端处理客户端连接,官方号称可以处理10万(实现高并发)

    • 第二,帮助处理静态资源请求(html、css、JS),返回给客户端浏览器(django等web服务 器处理静态资源能力差)

    • 常见web容器

      • 1.nginx(python、php)
        • LNMP
          • L:LInux
          • N:Nginx
          • M:MySQL
          • P: php
      • 2.apache(PHP)
        • LAMP
          • L:LInux
          • A:Apache
          • M:MySQL
          • P: php
      • 3.Tomcat(JAVE)
  3. 什么是WSGI(web协议)

    • WSGI是一种 python专用 的web协议 和http类似

    • WSGI实质:WSGI是一种描述web服务器(如 nginx,uWSGI web服务器 )如何与 web框架 (如用 Django、Flask框架写的程序)通信的规范、协议

    • WSGI定义了使用 python编写的web app(django)与web server(uWSGI)之间接口格式

    • 为什么需要web协议:

      • 1)不同的框架有不同的开发方式,但是无论如何,开发出的 应用程序(django)都要和服务器 (nginx)程序配合 ,才能为用户提供服务。
      • 2) 这样, 服务器程序(nginx) 就需要为不同的框架提供不同的支持,只有支持它的服务器才 能被开发出的应用使用,显然这是不可行的。
      • 3)web协议本质:就是定义了 Web服务器和Web应用程序或框架之间的一种简单而通用的接口规 范 。
  4. uWSGI (web服务器 和nginx类似)

    • 什么是uWSGI: uWSGI是一个全功能的HTTP服务器,实现了 WSGI协议 、 uwsgi协议 、 http协议 等。
    • uWSGI作用:它要做的就是把HTTP协议转化成语言支持的网络协议,比如把 HTTP协议转化成WSGI 协议,让Python可以直接使用 。
    • uWSGI特点:轻量级,易部署,性能比nginx差很多,支持多种协议
  5. Nginx

    • Django是一个Web框架,框架的作用在于处理request和 reponse,其他的不是框架所关心的内容。
    • 所以如何部署Django不是Django所需要关心的。
  6. nginx+uwsgi+django部署各模块作用

    1. ![QQ截图20201113195639](C:UserswyxDesktop小实训day15 web容器 nginx+uwsgi+django部署图片QQ截图20201113195639.png)

    2. Django + Uwsgi + Nginx方案

      1. ![image-20201113195804044](C:UserswyxDesktop小实训day15 web容器 nginx+uwsgi+django部署图片image-20201113195804044.png)

      2. 请求处理整体流程
        1. nginx接收到浏览器发送过来的http请求,将包进行解析,分析url
          • 静态文件请求: 就直接访问用户给nginx配置的静态文件目录 (html/css/js/图片) , 直接返回用户请求的静态文件
        2. 动态接口请求: 那么nginx就将请求转发给uWSGI,最后到达django处理
      3. 各模块作用
        • nginx :是对外的服务器,外部浏览器通过url访问nginx,nginx主要处理静态请求 (html/css/js/图片)
          • uWSGI :是对内的服务器,主要用来 处理动态请求 。(从mysql、redis、es等中动态查询到的 数据)
          • uwsgi :是一种web协议,接收到请求之后将包进行处理,处理成wsgi可以接受的格式,并 发给wsgi
          • wsgi :是python专用的web协议,根据请求调用应用程序(django)的某个文件,某个文件 的某个函数
          • django :是真正干活的,查询数据等资源,把处理的结果再次返回给WSGI, WSGI 将返回值 进行打包,打包成uwsgi能够接收的格式
        • uwsgi :接收wsgi发送的请求,并转发给nginx,nginx最终将返回值返回给浏览器
      4. Django + uWSGI方案特点
        • 没有nginx而只有uwsgi的服务器,则是Internet请求直接由uwsgi处理,并反馈到web项目中。
        • nginx可以实现安全过滤,防DDOS等保护安全的操作,并且如果配置了多台服务器,nginx可以保 证服务器的负载相对均衡。
        • 而uwsgi则是一个web服务器,实现了WSGI协议(Web Server Gateway Interface),http协议等,它可以 接收和处理请求,发出响应等。 所以只用uwsgi也是可以的。
      5. nginx和uWSGI特点
        1. nginx的作用
          • 反向代理,可以拦截一些web攻击,保护后端的web服务器
          • 负载均衡,根据轮询算法,分配请求到多节点web服务器
          • 缓存静态资源,加快访问速度,释放web服务器的内存占用,专项专用
          • ![image-20201113201941440](C:UserswyxDesktop小实训day15 web容器 nginx+uwsgi+django部署图片image-20201113201941440.png)
        2. uWSGI的适用
          • 单节点服务器的简易部署
          • 轻量级,好部署zz

配置Uwsgi+Nginx+Django+Vue

  1. .django的settings配置

    1. 这里可以先不必配置

      # 1.修改配置
      # 正式上线关闭调试模式, 不会暴露服务器信息
      DEBUG = False
      # 2.允许的主机
      ALLOWED_HOSTS = ['xxx.com','127.0.0.1']
      
    2. # 3.前端修改接口地址(vue)
      http://192.168.56.100:8888/ => http://xxx.com/
      # 4.MySQL数据库根据实际情况配置(注意地址)
      # 5.缓存配置, 改为默认, 最简单形式(配置redis)
      # 6.收集静态文件
      # 静态资源收集位置
      STATIC_ROOT = os.path.join(BASE_DIR, 'static')
      # 7.命令行执行
      python manage.py collectstatic
      
  2. 安装uwsgi 配置uWSGI

    1. 安装uwsgi 在终端窗口

    2. '''1. 安装uwsgi'''
      [root@linux-node1 /]# workon syl
      [root@linux-node1 /]# pip3 install uwsgi # 安装uwsgi
      [root@linux-node1 /]# whereis uwsgi # 查看uwsgi安装路径
      uwsgi: /root/.virtualenvs/syl/bin/uwsgi
      
    3. 配置uwgsi.ini启动文件

      1. 可以直接在项目中配置

      2. ![image-20201113212314347](C:UserswyxDesktop小实训day15 web容器 nginx+uwsgi+django部署图片image-20201113212314347.png)

      3. [root@linux-node1 /]# vim uwsgi_conf/uwsgi.ini
        [uwsgi]
        # 使用Nginx连接时使用,Django程序所在服务器地址和端口号
        socket=127.0.0.1:8000
        # 项目目录绝对路径
        chdir=/root/shiyanlou_project/syl
        # 项目中wsgi.py文件的目录,相对于项目目录
        wsgi-file=syl/wsgi.py
        # 进程数(机器核数的1倍)
        processes=4
        # 线程数
        threads=15
        # uwsgi服务器的角色
        master=True
        # 存放进程编号的文件
        pidfile=uwsgi.pid
        # 日志文件
        daemonize=uwsgi.log
        # 指定依赖的虚拟环境
        virtualenv=/root/.virtualenvs/syl
        
  3. 安装配置nginx

    1. 安装nginx

    2. [root@linux-node1 /]# sudo apt update # 更新apt
      [root@linux-node1 /]# sudo apt install nginx # 安装nginx
      [root@linux-node1 /]# sudo systemctl status nginx
      
    3. 打包vue静态资源到Linux下

      • 在终端输入 npm run build 打包

      • ![image-20201114135755082](C:UserswyxDesktop小实训day15 web容器 nginx+uwsgi+django部署图片image-20201114135755082.png)

      • 生成之后复制到Linux下(也就是虚拟机)

      • 放到自己想放到的地方 然后cd到目录中 输入pwd查看路径

      • server {
                listen 8888;
                server_name 192.168.56.100;
        
                location /static {
                        alias /root/dist;       #这个地方写入dist的绝对路径
                }
                location / {
                        include uwsgi_params;
                        uwsgi_pass 127.0.0.1:8888;
                        uwsgi_ignore_client_abort on;
                }
        }
        
  4. 在终端输入:vim /etc/nginx/conf.d/django.conf 编辑以下文件格式 注意第二个server 是vue静态资源的绝对路径

    • 配置nginx+uwsgi启动 第一个server是Django的第二个server是Vue的

    •  server {
       	listen 8888;
       	server_name 192.168.56.100;
       
       	location /static {
       		alias /teach/shiyanlou_project/syl/static;
       	}
       location / {
       	include uwsgi_params;
       	uwsgi_pass 127.0.0.1:8000;
       	uwsgi_ignore_client_abort on;
       	}
       }
       
       server {
               listen 8888;
               server_name 192.168.56.100;
       
               location /static {
                       alias /root/dist;    #这个地方写入dist的绝对路径
               }
               location / {
                       include uwsgi_params;
                       uwsgi_pass 127.0.0.1:8888;
                       uwsgi_ignore_client_abort on;
               }
       }
       
      
  5. uwsgi和nginx 启动、关闭、查看日志

    • 在 syl虚拟环境下操作

    •  '''1.启动并查看nginx日志'''
       systemctl restart nginx # 开启nginx
       tail -f /var/log/nginx/access.log # 查看nginx接入日志
       tail -f /var/log/nginx/error.log # 查看nginx错误日志
       
       
       '''2.启动并查看uwsgi日志'''
       cd /teach/shiyanlou_project/uwsgi_conf # 进入实验楼目录
       
       uwsgi --ini uwsgi.ini # 启动uwsgi的
       
       
       django项目
       # http://192.168.56.100:8888/ 访问项目
       
       uwsgi --stop uwsgi.pid # 关闭uwsgi
       
       tail -f uwsgi.log # 查看uwsgi日志
       
       ps -ef|grep uwsgi # 查看uwsgi服务是否启动
       
       root 92328 89266 0 14:37 pts/1 00:00:00 grep --color=auto uwsgi
       
       netstat -anptu | grep 8888 # 查看8888端口被哪一个程序
       占用
      
  6. 配置vue跨域

    • 在components下axios_api下修改 (这个是我自己的跨域文件,你需要修改你自己的)

    •  import axios from 'axios'
       
       axios.defaults.baseURL = "http://192.168.56.100:8888/"
      
  7. 重启服务

    • 获取id

    •  ps -A |grep 名字
      
    • 杀死

    •  kill -9 34302
      
    • 启动

    •  systemctl start nginx
       uwsgi --ini uwsgi.ini
      
原文地址:https://www.cnblogs.com/wyx-zy/p/14012677.html