ICode9

精准搜索请尝试: 精确搜索
首页 > 系统相关> 文章详细

nginx – 亚马逊Linux上的uwsgi暴发户

2019-09-17 11:08:54  阅读:211  来源: 互联网

标签:upstart nginx amazon-ec2 flask uwsgi


我在amazon linux上按照本教程https://uwsgi.readthedocs.org/en/latest/Upstart.html创建了一个uwsgi文件.虽然它似乎没有运行,因为Nginx只是说坏网关.如果我跑了

/etc/init/uwsgi.conf

description "uwsgi tiny instance"
start on runlevel [2345]
stop on runlevel [06]

exec /home/ec2-user/venv/bin/uwsgi --ini /home/ec2-user/uwsgi-prod_demo.ini

如果我在shell中运行以下命令,则运行python应用程序.

/home/ec2-user/venv/bin/uwsgi --ini /home/ec2-user/uwsgi-prod_demo.ini

uwsgi-prod_demo.ini

[uwsgi]
socket = :8080
chdir = /home/ec2-user/prod_demo
master = True
venv = /home/ec2-user/venv
callable = app
wsgi-file = /home/ec2-user/prod_demo/manage.py
enable-threads = True
https = =0,/home/ec2-user/xxx.com.au.pem,/home/ec2-user/newkey.pem,HIGH

nginx.conf

user  ec2-user;
worker_processes  1;

error_log  /var/log/nginx/error.log;
#error_log  /var/log/nginx/error.log  notice;
#error_log  /var/log/nginx/error.log  info;

pid        /var/run/nginx.pid;


events {
    worker_connections  1024;
}


