NGINX网关快速部署

NGINX + spawn-fcgi + fastCGI

后台网关快速部署 2022-08-21

作为后台开发, 不仅仅要注重后台业务逻辑与集群部署,对前端的网关组件也要了解原理并且知晓快速部署流程;

原理

使用NGINX作为前端转发组件,其次使用spwan-fcgi加载的可执行文件进行接口层业务处理,然后透传给前端数据, fastCGI作为头文件方便c/c++等开发语言进行快速业务搭建,对于步骤中的参数可根据help命令或配置文件自行调整,如进程数,IP,端口等。

部署步骤

1. Linux版本

cat /proc/version;
Linux version 3.10.0-862.el7.x86_64 (builder@kbuilder.dev.centos.org) (gcc version 4.8.5 20150623 (Red Hat 4.8.5-28) (GCC) ) #1 SMP Fri Apr 20 16:44:24 UTC 2018

2. 安装Nginx

a. rpm版安装最方便,可根据rpm包模糊搜索安装包名
sudo yum search nginx;
sudo yum -y install pcp-pmda-nginx;
sudo /usr/local/nginx/sbin/nginx -c /usr/local/nginx/conf/nginx.conf;
b. 也可根据Nginx版本号源码自行编译安装,如果有提示依赖包有缺失可根据错误提示安装相依依赖包即可(示例仅供参考),如果依赖包找不到路径配置时添加路径即可
wget https://nginx.org/download/nginx-1.22.0.tar.gz;
tar -zxvf nginx-1.22.0.tar.gz;
cd nginx-1.22.0;
sudo yum install pcre openssl openssl-devel;
./configure --with-openssl=/usr/lib64/openssl;
sudo make && sudo make install; 

3. 安装spawn-fcgi,并把可执行文件拷贝到Nginx的可执行文件目录下,稍后启动

wget http://download.lighttpd.net/spawn-fcgi/releases-1.6.x/spawn-fcgi-1.6.4.tar.gz;
tar -zxvf spawn-fcgi-1.6.4.tar.gz;
cd spawn-fcgi-1.6.4;
./configure
sudo cp spawn-fcgi /usr/local/nginx/sbin

4. 安装fastcgi,编译example,如果有报错加上依赖库-lfcgi++ -lpthread

wget https://github.com/FastCGI-Archives/fcgi2/archive/refs/heads/master.zip;
unzip master.zip;
cd fcgi2-master;
./autogen.sh;
./configure;
sudo make && sudo make install;
cd examples;
g++ echo.c -o echo -lfcgi;
/*
 * echo.c --
 *
 *	Produce a page containing all FastCGI inputs
 *
 *
 * Copyright (c) 1996 Open Market, Inc.
 *
 * See the file "LICENSE.TERMS" for information on usage and redistribution
 * of this file, and for a DISCLAIMER OF ALL WARRANTIES.
 *
 */

#include "fcgi_config.h"

#include <stdlib.h>

#ifdef HAVE_UNISTD_H
#include <unistd.h>
#endif

#ifdef _WIN32
#include <process.h>
#else
extern char **environ;
#endif

#include "fcgi_stdio.h"


static void PrintEnv(char *label, char **envp)
{
    printf("%s:<br>\n<pre>\n", label);
    for ( ; *envp != NULL; envp++) {
        printf("%s\n", *envp);
    }
    printf("</pre><p>\n");
}

int main ()
{
    char **initialEnv = environ;
    int count = 0;

    while (FCGI_Accept() >= 0) {
        char *contentLength = getenv("CONTENT_LENGTH");
        int len;

	printf("Content-type: text/html\r\n"
	    "\r\n"
	    "<title>FastCGI echo</title>"
	    "<h1>FastCGI echo</h1>\n"
            "Request number %d,  Process ID: %d<p>\n", ++count, getpid());

        if (contentLength != NULL) {
            len = strtol(contentLength, NULL, 10);
        }
        else {
            len = 0;
        }

        if (len <= 0) {
	    printf("I am bianbian.<p>\n");
        }
        else {
            int i, ch;

	    printf("Standard input:<br>\n<pre>\n");
            for (i = 0; i < len; i++) {
                if ((ch = getchar()) < 0) {
                    printf("Error: Not enough bytes received on standard input<p>\n");
                    break;
		}
                putchar(ch);
            }
            printf("\n</pre><p>\n");
        }

        PrintEnv("Request environment", environ);
        PrintEnv("Initial environment", initialEnv);
    } /* while */

    return 0;
}

