CentOS服务器配置Nginx、uwsgi实现Android文件上传功能

系统准备

首先,我们安装yum-utils,一个yum的拓展库,能够实现完整得yum功能和插件
sudo yum -y install yum-utils
接下来安卓CentOS开发者工具,用于编译源代码
sudo yum -y groupinstall development

安装python3

安装IUS
sudo yum -y install https://centos7.iuscommunity.org/ius-release.rpm
安装最新版本python
sudo yum -y install python36u
检查python版本
python3.6 -V
接下来安装python36u0devel包,提供了python3环境下需要的库和头文件
sudo yum -y install python36u-devel

配置虚拟环境

虚拟环境可以提供独立的环境给不同的python项目,保证你的项目有独立的依赖不会干扰到其他项目 。每个编程环境都可以安装不同的python库
选择一个路径去放置python编程环境
cd opt/
mkdir python-virtual-dev
cd python-virtual-dev
python-3.6 demo
接着进入该环境
source demo/bin/activate
安装django库
pip install django
安装uwsgi
pip install uwsgi

配置Nginx

安装
yum -y install eqel-release
yum repolist
yum install nignx
安装完打开nginx服务
systemctl start nginx
并且测试初始页是否能完成服务
X.X.X.X(浏览本机IP地址)
接着修改nginx主配置文件
systemctl stop nginx
'cd /etc/nginx'
vim 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;

#    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 {
#        }
#    }
}  

配置文件
cd conf.d
vim vitrual.conf

# configuration of the server
server {
    # the port your site will be served on
    listen 8080;
    # the domain name it will serve for
    server_name  X.X.X.X; # substitute your machine's IP address or FQDN
    error_log /srv/www/yt_demo/logs/error.log;
    access_log /srv/www/yt_demo/logs/access.log;
    charset     utf-8;

    # Django media
    location /media/  {
        alias /srv/www/yt_demo/media/;  # your Django project's media files - amend as required
    }

    location /static/ {
        alias /srv/www/yt_demo/static/; # your Django project's static files - amend as required
    }

    # Finally, send all non-media requests to the Django server.
    location / {
        uwsgi_pass  unix:/opt/uwsgi/sock/yt_demo.sock;
        include    uwsgi_params; # the uwsgi_params file you installed
    }

创建用户组

useradd -s /bin/false -r uwsgi

创建Django项目

进入虚拟环境
source /opt/python-virtual-env/demo/bin/activate
选择路径创建项目
cd srv/
mkdir www
cd www
django admin startproject yt_demo
创建logs目录记录log文件
mkdir logs
cd logs
创建空文件
vim error.log
vim access.log
接下来修改文件权限保证nginx能够拥有访问权限
chown nginx:nginx -R yt_demo/
返回yt_demo文件夹并创建static和media文件夹
mkdir static
mkdir media

配置uwsgi

cd /etc
mkdir uwsgi
cd uwsgi
vim emperor.ini

[uwsgi]
emperor = /etc/uwsgi/vassals
uid = uwsgi
gid = nginx
logto = /etc/uwsgi/log

创建log文件
vim log
vassals配置
mkdir vassals
vim demo.ini

[uwsgi]
http = :8000
socket = /opt/uwsgi/sock/yt_demo.sock
chdir = /srv/www/yt_demo
pythonpath = /srv/www/yt_demo/yt_demo
home = /opt/python-virtual-env/demo
module = yt_demo.wsgi
uid = uwsgi
chmod-socket = 664
chown-socket = uwsgi

修改系统uwsgi配置
cd /etc/systemd/system
vim uwsgi.service

[Unit]
Description=uWSGI Emperor
After=syslog.target

[Service]
ExecStart = /opt/python-virtual-env/demo/bin/uwsgi --ini /etc/uwsgi/emperor.ini
ExecStop = kill -INT `cat /run/uwsgi.pid`
ExecReload = kill -TERM `cat /run/uwsgi.pid`
Restart = always
Type = notify
NotifyAccess = main
PIDFile = /run/uwsgi.pid

[Install]
WantedBy=multi-user.target

创建sock

cd /opt/
mkdir sock
修改访问权限
'chown uwsgi:uwsgi /opt/uwsgi'
接下来测试配置是否成功
systemctl start nginx
systemctl start uwsgi

Django接受文件

创建Django应用

进入yt_demo项目路径
cd /srv/www/yt_demo/
创建应用
python manage.py startapp swim
修改/swim/views.py

from django.views.decorators.csrf import csrf_exempt
from django.core.files.storage import default_storage
from django.core.files.base import ContentFile
import traceback

from . import models

@csrf_exempt
def Uploadfile(request):
    if request.method == 'GET':
        return HttpResponse("Get success")
    elif request.method == 'POST':
        try:
           # newtxt = models.Txt(txtfile = request.FILE['accData'])
           # newtxt.save()
            swim_txt = request.FILES.get('accData')
            #with open('/srv/www/yt_demo/media/acc/acc.txt','wb+') as destination:
             #   for chunk in swim_txt.chunks():
              #      destination.write(chunk)
            path = default_storage.save('/srv/www/yt_demo/media/acc/'+swim_txt.name,ContentFile(swim_txt.read()))
            return HttpResponse('POST success')
        except:
            tb = traceback.format_exc()
            return HttpResponse(tb)
    else:
        return HttpResponse('Other request')
    #if request.method == 'POST':
       # try:
           # swim_txt = request.FILES.get('accData')
           # path = default_storage.save('User/static/User/swimdata/'+swim_txt.name,ContentFile(swim_txt.read()))
       # return HttpResponse('File got')
      # except:
            #return HttpResponse('File failed')

def index(request):
    return HttpResponse("Hello,world.You're at the swim index.")
# Create your views here.

修改swim/urls.py

from django.conf.urls import url
from . import views

urlpatterns = [
    url(r'^$',views.index,name = 'index'),
    url(r'^Uploadfile/$',views.Uploadfile,name = 'Uploadfile'),
]

修改yt_demo/urls.py

from django.conf.urls import url,include
from django.contrib import admin
from django.conf.urls.static import static
from django.conf import settings

urlpatterns = [
    url(r'^admin/', admin.site.urls),
    url(r'^swim/', include('swim.urls')),
] + static(settings.MEDIA_URL, document_root=settings.MEDIA_ROOT)

记得修改media文件夹的访问权限防止出现权限问题

你可能感兴趣的:(CentOS服务器配置Nginx、uwsgi实现Android文件上传功能)