zoukankan      html  css  js  c++  java
  • 0.3 linux安装部署njinx + uwsgi + django + vue(Windows)

    一、django的settings配置


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

    (~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~)

    二、安装uwsgi 配置uWSGI


    1. 安装uwsgi

    '''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
    

    (~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~)

    2. 配置uwgsi.ini启动文件

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

    (~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~)

    3. 使用uwsgi启动django:一定要在这个项目目录中

    '''3. 使用uwsgi启动django:一定要在这个项目目录中'''
    [root@linux-node1 /]# 
    uwsgi --http 192.168.56.100:6666 --file syl/wsgi.py --static-map=/static=static
    访问项目:http://192.168.56.11
    

    (~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~)

    4. 使用uwsgi启动django:一定要在这个项目目录中

    '''3. 使用uwsgi启动django:一定要在这个项目目录中'''
    [root@linux-node1 /]# 
    uwsgi --http 192.168.56.100:6666 --file syl/wsgi.py --static-map=/static=static
    访问项目:http://192.168.56.11
    

    三、安装配置nginx


    1. 安装nginx

    [root@linux-node1 /]# sudo apt update                  # 更新apt
    [root@linux-node1 /]# sudo apt install nginx           # 安装nginx
    [root@linux-node1 /]# sudo systemctl status nginx      # 查看nginx状态
    

    (~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~)

    2. /etc/nginx/nginx.confnginx主配置文件解读

    user www-data;
    worker_processes auto;
    pid /run/nginx.pid;
    include /etc/nginx/modules-enabled/*.conf;
    
    events {
    	worker_connections 768;      # 链接数量
    }
    
    http {
    	sendfile on;
    	tcp_nopush on;
    	tcp_nodelay on;
    	keepalive_timeout 65;
    	types_hash_max_size 2048;
    	
    	access_log /var/log/nginx/access.log;         # 客户浏览器访问nginx服务记录(客户户端访问异常时可以查看)
    	error_log /var/log/nginx/error.log;           # nginx错误日志(nginx启动时报错的日志)
    	include /etc/nginx/conf.d/*.conf;             # nginx扩展配置文件件
    	include /etc/nginx/sites-enabled/*;
    }
    

    (~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~)

    3. 打包vue静态资源到Linux

    1.在终端输入 npm run build 打包

    执行之后会出现dist的目录 包括static文件夹和index.html文件。。

    将这个dist文件夹拖到linux中 放到自己想放到的地方 然后cd到目录中 输入pwd查看路径

    (~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~)

    4. 配置nginx+uwsgi启动

    第一个server是django配置 下面那个是nvue的

    # /etc/nginx/conf.d/django.conf
    server {
        listen       8888;
        server_name  192.168.56.100;
        
            location /static {
                 #这个就是之前收集静态文件路径 绝地路径
                alias /root/home/worker/opwf_project/opwf/static;
            }
        
            location / {
                  include uwsgi_params;
                  uwsgi_pass 127.0.0.1:8000;
                  uwsgi_ignore_client_abort on;
            }
    }
    
    #nginx部署vue
    server {
            listen 8080;
            server_name 192.168.56.100;
            #access_log logs/access_example.log  main;
            #路径为自己保存的dist文件夹 注意root后方有一个空格 
            root /root/home/worker/frontopwf/dist;
            #解决打开页面报404问题
            location / {
                    try_files $uri $uri/ @router;
            }
            location @router {
                    rewrite ^.*$ /index.html last;
            }
    }
    

    写完可以在页面访问192.168.56.100:8888访问django。。

    192.168.56.100:8080访问前端vue。。。

    (~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~)

    四、uwsgi和nginx 启动、关闭、查看日志

    (~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~)

    '''1.启动并查看nginx日志'''
    [root@linux-node1 demo2]# systemctl restart nginx         # 开启nginx
    root@dev:uwsgi_conf# tail -f /var/log/nginx/access.log    # 查看nginx接入日志
    root@dev:uwsgi_conf# tail -f /var/log/nginx/error.log     # 查看nginx错误日志
    
    '''2.启动并查看uwsgi日志'''
    root@dev:uwsgi_conf# cd /teach/shiyanlou_project/uwsgi_conf     # 进入实验楼目录
    [root@linux-node1 demo2]# uwsgi --ini uwsgi.ini                 # 启动uwsgi的django项目
    # http://192.168.56.100:8888/ 访问项目
    [root@linux-node1 demo2]# uwsgi --stop uwsgi.pid                # 关闭uwsgi
    [root@dev:uwsgi_conf# tail -f uwsgi.log                      # 查看uwsgi日志
    

    (~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~)

    (syl) root@dev:uwsgi_conf# ps -ef|grep uwsgi       # 查看uwsgi服务是否启动
    root      92328  89266  0 14:37 pts/1    00:00:00 grep --color=auto uwsgi
    (syl) root@dev:uwsgi_conf# netstat -anptu | grep 8888     # 查看8888端口被哪一个程序占用
    

    (~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~)

    注意每次修改完代码最好都重新打开uwsgi和nginx

  • 相关阅读:
    Base4.net和IronPython的一些相关东东
    WPF E 文章汇总
    Novell 发布Mono 1.2 推动.NET跨平台
    Google真好,这么多的工具……
    bootstrap源码学习与示例:bootstrappopover
    bootstrap源码学习与示例:bootstrapscrollspy
    bootstrap源码学习与示例:bootstrapcollapse
    bootstrap源码学习与示例:bootstrapaffix
    bootstrap源码学习与示例:bootstraptab
    mass Framework attr模块 v3
  • 原文地址:https://www.cnblogs.com/tjw-bk/p/14122258.html
Copyright © 2011-2022 走看看