5. 启动echo程序

a. 在nginx目录下创建fastcgibin, 在哪里无所谓,只要启动路径即可,并拷贝上面的echo程序到fastcgibin下
cd /usr/local/nginx/;
sudo mkdir fastcgibin;
cd fastcgibin;
sudo cp ~/fcgi2-master/examples/echo ./;
sudo /usr/local/nginx/sbin/spawn-fcgi -a 127.0.0.1 -p 7000 -f ./echo -F 1;
b. 服务已启动,还需要配置nginx_conf,修改location把前端请求参数转发到cgi进程上面进行业务处理,参考注释的location即可
location ~ /ttl/ {
        fastcgi_pass 127.0.0.1:7000;
        fastcgi_index index.cgi;
        fastcgi_param SCRIPT_FILENAME /scripts$fastcgi_script_name;
        include fastcgi_params;
        }  
c. 重启nginx, 浏览器请求服务器
sudo /usr/local/nginx/sbin/nginx -s reload;
d. 请求示例如下,显示了请求次数与进程ID

在这里插入图片描述

  • 3
    点赞
  • 10
    收藏
    觉得还不错? 一键收藏
  • 1
    评论
### 回答1: Nginx和uWSGI是部署Django应用程序的两个重要组件。Nginx是一个高性能的Web服务器,可以作为反向代理服务器,将请求转发到uWSGI服务器。uWSGI是一个Web服务器网关接口,可以将Django应用程序与Web服务器连接起来。 要部署Django应用程序,首先需要安装Nginx和uWSGI。然后,将Django应用程序配置为uWSGI服务器可以识别的格式。最后,将Nginx配置为反向代理服务器,将请求转发到uWSGI服务器。 具体步骤如下: 1. 安装Nginx和uWSGI 在Linux系统中,可以使用包管理器安装Nginx和uWSGI。例如,在Ubuntu系统中,可以使用以下命令安装: sudo apt-get install nginx uwsgi uwsgi-plugin-python3 2. 配置Django应用程序 将Django应用程序配置为uWSGI服务器可以识别的格式。可以创建一个uwsgi.ini文件,指定Django应用程序的路径和其他配置参数。例如: [uwsgi] module = myproject.wsgi:application env = DJANGO_SETTINGS_MODULE=myproject.settings master = true processes = 5 socket = /tmp/myproject.sock chmod-socket = 664 vacuum = true 3. 启动uWSGI服务器 使用以下命令启动uWSGI服务器: uwsgi --ini uwsgi.ini 4. 配置NginxNginx配置为反向代理服务器,将请求转发到uWSGI服务器。可以创建一个nginx.conf文件,指定Nginx的配置参数。例如: server { listen 80; server_name example.com; location / { include uwsgi_params; uwsgi_pass unix:/tmp/myproject.sock; } } 5. 启动Nginx服务器 使用以下命令启动Nginx服务器: sudo service nginx start 完成以上步骤后,就可以通过访问Nginx服务器的IP地址或域名来访问Django应用程序了。 ### 回答2: Django是一个优秀的Python Web框架,可以快速、高效地开发Web应用程序。为了将Django应用程序部署到生产环境中,必须选择一个适合的Web服务器和应用服务器nginx和uwsgi是目前最流行的Web服务器和应用服务器之一。 部署Django应用程序通常需要使用一个Web服务器来处理用户请求,例如静态文件请求,以及一个应用服务器来处理动态请求和逻辑处理。nginx作为一个高性能的反向代理和Web服务器,能够提供快速的静态文件服务,并能够处理大量的并发请求。uwsgi则是一个WSGI应用服务器,用于处理Django应用程序的动态请求。 下面是nginx和uwsgi部署Django的一般流程: 步骤一:安装和配置uwsgi 1. 使用pip安装uwsgi `pip install uwsgi` 2. 创建uwsgi配置文件 创建一个名为uwsgi.ini的配置文件。文件内容可以参考以下示例: ``` [uwsgi] chdir=/path/to/your/project module=project.wsgi:application home=/path/to/virtualenv/ master=True processes=4 socket=127.0.0.1:8001 vacuum=True ``` 配置文件中,chdir指定Django项目的根目录,module指定Django的WSGI接口,home指定虚拟环境的路径,master指定uwsgi是否以主进程方式运行(建议设置为True),processes指定子进程的数量,socket指定uwsgi监听的IP地址和端口号,vacuum指定uwsgi退出时是否清理UNIX套接字的文件。 3. 在命令行中启动uwsgi `uwsgi --ini /path/to/your/uwsgi.ini` 4. 测试uwsgi是否正常工作 可以使用浏览器或curl等工具访问uwsgi绑定的IP和端口。如果看到Django应用程序的欢迎页面,则说明uwsgi正常工作。 步骤二:安装和配置nginx 1. 使用apt-get或yum等包管理工具安装nginx `apt-get install nginx` 2. 创建nginx配置文件 创建一个名为myproject的配置文件。文件内容可以参考以下示例: ``` server { listen 80; server_name yourdomain.com; access_log /var/log/nginx/access.log; error_log /var/log/nginx/error.log; location / { include uwsgi_params; uwsgi_pass 127.0.0.1:8001; } location /static { alias /path/to/your/project/static; } } ``` 配置文件中,server_name指定nginx要监听的域名或IP地址,access_log和error_log分别指定nginx的访问日志和错误日志的路径,location /指定nginx如何处理动态请求,包括使用uwsgi_params配置文件和uwsgi_pass指令将请求转发到uwsgi服务器。location /static则指定nginx如何处理静态文件请求。 3. 启动nginx `service nginx start` 4. 测试nginx是否正常工作 可以使用浏览器或curl等工具访问nginx绑定的IP和端口。如果看到Django应用程序的欢迎页面,则说明nginx和uwsgi已经正常工作,Django应用程序已经成功部署。 总结 以上就是使用nginx和uwsgi部署Django应用程序的一般流程。我们需要先安装和配置uwsgi,然后配置nginx,最后启动nginx和uwsgi,并测试应用程序是否正常工作。如果需要将Django应用程序部署到生产环境中,还需要学习更多的部署技巧和经验,例如负载均衡、安全加固等。 ### 回答3: Django是一款非常流行的Web框架,而Nginx和uWSGI则是常见的Web服务器和Python应用程序服务器。这三个工具可以结合起来,用于部署和运行Django应用程序。 首先,我们需要将Django应用程序部署到一台服务器上,例如Ubuntu或CentOS。我们可以使用Git等工具来完成此操作。同时,我们需要在服务器上安装Python虚拟环境。Python虚拟环境可以为每个应用程序提供独立的Python环境,从而避免干扰其他应用程序。安装虚拟环境后,我们可以使用pip来安装Django和其他依赖项。 接下来,我们可以使用uWSGI来作为Django应用程序的Python应用程序服务器。uWSGI支持多种协议,例如HTTP和WebSocket。我们可以使用以下命令来启动uWSGI: ``` uwsgi --http :8000 --module mysite.wsgi --venv /path/to/venv ``` 这里,我们使用“http”协议并指定端口号8000。我们还指定了Django应用程序的入口点,即wsgi.py文件。最后,我们指定了Python虚拟环境的路径。当我们运行此命令时,uWSGI将启动一个Web服务器,该服务器将使用8000端口来监听HTTP请求,并将请求转发给Django应用程序。 最后,我们可以使用Nginx来作为反向代理服务器,以将uWSGI和Django应用程序连接到外部Internet。Nginx支持负载平衡和HTTPS等特性。我们可以使用以下Nginx配置文件来配置反向代理服务器: ``` server { listen 80; server_name example.com; location / { include uwsgi_params; uwsgi_pass unix:/tmp/uwsgi.sock; } location /static/ { alias /path/to/static/; } } ``` 这里,我们定义了一个名为example.com的虚拟主机来监听HTTP请求。我们将所有请求转发到uWSGI服务器的Unix套接字上,该套接字默认为/tmp/uwsgi.sock。另外,我们还配置了一个用于提供静态文件的路径。 使用此配置文件后,我们可以启动Nginx服务器,从而将所有来自外部Internet的请求都转发到Django应用程序上。此时,我们就成功地使用Nginx和uWSGI部署了Django应用程序,从而使其能够运行在Web服务器上。

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值