centos6.5腾讯云django环境部署---二、Gunicorn+Django+nginx+mysql部署

接上一章:已经按照以前章节安装了Python2.7.10,Django 1.8.14. 以及mysql并建立了数据库以及数据库账号密码。python

1、安装nginx

yum -y install nginx
#设置nginx开机启动:
chkconfig nginx on
启动nginx:service nginx start

  若是安装不了或者找不到nginx的源,则手动添加文件:mysql

/etc/yum.repos.d/nginx.repo

  在里面填入:nginx

[nginx]

name=nginx repo

baseurl=http://nginx.org/packages/centos/6/$basearch/

gpgcheck=0

enabled=1

  而后再执行一次yum -y install nginx  sql

启动报错:nginx: [emerg] socket() [::]:80 failed (97: Address family not supported by protocol)数据库

  解决办法:vim /etc/nginx/conf.d/default.confvim

  将:   listen       80 default_server; centos

            listen       [::]:80 default_server;bash

  改成: listen       80;
             #listen       [::]:80 default_server;

  启动nginx就好了。。app

2、配置nginx

vi /etc/nginx/nginx.conf

     (修改为本身的用户帐号,它默认用的是nginx用户,但咱们博客的目录下访问这些是须要用户帐号的,而nginx这个用户是没有权限的。因此将user后改为本身的用户帐号brad。若是不作这些修改,咱们后面访问静态文件会出现问题。由于nginx原本就没有权限去访问这些静态的文件。)socket

    

  


3、安装gunicorn

  一、安装

/usr/local/bin/pip install gunicorn

  二、 在xxx_project下新建gunicorn的配置文件gunicorn.conf.py

import multiprocessing

bind = "127.0.0.1:8080"
workers = 2
errorlog = '/home/brad/xxx_project/gunicorn.error.log'
#accesslog = './gunicorn.access.log'
#loglevel = 'debug'
proc_name = 'gunicorn_blog_project'

  三、在XXX_project下新建nginx的配置文件nginx.conf 

server {
     listen 80;
     server_name localhost example.com;
     access_log /home/brad/xxx_project/nginx.access.log;
     error_log /home/brad/xxx_project/nginx.error.log;

     location / {
         proxy_pass http://127.0.0.1:8080;
         proxy_set_header Host $host;
         proxy_set_header X-Real-IP $remote_addr;
         proxy_set_header X-Forwarded-For $proxy_add_x_forwarded_for;
     }

     location /robots.txt {
        alias /home/brad/xxx_project/static/robots.txt;
     }

     location /favicon.ico {
          alias /home/brad/xxx_project/static/img/favicon.ico;
     }

     location ~ ^/(media|static)/  {
         root    /home/brad/xxx_project;
         expires 30d;
     }


     # this prevents hidden files (beginning with a period) from being served
      location ~ /\. { 
        access_log off; log_not_found off; deny all;
     }

}

  四、将其连接到 /etc/nginx/conf.d/blog_project.conf (须要root账号权限或者sudo)

sudo ln -s /home/brad/xxx_project/nginx.conf /etc/nginx/conf.d/xxx_project.conf

  五、同时,必须把nginx.conf里server_name后面的内容(localhost)加入到 settings.py里的ALLOWED_HOSTS

sudo vi settings.py

  

  六、如今咱们如今能够运行一下gunicorn:

sudo nohup /usr/local/python2710/bin/gunicorn xz1024_project.wsgi:application -c /home/brad/xz1024_project/gunicorn.conf.py& 

  注意:须要在/home/brad/xxx_project目录下面执行。

  8.若是要外部访问,则打开80端口:

sudo /sbin/iptables -I INPUT -p tcp --dport 80 -j ACCEPT

sudo service iptatbles save
相关文章
相关标签/搜索