Nginx + fastCGI 实现动态网页部署
简介
- 本文章主要介绍下,如何通过Nginx + fastCGI来部署动态网页。
CGI介绍
- 在介绍fastCGI之前先介绍下CGI是什么。
- CGI : Common Gateway Interface,公共网关接口。在物理层面上是一段程序,运行在服务器上,提供同客户端HTML页面的接口。
- Nginx+CGI处理步骤
- 用户发送HTTP请求到Web服务器
- Web服务器fork一个CGI子进程,将用户请求交给CGI程序
- CGI程序把处理结果传送给Web服务器,CGI子进程被销毁
- Web服务器把结果返回到用户
- CGI缺点
- CGI每处理一个请求,就要fork一个子进程,处理完请求,再销毁子进程。频繁的创建和销毁进程,就会大大降低Web服务器的效率。
- fastCGI
- fastCGI是对CGI的优化,fastCGI并不会每处理一个请求就创建一个进程, 这样就避免了频繁创建和销毁CGI进程,可以大大提高服务器的效率。
- 下面就重点介绍下fastCGI
fastCGI
- FastCGI是一个可伸缩的、高速的在HTTP服务器和动态脚本语言间通信的接口,主要优点是把动态语言和HTTP服务器分离开来。
- 主要是将CGI进程保持在内存中进行管理调度,以获得较高的性能。
- fastCGI的工作原理
- Web服务器启动时载入fastCGI进程管理器
- fastCGI进程管理器自身初始化,启动多个CGI子进程并等待来自Web服务器的连接
- 当客户端请求到达Web服务器时,fastCGI进程管理器选择并连接到一个CGI进程来处理请求
- fastCGI子进程完成处理后将结果返回给Web服务器
- 问题
- Nginx下fastCGI与服务器是分离的,就是Nginx无法直接调用fastCGI,需要用spawn-fcgi来管理
spawn-fcgi
- spawn-fcgi是Nginx和fastCGI之间的桥梁,负责Nginx和fastCGI之间的数据通信