http {
    include       /etc/nginx/mime.types;
    default_type  application/octet-stream;

    log_format  main  '$remote_addr - $remote_user [$time_local] "$request" '
                      '$status $body_bytes_sent "$http_referer" '
                      '"$http_user_agent" "$http_x_forwarded_for"';

    access_log  /var/log/nginx/access.log  main;

    sendfile        on;
    #tcp_nopush     on;

    #keepalive_timeout  0;
    keepalive_timeout  65;

    #gzip  on;

    # Load modular configuration files from the /etc/nginx/conf.d directory.
    # See http://nginx.org/en/docs/ngx_core_module.html#include
    # for more information.
    include /etc/nginx/conf.d/*.conf;

  server {
    listen 80;
    listen 443 ssl;
    ssl_certificate /home/ec2-user/xxx.com.au.pem;
    ssl_certificate_key /home/ec2-user/newkey.pem;
    server_name import.xxx.com.au  *.import.xxx.com.au;
    access_log /var/log/prod_demo/access_log;

    root /home/ec2-user/prod_demo;

    location / {
      uwsgi_pass 127.0.0.1:8080;
      include uwsgi_params;
    }

    location /static {
         alias /home/ec2-user/prod_demo/app/static;
    }

    location = /favicon.ico {
            alias    /home/ec2-user/prod_demo/app/static/images/favicon.ico;
    }
  }
}

解决方法:

为了解决这个问题,我做了一些事情.
– 将所有脚本从主目录移动到/ var / www /
– 创建了一个www组和www用户,并将www / www / www创建到www:www

完整说明

>创建用户和组www和www

sudo groupadd www
sudo adduser www -g www

>创建一个dir,你的烧瓶应用程序将是/ var / www /

sudo chown -R www:www /var/www

> /etc/nginx/nginx.conf

# /etc/nginx/nginx.conf

# For more information on configuration, see:
#   * Official English Documentation: http://nginx.org/en/docs/
#   * Official Russian Documentation: http://nginx.org/ru/docs/

user  www;
worker_processes  1;

error_log  /var/log/nginx/error.log;
#error_log  /var/log/nginx/error.log  notice;
#error_log  /var/log/nginx/error.log  info;

pid        /var/run/nginx.pid;


events {
    worker_connections  1024;
}


http {
    include       /etc/nginx/mime.types;
    default_type  application/octet-stream;

    log_format  main  '$remote_addr - $remote_user [$time_local] "$request" '
                      '$status $body_bytes_sent "$http_referer" '
                      '"$http_user_agent" "$http_x_forwarded_for"';

    access_log  /var/log/nginx/access.log  main;

    sendfile        on;
    #tcp_nopush     on;
    client_max_body_size 20M;

    #keepalive_timeout  0;
    keepalive_timeout  0;

    uwsgi_read_timeout 86400;
    uwsgi_send_timeout 86400;

    #gzip  on;

    # Load modular configuration files from the /etc/nginx/conf.d directory.
    # See http://nginx.org/en/docs/ngx_core_module.html#include
    # for more information.
    include /etc/nginx/conf.d/*.conf;

  server {
    listen 80;
    listen 443 ssl;
    ssl_certificate /var/www/test.com.au.pem;
    ssl_certificate_key /var/www/newkey.pem;
    server_name demo.test.com.au;
    access_log /var/log/prod_demo/access_log;

    root /var/www/prod_demo;

    location / {
      uwsgi_pass 127.0.0.1:28080;
      include uwsgi_params;
    }

    location /static {
         alias /var/www/prod_demo/app/static;
    }

    location = /favicon.ico {
            alias    /var/www/prod_demo/app/static/images/favicon.ico;
    }
  }

  server {
    listen 80;
    listen 443 ssl;
    ssl_certificate /var/www/test.com.au.pem;
    ssl_certificate_key /var/www/newkey.pem;
    server_name ajtravel.test.com.au;
    access_log /var/log/prod_demo_two/access_log;

    root /var/www/prod_demo_two;

    location / {
      uwsgi_pass 127.0.0.1:28082;
      include uwsgi_params;
    }

    location /static {
         alias /var/www/prod_demo_two/app/static;
    }

    location = /favicon.ico {
            alias    /var/www/prod_demo_two/app/static/images/favicon.ico;
    }
  }

   #test config

  server {
    listen 80;
    listen 443 ssl;
    ssl_certificate /var/www/test.com.au.pem;
    ssl_certificate_key /var/www/newkey.pem;
    server_name demo.test.test.com.au;
    access_log /var/log/prod_demo/access_log;

    root /var/www/prod_demo;

    location / {
      uwsgi_pass 127.0.0.1:28080;
      include uwsgi_params;
    }

    location /static {
         alias /var/www/prod_demo/app/static;
    }

    location = /favicon.ico {
            alias    /var/www/prod_demo/app/static/images/favicon.ico;
    }
  }

  server {
    listen 80;
    listen 443 ssl;
    ssl_certificate /var/www/test.com.au.pem;
    ssl_certificate_key /var/www/newkey.pem;
    server_name ajtravel.test.test.com.au;
    access_log /var/log/prod_demo_two/access_log;

    root /var/www/prod_demo_two;

    location / {
      uwsgi_pass 127.0.0.1:28082;
      include uwsgi_params;
    }

    location /static {
         alias /var/www/prod_demo_two/app/static;
    }

    location = /favicon.ico {
            alias    /var/www/prod_demo_two/app/static/images/favicon.ico;
    }
  }
}

> /etc/init/uwsgi-prod-demo.conf

# https://uwsgi.readthedocs.org/en/latest/Upstart.html
# /etc/init/uwsgi.conf
# simple uWSGI script

description "uwsgi tiny instance"
#start on runlevel [2345]
#stop on runlevel [06]

start on started elastic-network-interfaces

exec /var/www/venv/bin/uwsgi --ini /var/www/uwsgi-prod_demo.ini

> /var/www/uwsgi-prod_demo.ini

[uwsgi]
uid = www
gid = www
socket = :28080
chdir = /var/www/prod_demo
master = True
venv = /var/www/venv
callable = app
wsgi-file = /var/www/prod_demo/manage.py
enable-threads = True

标签:upstart,nginx,amazon-ec2,flask,uwsgi
来源: https://codeday.me/bug/20190917/1809369.html

本站声明: 1. iCode9 技术分享网(下文简称本站)提供的所有内容,仅供技术学习、探讨和分享;
2. 关于本站的所有留言、评论、转载及引用,纯属内容发起人的个人观点,与本站观点和立场无关;
3. 关于本站的所有言论和文字,纯属内容发起人的个人观点,与本站观点和立场无关;
4. 本站文章均是网友提供,不完全保证技术分享内容的完整性、准确性、时效性、风险性和版权归属;如您发现该文章侵犯了您的权益,可联系我们第一时间进行删除;
5. 本站为非盈利性的个人网站,所有内容不会用来进行牟利,也不会利用任何形式的广告来间接获益,纯粹是为了广大技术爱好者提供技术内容和技术思想的分享性交流网站。

专注分享技术,共同学习,共同进步。侵权联系[81616952@qq.com]

Copyright (C)ICode9.com, All Rights Reserved.

ICode9版权所有