django+nginx+flup

由于之前写的代码总是用的是Django自带的WSGIServer/0.1进行测试的。
但是这个webserver服务器毕竟只是用来进行测试的,它的某些性能方面都
不会特别的完善。并发性也不是很好

所以一般我们要把django项目挂载到网络上去的话,用那个肯定是不行的。
所以我们选用了nginx,当然nginx作为webserver的性能是没话说的了,
但是我们的Django没有直接和别的webserver对话的模块,所以这样的flup
也就应运而生了,flup就是nginx与Django之间的桥梁。

1.nginx:("engine x") 是一个高性能的 HTTP 和 反向代理 服务器,作用和apache的类似。
它可以处理一些静态文件的请求,而对于动态的文件的请求,它可以通过fastcgi方式,来分发请求给不同的动态语言处理。

2.flup:本身是一个使用python写的web服务器软件,它可以接受nginx发来的请求,
执行相应的python代码,将结果返回给nginx。

3.django:基于python的一个web框架,它可以我们做一些基础性的东西,
比如cookie,session管理,模板机制,权限管理等等
 

要使用他们当然是先要安装他们咯

安装python


安装Django


安装flup


安装nginx


接下来就是进行配置咯


在nginx配置文件中加上我们的python程序server:
如:
在本地的nginx的配置文件wxy.conf


server {
    listen 80;
    server_name  wxy.v5data.com;
    access_log    /home/nlog/v5data.log;
    error_log     /var/log/nginx/v5data.err.log;

    location / {
        fastcgi_pass unix:/tmp/v5data.sock;
        include fcgi.conf;
    }

    location /w3c/ {
        alias /home/htdocs/w3c/;
    }

    location = /favicon.ico {
        root /home/htdocs/w3c/favicon/v5data.com/;
    }
}

fcgi.conf:


    fastcgi_pass_header Authorization;
    fastcgi_intercept_errors off;

    fastcgi_param PATH_INFO             $fastcgi_script_name;
    fastcgi_param REQUEST_METHOD        $request_method;
    fastcgi_param QUERY_STRING          $query_string;
    fastcgi_param CONTENT_TYPE          $content_type;
    fastcgi_param CONTENT_LENGTH        $content_length;
    fastcgi_param SERVER_PORT           $server_port;
    fastcgi_param SERVER_PROTOCOL       $server_protocol;
    fastcgi_param SERVER_NAME           $server_name;

    fastcgi_param REQUEST_URI           $request_uri;
    fastcgi_param DOCUMENT_URI          $document_uri;
    fastcgi_param DOCUMENT_ROOT         $document_root;
    fastcgi_param SERVER_ADDR           $server_addr;
    fastcgi_param REMOTE_USER           $remote_user;
    fastcgi_param REMOTE_ADDR           $remote_addr;
    fastcgi_param REMOTE_PORT           $remote_port;
    fastcgi_param SERVER_SOFTWARE       "nginx";
    fastcgi_param GATEWAY_INTERFACE     "CGI/1.1";


最后再把wxy.conf文件添加到nginx的nginx.conf里面即可
include wxy.conf


上面的大部分是这样的了,当然Django项目如何建立,python代码如何写就不用在这里说了吧,呵呵。。。

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
在Linux系统上部署Django + nginx + uWSGI的步骤如下: 1. 安装必要的软件 在Linux系统上安装必要的软件包,包括Python、pip、nginx、uWSGI等。 2. 创建Django项目 使用Django创建一个新项目或使用现有的Django项目。 3. 配置uWSGI 在Django项目的根目录下创建一个uwsgi.ini文件,用于配置uWSGI。示例配置如下: ``` [uwsgi] # 指定运行模式为WSGI http = :8000 # 指定Django应用的wsgi模块 wsgi-file = myproject.wsgi # 指定进程数 processes = 4 # 指定线程数 threads = 2 # 指定静态文件路径 static-map = /static=/path/to/static # 指定日志路径 logto = /path/to/logfile ``` 其中,http参数指定了监听的端口号,wsgi-file参数指定了Django应用的wsgi模块,processes参数指定了进程数,threads参数指定了线程数,static-map参数指定了静态文件的路径,logto参数指定了日志文件的路径。 4. 配置nginxnginx的配置文件中添加以下内容: ``` server { listen 80; server_name example.com; access_log /var/log/nginx/access.log; error_log /var/log/nginx/error.log; location / { uwsgi_pass 127.0.0.1:8000; include uwsgi_params; } location /static { alias /path/to/static; } } ``` 其中,server_name指定了域名,access_log和error_log指定了日志文件的路径,uwsgi_pass指定了uWSGI的地址和端口号,include指定了uWSGI的参数。 5. 启动uWSGI服务 使用以下命令启动uWSGI服务: ``` uwsgi --ini uwsgi.ini ``` 6. 启动nginx服务 使用以下命令启动nginx服务: ``` sudo service nginx start ``` 这样就完成了Django + nginx + uWSGI的部署。可以通过访问该网站的域名来验证是否部署成功。

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值