1. 系统包安装

# more /etc/redhat-release 

CentOS Linux release 7.3.1611 (Core) 

#

# yum install epel-release

# yum install -y nginx

# yum install -y uwsgi

# yum install -y uwsgi-plugin-python

2.python packets

1). setuptools

# wget https://pypi.python.org/packages/a9/23/720c7558ba6ad3e0f5ad01e0d6ea2288b486da32f053c73e259f7c392042/setuptools-36.0.1.zip#md5=430eb106788183eefe9f444a300007f0

# ll

# yum install -y unzip

# unzip setuptools-36.0.1.zip 

# cd setuptools-36.0.1

# ls

# python setup.py install

# cd ..

2).ez_setup

# wget https://pypi.python.org/packages/ba/2c/743df41bd6b3298706dfe91b0c7ecdc47f2dc1a3104abeb6e9aa4a45fa5d/ez_setup-0.9.tar.gz

# ls

# tar zxvf ez_setup-0.9.tar.gz 

# cd ez_setup-0.9

# ls

# python setup.py install

# cd ..

3). pip

# easy_install pip

4).Flask

# pip install Flask

5).virtualenv

# pip install virtualenv

3.app configuration

1).web app

# cd /opt/

# ls

# mkdir app

# ls

# useradd webapp

# chown webapp.webapp app

# su - webapp

$ cd /opt/app

$ vi app.py

from flask import Flask

app = Flask(__name__)

@app.route("/")

def index():

    return "hello,Flask web app."

if __name__ == "__main__":

    app.run('0.0.0.0', port=3333, debug=True)

$ vi website.py

import sys 

import os.path 

sys.path.insert(0, os.path.dirname(__file__)) 

from app import app as application

$ virtualenv --no-site-packages env

$ . env/bin/activate

$ pip install flask 

$ python app.py 

2).uwsgi configuration

$ mkdir -p uwsgi/apps-enabled

$ vi uwsgi/apps-enabled/app.ini

 

[uwsgi]

buffer-size = 32768

plugins = python

socket = 127.0.0.1:5000

threads = 2

master = true

uid = webapp

gid = webapp

chdir = /opt/app/

home = /opt/app/env/

pp = ..

module = website

 

3).nginx configuration

$ mkdir -p nginx/sites-enabled

$ vi nginx/sites-enabled/app.conf

upstream flask {

     server 127.0.0.1:5000;

 }  

# configuration of the server 

server {     

    # the domain name it will serve for     

    listen 8080; 

    # This is very important to test the server locally     

    server_name _; 

    # substitute your machine's IP address or FQDN     

    charset     utf-8;

    location / {

         uwsgi_pass  flask;

         include uwsgi_params;     

    } 

}

$ exit

嵌入nginx配置文件

[root@localhost ~]# vi /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 nginx;

worker_processes auto;

error_log /var/log/nginx/error.log;

pid /run/nginx.pid;

# Load dynamic modules. See /usr/share/nginx/README.dynamic.

include /usr/share/nginx/modules/*.conf;

events {

    worker_connections 1024;

}

http {

    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;

    tcp_nodelay         on;

    keepalive_timeout   65;

    types_hash_max_size 2048;

    include             /etc/nginx/mime.types;

    default_type        application/octet-stream;

    # 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;

    ###### python web app new add #####

    include /opt/app/nginx/sites-enabled/app.conf;

    server {

        listen       80 default_server;

        listen       [::]:80 default_server;

        server_name  _;

        root         /usr/share/nginx/html;

        # Load configuration files for the default server block.

        include /etc/nginx/default.d/*.conf;

        location / {

        }

        error_page 404 /404.html;

            location = /40x.html {

        }

        error_page 500 502 503 504 /50x.html;

            location = /50x.html {

        }

    }

# Settings for a TLS enabled server.

#

#    server {

#        listen       443 ssl http2 default_server;

#        listen       [::]:443 ssl http2 default_server;

#        server_name  _;

#        root         /usr/share/nginx/html;

#

#        ssl_certificate "/etc/pki/nginx/server.crt";

#        ssl_certificate_key "/etc/pki/nginx/private/server.key";

#        ssl_session_cache shared:SSL:1m;

#        ssl_session_timeout  10m;

#        ssl_ciphers HIGH:!aNULL:!MD5;

#        ssl_prefer_server_ciphers on;

#

#        # Load configuration files for the default server block.

#        include /etc/nginx/default.d/*.conf;

#

#        location / {

#        }

#

#        error_page 404 /404.html;

#            location = /40x.html {

#        }

#

#        error_page 500 502 503 504 /50x.html;

#            location = /50x.html {

#        }

#    }

}

[root@localhost ~]# 

4.启动uwsgi

[root@localhost soft]# uwsgi --ini /opt/app/uwsgi/apps-enabled/app.ini 

[uWSGI] getting INI configuration from /opt/app/uwsgi/apps-enabled/app.ini

*** Starting uWSGI 2.0.14 (64bit) on [Fri Jun  2 17:16:49 2017] ***

compiled with version: 4.8.5 20150623 (Red Hat 4.8.5-11) on 13 January 2017 23:06:53

os: Linux-3.10.0-514.el7.x86_64 #1 SMP Tue Nov 22 16:42:41 UTC 2016

nodename: localhost.localdomain

machine: x86_64

clock source: unix

pcre jit disabled

detected number of CPU cores: 1

current working directory: /home/soft

detected binary path: /usr/sbin/uwsgi

setgid() to 1001

setuid() to 1001

chdir() to /opt/app/

your processes number limit is 3862

your memory page size is 4096 bytes

detected max file descriptor number: 1024

lock engine: pthread robust mutexes

thunder lock: disabled (you can enable it with --thunder-lock)

uwsgi socket 0 bound to TCP address 127.0.0.1:5000 fd 3

Python version: 2.7.5 (default, Nov  6 2016, 00:28:07)  [GCC 4.8.5 20150623 (Red Hat 4.8.5-11)]

Set PythonHome to /opt/app/env/

Python main interpreter initialized at 0x12128e0

python threads support enabled

your server socket listen backlog is limited to 100 connections

your mercy for graceful operations on workers is 60 seconds

mapped 280832 bytes (274 KB) for 2 cores

*** Operational MODE: threaded ***

added ../ to pythonpath.

WSGI app 0 (mountpoint='') ready in 0 seconds on interpreter 0x12128e0 pid: 15167 (default app)

*** uWSGI is running in multiple interpreter mode ***

spawned uWSGI master process (pid: 15167)

spawned uWSGI worker 1 (pid: 15172, cores: 2)

5.启动nginx

# nginx

6.访问

浏览器"http://server-ip:8080"