安装
- fastCGI
- ./configure
- make
- make install
- 如果make时报错,在libfcgi/fcgio.cpp中添加头文件 #include <stdio.h>
- spawn-fcgi
- ./configure
- make
- make install
- 关于Nginx的安装另一篇文章中有介绍 : Nginx部署静态网页
环境配置
- Nginx配置
- 主要是将Nginx处理不了的指令交给fastCGI操作
- 打开Nginx配置文件 /usr/local/nginx/conf/nginx.conf,在server字段里加一个location字段
-
# 处理指令location /fastCgiTest{# 配置fastcgi模块,这里的端口是fastCGI进程的端口fastcgi_pass 192.168.206.128:10010# 包含配置文件include fastcgi.conf}
-
- Nginx默认展示登录网页(用该程序替换Nginx默认index.html)
-
<!DOCTYPE html><html lang="en"><head><meta charset="UTF-8"><title>FastCGI测试网站</title></head><body><h1 align="center">FastCGI测试网站</h1><div class="container"><form method="post" action="http://192.168.206.128/fastCgiTest"><p align="center"><label>姓名:<input type="text" name="username" placeholder="admin" autofocus="autofocus"></label></p><p align="center"><label>密码:<input type="tel" name="phone" placeholder="000" required="required"></label></p><p align="center"><button class="mybtn">登录</button></p></form></div></body></html>
-
spawn-fcgi的使用
- 命令 : spawn-fcgi -a IP -p PORT -f fastcgi程序
- IP : Nginx服务器ip地址,就是上面配置的127.0.0.1
- PORT : 服务器将数据发送到的端口,就是上面我们配置的10010端口
- fastcgi程序 : spawn-fcgi fork fastcgi进程,fastcgi程序需要我们自己实现并编译。
编写fastcgi程序
- 这是参考fastcgi中的一个demo写的一个,主要实现登录功能,如果输入正确的用户名和密码,展示登录成功界面,如果输入错误的用户名和密码,继续展示登录界面,并提示重新登录。
-
#include "fcgi_config.h"#include <stdlib.h>#ifdef HAVE_UNISTD_H#include <unistd.h>#endif#ifdef _WIN32#include <process.h>#elseextern char **environ;#endif#include <string.h>#include "fcgi_stdio.h"//检查登录账号和密码int checkLogin(char* recvBuf, const char* userName, const char* password);int main (){char **initialEnv = environ;int count = 0;while (FCGI_Accept() >= 0) {//请求数据长度char *contentLength = getenv("CONTENT_LENGTH");//请求方法(GET/POST)char *requestmechod = getenv("REQUEST_METHOD");//响应头(printf相当于发送数据)printf("MyFlag: IsFastCGI\r\n"); //可以加自定义响应头printf("Content-type: text/html\r\n");printf("\r\n");int length = 0;//POST请求if(strcmp(requestmechod, "POST") == 0){length = strtol(contentLength, NULL, 10);//post请求没有数据,不处理if(length == 0){continue;}//读取post请求数据char ch;char recvBuf[1024 * 10] = {0};for (int i = 0; i < length; i++) {if ((ch = getchar()) < 0) {printf("read post data failed\n");continue;}recvBuf[i] = ch;}if(checkLogin(recvBuf, "admin", "000")){printf("<h1>Login success!</h1>\r\n");}else{printf("<!DOCTYPE html>\r\n");printf("<html lang=\"en\">\r\n");printf("<head>\r\n");printf("<meta charset=\"UTF-8\">\r\n");printf("<title>FastCGI测试网站</title>\r\n");printf("</head>\r\n");printf("<body>\r\n");printf("<h1 align=\"center\">FastCGI测试网站</h1>\r\n");printf("<div class=\"container\">\r\n");printf("<form method=\"post\" action=\"http://192.168.206.128/fastCgiTest\">\r\n");printf("<p align=\"center\"><label>姓名:<input type=\"text\" name=\"username\" placeholder=\"admin\" autofocus=\"autofocus\"></label></p>\r\n");printf("<p align=\"center\"><label>密码:<input type=\"password\" name=\"password\" placeholder=\"000\" required=\"required\"></label></p>\r\n");printf("<p align=\"center\">\r\n");printf("<button class=\"mybtn\">登录</button>\r\n");printf("</p>\r\n");printf("</form>\r\n");printf("</div>\r\n");printf("<dialog open>\r\n");printf("<p>用户名或密码错误,请重新登录</p>\r\n");printf("<form method=\"dialog\">\r\n");printf("<button align=\"center\">确定</button>\r\n");printf("</form>\r\n");printf("</dialog>\r\n");printf("</html>\r\n");}}} /* while */return 0;}int checkLogin(char* recvBuf, const char* userName, const char* password){ char* p = recvBuf;char* pUserName = strtok(p, "&");char* pPassWord = strtok(NULL, "&");char* pUserNameKey = strtok(pUserName, "=");char* pUserNameValue = strtok(NULL, "=");char* pPassWordKey = strtok(pPassWord, "=");char* pPassWordValue = strtok(NULL, "=");if(strcmp(pUserNameValue, userName) == 0 && strcmp(pPassWordValue, password) == 0){return 1;}return 0;} - 编译
- gcc echo.c -lfcgi
- 启动fastcgi
- spawn-fcgi -a 192.168.206.128 -p 10010 -f ./a.out
- 如果有以下报错,说明启动失败了。先直接启动下a.out看是什么报错
- spawn-fcgi: child exited with: 127
- 直接启动a.out,可以看到以下报错
- ./a.out: error while loading shared libraries: libfcgi.so.0: cannot open shared object file: No such file or directory
- 说明找不到库文件libfcgi.so,这个文件在这个目录下 /usr/local/lib
- 可以把这个目录加到 /etc/ld.so.conf文件中,执行sudo ldconfig
- 再重新启动fastcgi程序。注意a.out前面一定要加路径。
- 有以下打印说明启动成功了
- spawn-fcgi: child spawned successfully: PID: 26378
测试
- 首先我们在浏览器中访问Nginx,默认端口为80。然后会展示我们写的登录网页,在登录网页中输入用户名和密码后,点击提交,会发送POST请求到Nginx配置文件中配置的/fastCgiTest指令上。Nginx就会根据ip和端口将指令转发到fastCGI程序,fastCGI程序处理POST请求数据,如果用户名和密码正确,显示登录成功,如果用户名和密码错误,继续展示登录界面,并提示用户重新登录。
- 先访问Nginx,展示默认网页

