从零手写实现 nginx-15-nginx.conf 解析处理转换为 POJO

2024-06-11 09:44

本文主要是介绍从零手写实现 nginx-15-nginx.conf 解析处理转换为 POJO,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

前言

大家好,我是老马。很高兴遇到你。

我们为 java 开发者实现了 java 版本的 nginx

https://github.com/houbb/nginx4j

如果你想知道 servlet 如何处理的,可以参考我的另一个项目:

手写从零实现简易版 tomcat minicat

手写 nginx 系列

如果你对 nginx 原理感兴趣,可以阅读:

从零手写实现 nginx-01-为什么不能有 java 版本的 nginx?

从零手写实现 nginx-02-nginx 的核心能力

从零手写实现 nginx-03-nginx 基于 Netty 实现

从零手写实现 nginx-04-基于 netty http 出入参优化处理

从零手写实现 nginx-05-MIME类型(Multipurpose Internet Mail Extensions,多用途互联网邮件扩展类型)

从零手写实现 nginx-06-文件夹自动索引

从零手写实现 nginx-07-大文件下载

从零手写实现 nginx-08-范围查询

从零手写实现 nginx-09-文件压缩

从零手写实现 nginx-10-sendfile 零拷贝

从零手写实现 nginx-11-file+range 合并

从零手写实现 nginx-12-keep-alive 连接复用

从零手写实现 nginx-13-nginx.conf 配置文件介绍

从零手写实现 nginx-14-nginx.conf 和 hocon 格式有关系吗?

从零手写实现 nginx-15-nginx.conf 如何通过 java 解析处理?

从零手写实现 nginx-16-nginx 支持配置多个 server

从零手写实现 nginx-17-nginx 默认配置优化

从零手写实现 nginx-18-nginx 请求头+响应头操作

从零手写实现 nginx-19-nginx cors

从零手写实现 nginx-20-nginx 占位符 placeholder

目标

上一节我们定义了配置的标准 POJO

这一节课我们来把 nginx.conf 文件解析为标准的 pojo

实现思路

通过三方库直接解析处理配置文件。

核心代码

