• 重庆“轮椅教师”高位截瘫仍坚守讲台 2019-07-07
  • 百度车联网携手宝马 合作伙伴全面升级为国际OEM厂商 2019-07-01
  • 全面从严治党永远在路上——辽宁代表团开放日侧记 2019-07-01
  • 【学习时刻】华侨大学黄日涵:“一带一路”盛会开启合作发展新篇章 2019-06-24
  • 秒变迷弟!吴建豪晒与甄子丹合影:偶像给我签名 2019-06-20
  • 军统头目戴笠留下哪些巨额遗产 令蒋介石身边人惊诧 2019-06-20
  • 初春喝藿香汤 解表化湿,散寒温经 2019-06-18
  • 新华时评:磋商,不等于反复折腾 2019-06-09
  • 天山特克斯峡谷 中国国家地理网 2019-06-08
  • 端午小长假珠海口岸将迎双向客流高峰 2019-06-08
  • 王朝崩塌!恒大半个月内双线出局 卡帅敲响下课警钟 2019-06-07
  • 一周人事:国务院发布任免刘伟当选北京市总工会主席 2019-06-07
  • 敞篷式设计 日产聆风Open Car官图发布 2019-06-06
  • 习近平为传统文化“代言” 2019-06-05
  • 奋力谱写新时代追赶超越新篇章——访陕西省委书记胡和平 2019-06-04
  • 香港赛马会手表:详解Django+uwsgi+Nginx上线最佳实战

    香港赛马会网站惠泽社绝杀八码 www.mwcrz.tw  更新时间:2019年03月14日 10:57:51   作者:BlueMiaomiao   我要评论

    这篇文章主要介绍了Django+uwsgi+Nginx上线最佳实战,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友们下面随着小编来一起学习学习吧

    什么是uwsgi?

    uWSGI是一个Web服务器,它实现了WSGI协议、uwsgi、http等协议。Nginx中HttpUwsgiModule的作用是与uWSGI服务器进行交换。WSGI是一种Web服务器网关接口。它是一个Web服务器(如nginx,uWSGI等服务器)与web应用(如用Flask框架写的程序)通信的一种规范。

    1. WSGI是一种通信协议。
    2. uwsgi是一种线路协议而不是通信协议,在此常用于在uWSGI服务器与其他网络服务器的数据通信。uwsgi协议是一个uWSGI服务器自有的协议,它用于定义传输信息的类型(type of information),每一个uwsgi packet前4byte为传输信息类型描述,它与WSGI相比是两样东西。
    3. uWSGI是实现了uwsgi和WSGI两种协议的Web服务器。

    在开始之前

    最小化安装CentOS 6

    备份网卡文件

    ~$ mkdir /etc/sysconfig/network-scripts/backup
    ~$ cp /etc/sysconfig/network-scripts/ifcfg-eth0 /etc/sysconfig/network-scripts/backup/ifcfg-eth0.backup

    配置阿里云镜像源

    ~$ mkdir /etc/yum.repos.d/old
    ~$ mv /etc/yum.repos.d/CentOS-* /etc/yum.repos.d/old/
    ~$ cd /etc/yum.repos.d/
    ~$ curl -o /etc/yum.repos.d/CentOS-Base.repo //mirrors.aliyun.com/repo/Centos-6.repo
    ~$ yum clean all && yum repolist all && yum update -y
    ~$ reboot

    Python3.6.0

    上传Python-3.6.0.tar.xz

    ~$ rz

    安装依赖

    yum install zlib* gcc openssl openssl-devel libffi-devel -y
    yum install pcre pcre-devel pcre-static -y

    解压Python-3.6.0.tar.xz

    ~$ tar -xvf Python-3.6.0.tar.xz
    ~$ cd Python-3.6.0

    修改部分源代码

    ~$ vim Modules/Setup.dist
    # 将该文件的204到209行部分代码取消注释,完成后如下所示:
    # Socket module helper for socket(2)
    _socket socketmodule.c
    
    # Socket module helper for SSL support; you must comment out the other
    # socket line above, and possibly edit the SSL variable:
    SSL=/usr/local/ssl
    _ssl _ssl.c \
      -DUSE_SSL -I$(SSL)/include -I$(SSL)/include/openssl \
      -L$(SSL)/lib -lssl -lcrypto
    
    # The crypt module is now disabled by default because it breaks builds
    

    编译安装

    ~$ ./configure
    ~$ make -j
    ~$ make install
    ~$ cd
    ~$ rm -rf Python-3.6.0

    防火墙

    # 恢复默认配置
    iptables -F
    # 放通3306/8000/80端口
    iptables -I INPUT -p tcp -m tcp --dport 3306 -j ACCEPT
    iptables -I INPUT -p tcp -m tcp --dport 8000 -j ACCEPT
    iptables -I INPUT -p tcp -m tcp --dport 80 -j ACCEPT
    # 保存规则
    /etc/init.d/iptables save

    SELinux

    关闭SELinux

    ~$ vim /etc/selinux/config
    # 修改配置为如下所示:
    SELINUX=permissive
    
    ~$ reboot

    数据库

    二进制方式安装

    # 查找相关旧文件并删除
    find / -name mysql
    find / -name mariadb
    # 移除全部相关包
    rpm -qa | grep mysql
    rpm -qa | grep mariadb
    # 添加用户
    useradd mysql -s /sbin/nologin -M
    # 解压移动文件
    tar -xvf mysql-5.7.24-linux-glibc2.12-x86_64.tar.gz
    mv mysql-5.7.24-linux-glibc2.12-x86_64 /applications/
    ln -s /applications/mysql-5.7.24-linux-glibc2.12-x86_64/ /applications/mysql
    # 创建配置文件
    vim /etc/my.cnf
    # 创建相关目录
    mkdir -p /data/mysql/data
    mkdir -p /data/mysql/log
    # 手动创建日志文件
    touch /data/mysql/log/mysqld.log
    # 修改权限
    chown -R mysql.mysql /applications/mysql
    chown -R mysql.mysql /data/mysql
    

    MySQL配置文件

    [client]
    port=3306
    socket=/data/mysql/mysql.sock
    
    [mysqld]
    port=3306
    datadir=/data/mysql/data
    basedir=/applications/mysql
    pid-file=/data/mysql/mysqld.pid
    socket=/data/mysql/mysql.sock
    user=mysql
    character-set-server=utf8mb4
    default-storage-engine=INNODB
    collation-server = utf8mb4_general_ci
    init_connect='SET NAMES utf8mb4'
    max_connections = 1000
    max_connect_errors = 1200
    max_allowed_packet = 128M
    explicit_defaults_for_timestamp = true
    query_cache_size = 0
    query_cache_type = 0
    log_error = /data/mysql/log/error.log
    slow_query_log = 1
    slow_query_log_file = /data/mysql/log/slow.log
    log_queries_not_using_indexes = 1
    log_throttle_queries_not_using_indexes = 5
    long_query_time = 8
    log_slow_slave_statements = 1
    min_examined_row_limit = 100
    expire_logs_days = 5
    tmpdir = /tmp
    innodb_buffer_pool_size = 128M
    
    [mysqld_safe]
    log-error=/data/mysql/log/mysqld.log
    pid-file=/data/mysql/mysqld.pid
    # 同步数据
    /applications/mysql/bin/mysql_install_db --basedir=/applications/mysql/ --datadir=/data/mysql/data/ --user=mysql

    配置并启动

    cp /applications/mysql/support-files/mysql.server /etc/init.d/mysqld
    chmod +x /etc/init.d/mysqld 
    vim /etc/init.d/mysqld
    # 修改以下两行
    basedir=/applications/mysql
    datadir=/data/mysql/data
    # 查看是否启动
    netstat -tunlap | grep mysql
    # 添加服务并设置为开机自启动
    chkconfig --add mysqld
    chkconfig mysqld on

    初始化数据库

    /applications/mysql/bin/mysql_secure_installation
    -- 设置用户密码
    alter user 'root'@'localhost' identified by '123456';
    -- 允许root远程访问
    GRANT ALL PRIVILEGES ON *.* TO 'root'@'%' IDENTIFIED BY '123456' WITH GRANT OPTION;
    FLUSH PRIVILEGES;

    Django

    配置pip3源

    mkdir /root/.pip
    touch /root/.pip/pip.conf
    echo '[global]' >> /root/.pip/pip.conf
    echo 'trusted-host=mirrors.aliyun.com' >> /root/.pip/pip.conf
    echo 'index-url=https://mirrors.aliyun.com/pypi/simple/' >> /root/.pip/pip.conf

    创建虚拟环境安装依赖

    # PublisherPro,一个支持MD轻量级的CMS程式.
    git clone https://gitee.com/bluemiaomiao/PublisherPro.git
    pip3 install virtualenv
    cd PROJECT_DIR
    virtualenv venv
    source venv/bin/activate
    pip3 install -r requestments.txt
    pip3 install uwsgi
    mkdir log
    mkdir script
    touch PublisherPro/script/uwsgi.pid
    touch PublisherPro/script/uwsgi.status
    vim uwsgi.ini

    修改项目配置

    # PROJECT_DIR/PROJECT_NAME/settings.py
    # 设置为生产环境
    DEBUG = False
    # 配置数据库
    DATABASES = {
     'default': {
      'ENGINE': 'django.db.backends.mysql',
      'NAME': 'publisher_pro',
      'USER': 'pubpro',
      'PASSWORD': 'bluemiaomiao',
      'HOST': '192.168.1.203',
      'PORT': '3306',
      'OPTIONS': {'init_command': 'SET default_storage_engine=INNODB;'},
     }
    }
    # 配置静态文件相关
    # STATICFILES_DIRS = [os.path.join(BASE_DIR, 'static')]
    STATIC_ROOT = os.path.join(BASE_DIR, 'static')
    

    创建数据库和用户

    CREATE DATABASE `publisher_pro` CHARACTER SET 'utf8' COLLATE 'utf8_general_ci';
    CREATE USER `pubpro`@`localhost` IDENTIFIED BY 'bluemiaomiao' PASSWORD EXPIRE NEVER;
    CREATE USER `pubpro`@`%` IDENTIFIED BY 'bluemiaomiao' PASSWORD EXPIRE NEVER;
    GRANT All ON `publisher\_pro`.* TO `pubpro`@`%`;

    同步数据库

    ./venv/bin/python3 manage.py makemigrations
    ./venv/bin/python3 manage.py migrate
    ./venv/bin/python3 manage.py createsuperuser
    ./venv/bin/python3 manage.py collectstatic

    uwsgi

    配置文件内容

    # uwsig使用配置文件启动
    [uwsgi]
    # 项目目录
    chdir=/applications/website/PublisherPro
    # 指定项目的application
    module=PublisherPro.wsgi:application
    # 指定sock的文件路径  
    socket=/applications/website/PublisherPro/script/uwsgi.sock
    # 进程个数  
    workers=5
    pidfile=/applications/website/PublisherPro/script/uwsgi.pid
    # 状态文件
    stats=/applications/website/PublisherPro/script/uwsgi.status
    # 指定IP端口  
    http=0.0.0.0:8000
    # 指定静态文件
    static-map=/static=/applications/website/PublisherPro/static
    # 启动uwsgi的用户名和用户组
    uid=pubpro
    gid=pubpro
    # 启用主进程
    master=true
    # 自动移除unix Socket和pid文件当服务停止的时候
    vacuum=true
    # 序列化接受的内容,如果可能的话
    thunder-lock=true
    # 启用线程
    enable-threads=true
    # 设置自中断时间
    harakiri=30
    # 设置缓冲
    post-buffering=4096
    # 设置日志目录
    daemonize=/applications/website/PublisherPro/log/uwsgi.log

    创建用户和组并修改权限

    # 创建用户
    useradd pubpro -s /sbin/nologin -M
    # 检查结果
    id pubpro
    # 修改权限
    chown -R pubpro.pubpro /applications/website/PublisherPro/
    # 检查结果
    ll -d /applications/website/PublisherPro/
    

    测试Django应用

    # 启动应用
    uwsgi --ini uwsgi.ini
    # 重载应用
    uwsgi --reload script/uwsgi.pid
    # 状态信息
    uwsgi --connect-and-read script/uwsgi.status
    # 停止应用
    uwsgi --stop script/uwsgi.pid
    

    Nginx

    server {
     listen 80;
     server_name 192.168.2.108;
     access_log /var/log/nginx/access.log main;
     charset utf-8;
     gzip_types text/plain application/x-javascript text/css text/javascript application/x-httpd-php application/json text/json image/jpeg image/gif image/png application/octet-stream;
     error_page 404 /404.html;
     error_page 500 502 503 504 /50x.html;
    
     # 指定项目路径uwsgi
     location / {
        # 导入一个Nginx??樗怯美春蛈WSGI进行通讯的
      include uwsgi_params; 
        # 设置连接uWSGI超时时间
      uwsgi_connect_timeout 30; 
        # 指定uwsgi的sock文件所有动态请求就会直接丢给他
      uwsgi_pass unix:/data/PublisherPro/script/uwsgi.sock; 
     }
    
     # 指定静态文件路径
     location /static/ {
      alias /data/PublisherPro/static;
      index index.html index.htm;
     }
    }
    
    

    以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持脚本之家。

    相关文章

    • Python3 中把txt数据文件读入到矩阵中的方法

      Python3 中把txt数据文件读入到矩阵中的方法

      下面小编就为大家分享一篇Python3 中把txt数据文件读入到矩阵中的方法,具有很好的参考价值,希望对大家有所帮助。一起跟随小编过来看看吧
      2018-04-04
    • python网络编程之读取网站根目录实例

      python网络编程之读取网站根目录实例

      这篇文章主要介绍了python网络编程之读取网站根目录实例,以quux.org站根目录为例进行了实例分析,代码简单易懂,需要的朋友可以参考下
      2014-09-09
    • Python装饰器基础概念与用法详解

      Python装饰器基础概念与用法详解

      这篇文章主要介绍了Python装饰器基础概念与用法,结合实例形式详细分析了Python装饰器的概念、功能、用法及相关操作注意事项,需要的朋友可以参考下
      2018-12-12
    • 使用Python程序抓取新浪在国内的所有IP的教程

      使用Python程序抓取新浪在国内的所有IP的教程

      这篇文章主要介绍了使用Python程序抓取新浪在国内的所有IP的教程,作为Python网络编程中获取IP的一个小实践,需要的朋友可以参考下
      2015-05-05
    • pytorch 调整某一维度数据顺序的方法

      pytorch 调整某一维度数据顺序的方法

      今天小编就为大家分享一篇pytorch 调整某一维度数据顺序的方法,具有很好的参考价值,希望对大家有所帮助。一起跟随小编过来看看吧
      2018-12-12
    • Python Socket使用实例

      Python Socket使用实例

      这篇文章主要介绍了Python Socket使用实例,具有一定借鉴价值,需要的朋友可以参考下。
      2017-12-12
    • Python中按值来获取指定的键

      Python中按值来获取指定的键

      今天小编就为大家分享一篇关于Python中按值来获取指定的键,小编觉得内容挺不错的,现在分享给大家,具有很好的参考价值,需要的朋友一起跟随小编来看看吧
      2019-03-03
    • Python中的浮点数原理与运算分析

      Python中的浮点数原理与运算分析

      这篇文章主要介绍了Python中的浮点数原理与运算分析,结合实例形式分析了Python浮点数操作的常见错误,并简单解释了浮点数运算的原理与比较运算实现方法,需要的朋友可以参考下
      2017-10-10
    • python实现二维数组的对角线遍历

      python实现二维数组的对角线遍历

      这篇文章主要为大家详细介绍了python实现二维数组的对角线遍历,具有一定的参考价值,感兴趣的小伙伴们可以参考一下
      2019-03-03
    • python简单猜数游戏实例

      python简单猜数游戏实例

      这篇文章主要介绍了python简单猜数游戏,涉及Python随机数及流程控制的相关技巧,需要的朋友可以参考下
      2015-07-07

    最新评论

  • 重庆“轮椅教师”高位截瘫仍坚守讲台 2019-07-07
  • 百度车联网携手宝马 合作伙伴全面升级为国际OEM厂商 2019-07-01
  • 全面从严治党永远在路上——辽宁代表团开放日侧记 2019-07-01
  • 【学习时刻】华侨大学黄日涵:“一带一路”盛会开启合作发展新篇章 2019-06-24
  • 秒变迷弟!吴建豪晒与甄子丹合影:偶像给我签名 2019-06-20
  • 军统头目戴笠留下哪些巨额遗产 令蒋介石身边人惊诧 2019-06-20
  • 初春喝藿香汤 解表化湿,散寒温经 2019-06-18
  • 新华时评:磋商,不等于反复折腾 2019-06-09
  • 天山特克斯峡谷 中国国家地理网 2019-06-08
  • 端午小长假珠海口岸将迎双向客流高峰 2019-06-08
  • 王朝崩塌!恒大半个月内双线出局 卡帅敲响下课警钟 2019-06-07
  • 一周人事:国务院发布任免刘伟当选北京市总工会主席 2019-06-07
  • 敞篷式设计 日产聆风Open Car官图发布 2019-06-06
  • 习近平为传统文化“代言” 2019-06-05
  • 奋力谱写新时代追赶超越新篇章——访陕西省委书记胡和平 2019-06-04
  • 腾讯fifa手游官网 怎么下堡垒之夜手机版 百搭二王电子 福建31选7中奖新规则 一码中特资料2019 快乐赛车计划 09年国际米兰比赛表 北京快三走势图 神秘宝藏电子游戏 中彩网双色球走势图