- 输入正确的用户名和密码,fastCGI程序处理后展示登录成功界面

- 输入错误的用户名和密码,fastCGI程序处理后,重新展示登录界面,并提示重新登录

相关文章:
Nginx + fastCGI 实现动态网页部署
简介 本文章主要介绍下,如何通过Nginx fastCGI来部署动态网页。 CGI介绍 在介绍fastCGI之前先介绍下CGI是什么。CGI : Common Gateway Interface,公共网关接口。在物理层面上是一段程序,运行在服务器上,提供同客户端HTML页面的…...
精彩回顾 | Fortinet Accelerate 2023·中国区巡展厦门站
Fortinet Accelerate 2023中国区 5月16日,Fortinet Accelerate 2023中国区巡展来到魅力“鹭岛”——厦门,技术、产品和业务专家,携手亚马逊云科技、唯一网络等云、网、安合作伙伴,与交通、物流、金融等各行业典型代表客户&#x…...
ChatGPT 和对话式 AI 的未来:2023 年的进展和应用
人工智能(Artificial Intelligence)在过去一段时间以来以前所未有的速度快速发展。从自动化日常任务到重要提醒的设定,AI以各种方式渗透到我们的生活中。然而,在这个领域中迈出的最重要一步是ChatGPT。 ChatGPT被瑞银(UBS)评为“有史以来增长最快的消费者应用程序”,于…...
Nginx配置WebSocket(WS)和WebSocket Secure(WSS)的完整指南
😀点点关注~ 😀点点关注~ 😀点点关注~ Nginx是一款广泛使用的高性能Web服务器和反向代理服务器。除了传统的HTTP和HTTPS协议支持外,Nginx还可以配置WebSocket(WS)和WebSocket Secure(WSS&…...
链表--part 1--链表基础理论(概括)
文章目录 单链表双链表循环链表链表链表的定义删除节点增加节点 首先什么是链表,链表是一种通过指针串联在一起的线性结构,每一个节点由两部分组成,一个是数据域一个是指针域(存放指向下一个节点的指针),最…...
【V2G】电动汽车接入电网优化调度研究(Matlab代码实现)
💥💥💞💞欢迎来到本博客❤️❤️💥💥 🏆博主优势:🌞🌞🌞博客内容尽量做到思维缜密,逻辑清晰,为了方便读者。 ⛳️座右铭&a…...
Excel中时间戳与标准日期格式的互相转换
背景 在excel中将13位毫秒级别的时间戳转换为标准的日期格式(yyyy-mm-dd hh:mm:ss.000),使用如下模板 TEXT(<source_cell>/1000/8640070*36519,"yyyy-mm-dd hh:mm:ss.000") 在excel中将10位秒级别的时间戳转换为标准的日期格式(yyyy-mm-dd hh:mm:ss…...
【Kafka集群】Kafka针对用户做ACL权限控制
在 Kafka 3.3.1 中,可以使用 ACL(Access Control List)控制用户对 topic 的访问权限。以下是一些基本示例: 创建一个名为 my-topic 的 topic 在命令行中执行以下命令创建一个名为 my-topic 的 topic: kafka-topics.…...
国内外数据安全治理框架介绍与分析
本文将介绍和分析:微软 DGPC框架,Gartner 数据安全治理框架 DSG,数据安全能力成熟度模型 DSMM 数据治理与数据安全治理系列文章 https://luozhonghua.blog.csdn.net/article/details/130417106 数据安全治理流程设计_luozhonghua2000的博客-CSDN博客 数据治理解决之道探讨…...
【Nodejs】使用Nodejs搭建HTTP服务,并实现公网远程访问
文章目录 前言1.安装Node.js环境2.创建node.js服务3. 访问node.js 服务4.内网穿透4.1 安装配置cpolar内网穿透4.2 创建隧道映射本地端口 5.固定公网地址 转载自内网穿透工具的文章:使用Nodejs搭建HTTP服务,并实现公网远程访问「内网穿透」 前言 Node.js…...
面试题之介绍自己测试的项目,担任的角色和做出的成果
在测试面试过程中,面试官想要了解一个同学对项目的掌握程度或一些例如沟通总结的软技能情况,该怎么考察呢? 一个具有代表性的题目来了:简单介绍一下自己测试的项目,担任的角色和做出的成果。 一、面试官角度 1、考察是否真正做过该…...
HTB靶机012-Valentine-WP
012-Valentine 靶机IP:10.10.10.79 Scan nmap端口扫描: ┌──(xavier㉿kali)-[~] └─$ sudo nmap -sSV -T4 10.10.10.79 -F Starting Nmap 7.93 ( https://nmap.org ) at 2023-04-29 00:47 CST Nmap scan report for 10.10.10.79 Host is up (0.30s…...
微信小程序nodejs+vue社区居民健康服务系统uniapp
系统分为社区居民,管理员,县区工作员,社区工作员三个角色 县区工作员的主要功能: 1.对社区的工作人员进行添加,修改,删除,查询 2.疫情专栏的信息进行添加,修改,删除&…...
尝试探索水下目标检测,基于yolov5轻量级系列模型n/s/m开发构建海底生物检测系统
其实,水下目标检测相关的项目早在之前就已经做了几个了,但是没有系统性地对比过,感兴趣的话可以先看下之前的文章,如下: 《基于自建数据集【海底生物检测】使用YOLOv5-v6.1/2版本构建目标检测模型超详细教程》 《基于…...
大数据Doris(二十四):Doris数据Insert Into导入方式介绍
文章目录 Doris数据Insert Into导入方式介绍 一、语法及参数 二、案例 三、注意事项 1、关于插入数据量 2、关于insert操作返回结果 3、关于导入任务超时 4、关于Session变量 5、关于数据导入错误 Doris数据Insert Into导入方式介绍 Doris 提供多种数据导入方案&…...
macOS Ventura 13.5beta (22G5027e)发布
系统介绍 黑果魏叔 5 月 20 日消息,苹果今日向 Mac 电脑用户推送了 macOS 13.5 开发者预览版 Beta 更新(内部版本号:22G5027e),本次更新距离上次发布隔了 17 天。 macOS Ventura 带来了台前调度、连续互通相机、Face…...
基于SpringBoot的财务管理系统的设计与实现
背景 财务管理系统能够通过互联网得到广泛的、全面的宣传,让尽可能多的员工了解和熟知财务管理系统的便捷高效,为管理者和员工提供了服务,节省人力、物力和时间,提高工作效率。 系统设计 为了更好的去理清本系统整体思路&#…...
使用OpenCV进行肺炎诊断检测
肺炎是一种由感染引起的严重呼吸道疾病,特别是在高危人群中,可能会出现危及生命的并发症。必须尽快诊断和治疗肺炎,以最大限度地提高患者康复的机会。 诊断过程并不容易,需要一些医学实验室工具和先进的医疗技能,但我们…...
北华大学第九届程序设计竞赛 题解
5.14和队友VP一场,第二次VP,状态明显比第一次好很多,总共A了7题,基本是能做出来的都做出来了,最后还剩下接近2小时的时间。。。。。 A "北华"有几何 思路:数图片中“北华”的数量,直…...
【Java算法题】剑指offer_01数据结构
前言 刷题链接: https://www.nowcoder.com/exam/oj/ta?page2&tpId13&type265 1. 链表 JZ24 反转链表 思路:基本操作,如下所示。 /* public class ListNode {int val;ListNode next null;ListNode(int val) {this.val val;} }…...
第19节 Node.js Express 框架
Express 是一个为Node.js设计的web开发框架,它基于nodejs平台。 Express 简介 Express是一个简洁而灵活的node.js Web应用框架, 提供了一系列强大特性帮助你创建各种Web应用,和丰富的HTTP工具。 使用Express可以快速地搭建一个完整功能的网站。 Expre…...
【机器视觉】单目测距——运动结构恢复
ps:图是随便找的,为了凑个封面 前言 在前面对光流法进行进一步改进,希望将2D光流推广至3D场景流时,发现2D转3D过程中存在尺度歧义问题,需要补全摄像头拍摄图像中缺失的深度信息,否则解空间不收敛…...
React19源码系列之 事件插件系统
事件类别 事件类型 定义 文档 Event Event 接口表示在 EventTarget 上出现的事件。 Event - Web API | MDN UIEvent UIEvent 接口表示简单的用户界面事件。 UIEvent - Web API | MDN KeyboardEvent KeyboardEvent 对象描述了用户与键盘的交互。 KeyboardEvent - Web…...
C++八股 —— 单例模式
文章目录 1. 基本概念2. 设计要点3. 实现方式4. 详解懒汉模式 1. 基本概念 线程安全(Thread Safety) 线程安全是指在多线程环境下,某个函数、类或代码片段能够被多个线程同时调用时,仍能保证数据的一致性和逻辑的正确性…...
九天毕昇深度学习平台 | 如何安装库?
pip install 库名 -i https://pypi.tuna.tsinghua.edu.cn/simple --user 举个例子: 报错 ModuleNotFoundError: No module named torch 那么我需要安装 torch pip install torch -i https://pypi.tuna.tsinghua.edu.cn/simple --user pip install 库名&#x…...
2025季度云服务器排行榜
在全球云服务器市场,各厂商的排名和地位并非一成不变,而是由其独特的优势、战略布局和市场适应性共同决定的。以下是根据2025年市场趋势,对主要云服务器厂商在排行榜中占据重要位置的原因和优势进行深度分析: 一、全球“三巨头”…...
安全突围:重塑内生安全体系:齐向东在2025年BCS大会的演讲
文章目录 前言第一部分:体系力量是突围之钥第一重困境是体系思想落地不畅。第二重困境是大小体系融合瓶颈。第三重困境是“小体系”运营梗阻。 第二部分:体系矛盾是突围之障一是数据孤岛的障碍。二是投入不足的障碍。三是新旧兼容难的障碍。 第三部分&am…...
深度剖析 DeepSeek 开源模型部署与应用:策略、权衡与未来走向
在人工智能技术呈指数级发展的当下,大模型已然成为推动各行业变革的核心驱动力。DeepSeek 开源模型以其卓越的性能和灵活的开源特性,吸引了众多企业与开发者的目光。如何高效且合理地部署与运用 DeepSeek 模型,成为释放其巨大潜力的关键所在&…...
spring Security对RBAC及其ABAC的支持使用
RBAC (基于角色的访问控制) RBAC (Role-Based Access Control) 是 Spring Security 中最常用的权限模型,它将权限分配给角色,再将角色分配给用户。 RBAC 核心实现 1. 数据库设计 users roles permissions ------- ------…...
TJCTF 2025
还以为是天津的。这个比较容易,虽然绕了点弯,可还是把CP AK了,不过我会的别人也会,还是没啥名次。记录一下吧。 Crypto bacon-bits with open(flag.txt) as f: flag f.read().strip() with open(text.txt) as t: text t.read…...