package com.github.houbb.nginx4j.config.load;import com.github.houbb.heaven.util.lang.StringUtil;
import com.github.houbb.heaven.util.util.CollectionUtil;
import com.github.houbb.nginx4j.bs.NginxUserConfigBs;
import com.github.houbb.nginx4j.bs.NginxUserServerConfigBs;
import com.github.houbb.nginx4j.config.NginxUserConfig;
import com.github.houbb.nginx4j.config.NginxUserServerConfig;
import com.github.houbb.nginx4j.constant.NginxUserConfigDefaultConst;
import com.github.houbb.nginx4j.constant.NginxUserServerConfigDefaultConst;
import com.github.odiszapc.nginxparser.NgxBlock;
import com.github.odiszapc.nginxparser.NgxConfig;
import com.github.odiszapc.nginxparser.NgxEntry;
import com.github.odiszapc.nginxparser.NgxParam;import java.io.IOException;
import java.util.List;/*** @since 0.13.0*/
public  class NginxUserConfigLoaderConfigFile extends AbstractNginxUserConfigLoader {private final String filePath;public NginxUserConfigLoaderConfigFile(String filePath) {this.filePath = filePath;}protected void fillBasicInfo(final NginxUserConfigBs configBs,final NgxConfig conf) {// 基本信息configBs.httpPid(getHttpPid(conf));}private String getHttpPid(final NgxConfig conf) {// 基本信息NgxParam pidParam = conf.findParam("pid");if(pidParam != null) {return pidParam.getValue();}return NginxUserConfigDefaultConst.HTTP_PID;}/*** <pre>*         listen 80;  # 监听80端口*         server_name example.com;  # 服务器域名**         # 单独为这个 server 启用 sendfile*         sendfile on;**         # 静态文件的根目录*         root /usr/share/nginx/html;  # 静态文件存放的根目录*         index index.html index.htm;  # 默认首页**         # 如果需要为这个 server 单独配置 gzip,可以覆盖全局配置*         gzip on;*         gzip_disable "msie6";*         gzip_vary on;*         gzip_proxied any;*         gzip_comp_level 6;*         gzip_buffers 16 8k;*         gzip_http_version 1.1;*         gzip_types text/plain text/css application/json application/javascript text/xml application/xml application/xml+rss text/javascript;** </pre>* @param configBs 配置* @param conf 文件信息*/protected void fillServerInfo(final NginxUserConfigBs configBs,final NgxConfig conf) {// 首先获取 blockList<NgxEntry> servers = conf.findAll(NgxConfig.BLOCK, "http", "server"); // 示例3if(CollectionUtil.isNotEmpty(servers)) {for (NgxEntry entry : servers) {NginxUserServerConfigBs serverConfigBs = NginxUserServerConfigBs.newInstance();NgxBlock serverBlock = (NgxBlock) entry;String name = serverBlock.getName();int httpServerPort = getHttpServerListen(conf, serverBlock);String httpServerName = getHttpServerName(conf, serverBlock);String httpServerRoot = getHttpServerRoot(conf, serverBlock);List<String> httpIndexList = getHttpServerIndexList(conf, serverBlock);// sendfile on;String sendFile = getHttpServerSendFile(conf, serverBlock);//gzipString gzip = getHttpServerGzip(conf, serverBlock);long gzipMinLen = getHttpServerGzipMinLen(conf, serverBlock);List<String> gzipTypes = getHttpServerGzipTypes(conf, serverBlock);serverConfigBs.httpServerName(httpServerName).httpServerListen(httpServerPort).httpServerRoot(httpServerRoot).httpServerIndexList(httpIndexList).sendFile(sendFile).gzip(gzip).gzipMinLength(gzipMinLen).gzipTypes(gzipTypes);NginxUserServerConfig serverConfig = serverConfigBs.build();configBs.addServerConfig(httpServerPort, httpServerName, serverConfig);}}}private List<String> getHttpServerGzipTypes(final NgxConfig conf, final NgxBlock serverBlock) {// valueNgxParam param = serverBlock.findParam("gzip_types");if(param != null) {return StringUtil.splitToList(param.getValue(), " ");}return NginxUserServerConfigDefaultConst.gzipTypes;}private long getHttpServerGzipMinLen(final NgxConfig conf, final NgxBlock serverBlock) {// valueNgxParam param = serverBlock.findParam("gzip_min_len");if(param != null) {return Long.valueOf(param.getValue());}return NginxUserServerConfigDefaultConst.gzipMinLength;}private String getHttpServerGzip(final NgxConfig conf, final NgxBlock serverBlock) {// valueNgxParam param = serverBlock.findParam("gzip");if(param != null) {return param.getValue();}return NginxUserServerConfigDefaultConst.gzip;}private List<String> getHttpServerIndexList(final NgxConfig conf, final NgxBlock serverBlock) {// valueNgxParam param = serverBlock.findParam("index");if(param != null) {return StringUtil.splitToList(param.getValue(), " ");}return NginxUserServerConfigDefaultConst.httpServerIndexList;}private String getHttpServerSendFile(final NgxConfig conf, final NgxBlock serverBlock) {// valueNgxParam param = serverBlock.findParam("sendfile");if(param != null) {return param.getValue();}return NginxUserServerConfigDefaultConst.sendFile;}private String getHttpServerRoot(final NgxConfig conf, final NgxBlock serverBlock) {// valueNgxParam param = serverBlock.findParam("root");if(param != null) {return param.getValue();}return NginxUserServerConfigDefaultConst.httpServerRoot;}private int getHttpServerListen(final NgxConfig conf, final NgxBlock serverBlock) {// valueNgxParam listenParam = serverBlock.findParam("listen");if(listenParam != null) {String value = listenParam.getValue();List<String> valueList = StringUtil.splitToList(value, " ");return Integer.parseInt(valueList.get(0));}return NginxUserServerConfigDefaultConst.httpServerListen;}private String getHttpServerName(final NgxConfig conf, final NgxBlock serverBlock) {// valueNgxParam param = serverBlock.findParam("server_name");if(param != null) {return param.getValue();}return NginxUserServerConfigDefaultConst.httpServerName;}@Overrideprotected NginxUserConfig doLoad() {NgxConfig conf = null;try {NginxUserConfigBs configBs = NginxUserConfigBs.newInstance();conf = NgxConfig.read(filePath);//1. basicfillBasicInfo(configBs, conf);//2. server 信息fillServerInfo(configBs, conf);// 返回return configBs.build();} catch (IOException e) {throw new RuntimeException(e);}}}

启动类

NginxUserConfig nginxUserConfig = NginxUserConfigLoaders.configFile("D:\\github\\nginx4j\\src\\main\\resources\\nginx.conf").load();Nginx4jBs.newInstance().nginxUserConfig(nginxUserConfig).init().start();

小结

整体而言 nginx.conf 的配置非常灵活。还有很多特性需要持续优化支持。

比如默认的全局配置,单独的 server 配置重载。

这篇关于从零手写实现 nginx-15-nginx.conf 解析处理转换为 POJO的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!


原文地址:
本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.chinasem.cn/article/1050822

相关文章

C/C++中OpenCV 矩阵运算的实现

《C/C++中OpenCV矩阵运算的实现》本文主要介绍了C/C++中OpenCV矩阵运算的实现,包括基本算术运算(标量与矩阵)、矩阵乘法、转置、逆矩阵、行列式、迹、范数等操作,感兴趣的可以了解一下... 目录矩阵的创建与初始化创建矩阵访问矩阵元素基本的算术运算 ➕➖✖️➗矩阵与标量运算矩阵与矩阵运算 (逐元

C/C++的OpenCV 进行图像梯度提取的几种实现

《C/C++的OpenCV进行图像梯度提取的几种实现》本文主要介绍了C/C++的OpenCV进行图像梯度提取的实现,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的... 目录预www.chinasem.cn备知识1. 图像加载与预处理2. Sobel 算子计算 X 和 Y

C/C++和OpenCV实现调用摄像头

《C/C++和OpenCV实现调用摄像头》本文主要介绍了C/C++和OpenCV实现调用摄像头,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友们下面随着小编来一... 目录准备工作1. 打开摄像头2. 读取视频帧3. 显示视频帧4. 释放资源5. 获取和设置摄像头属性

c/c++的opencv图像金字塔缩放实现

《c/c++的opencv图像金字塔缩放实现》本文主要介绍了c/c++的opencv图像金字塔缩放实现,通过对原始图像进行连续的下采样或上采样操作,生成一系列不同分辨率的图像,具有一定的参考价值,感兴... 目录图像金字塔简介图像下采样 (cv::pyrDown)图像上采样 (cv::pyrUp)C++ O

c/c++的opencv实现图片膨胀

《c/c++的opencv实现图片膨胀》图像膨胀是形态学操作,通过结构元素扩张亮区填充孔洞、连接断开部分、加粗物体,OpenCV的cv::dilate函数实现该操作,本文就来介绍一下opencv图片... 目录什么是图像膨胀?结构元素 (KerChina编程nel)OpenCV 中的 cv::dilate() 函

Python使用FFmpeg实现高效音频格式转换工具

《Python使用FFmpeg实现高效音频格式转换工具》在数字音频处理领域,音频格式转换是一项基础但至关重要的功能,本文主要为大家介绍了Python如何使用FFmpeg实现强大功能的图形化音频转换工具... 目录概述功能详解软件效果展示主界面布局转换过程截图完成提示开发步骤详解1. 环境准备2. 项目功能结

SpringBoot使用ffmpeg实现视频压缩

《SpringBoot使用ffmpeg实现视频压缩》FFmpeg是一个开源的跨平台多媒体处理工具集,用于录制,转换,编辑和流式传输音频和视频,本文将使用ffmpeg实现视频压缩功能,有需要的可以参考... 目录核心功能1.格式转换2.编解码3.音视频处理4.流媒体支持5.滤镜(Filter)安装配置linu

在Spring Boot中实现HTTPS加密通信及常见问题排查

《在SpringBoot中实现HTTPS加密通信及常见问题排查》HTTPS是HTTP的安全版本,通过SSL/TLS协议为通讯提供加密、身份验证和数据完整性保护,下面通过本文给大家介绍在SpringB... 目录一、HTTPS核心原理1.加密流程概述2.加密技术组合二、证书体系详解1、证书类型对比2. 证书获

Druid连接池实现自定义数据库密码加解密功能

《Druid连接池实现自定义数据库密码加解密功能》在现代应用开发中,数据安全是至关重要的,本文将介绍如何在​​Druid​​连接池中实现自定义的数据库密码加解密功能,有需要的小伙伴可以参考一下... 目录1. 环境准备2. 密码加密算法的选择3. 自定义 ​​DruidDataSource​​ 的密码解密3

使用Python实现Windows系统垃圾清理

《使用Python实现Windows系统垃圾清理》Windows自带的磁盘清理工具功能有限,无法深度清理各类垃圾文件,所以本文为大家介绍了如何使用Python+PyQt5开发一个Windows系统垃圾... 目录一、开发背景与工具概述1.1 为什么需要专业清理工具1.2 工具设计理念二、工具核心功能解析2.