最近工程开发遇到一个需求:用Java去解析并编辑nginx.conf

在github上找到nginx-java-parser工具,项目地址:https://github.com/odiszapc/nginx-java-parser

解析nginx.conf过程可以参考该项目的README.md

下面举个列子说明一下该如何编辑nginx.conf。

定义一个pojo

import com.alibaba.fastjson.JSONArray;
import com.google.common.base.Strings;
import lombok.Data; @Data
public class WebHost {
private long id;
private String host;
private String protocol;
private String name;
}

1、添加nginx配置

     public boolean addWebToNginxConfig(WebHost webHost, String fileName) {
if (webHost == null || Strings.isNullOrEmpty(fileName)) {
return false;
}
try {
NgxConfig ngxConfig = NgxConfig.read(fileName);
NgxBlock ngxBlockHttp = ngxConfig.findBlock("http");
NgxBlock ngxBlockWeb = new NgxBlock();
ngxBlockWeb.addValue("server");
ngxBlockHttp.addEntry(ngxBlockWeb);
if ("https".equals(webHost.getProtocol())) {
NgxParam ngxParam = new NgxParam();
ngxParam.addValue("listen 443 ssl");
ngxBlockWeb.addEntry(ngxParam);
ngxParam = new NgxParam();
ngxParam.addValue(String.format("server_name %s", webHost.getHost()));
ngxBlockWeb.addEntry(ngxParam); String virtualServerName = webHost.formatName();
ngxParam = new NgxParam();
ngxParam.addValue(String.format("ssl_certificate /etc/nginx/cert/%s.cert", virtualServerName));
ngxBlockWeb.addEntry(ngxParam);
ngxParam = new NgxParam();
ngxParam.addValue(String.format("ssl_certificate_key /etc/nginx/key/%s.key", virtualServerName));
ngxBlockWeb.addEntry(ngxParam);
} else {
NgxParam ngxParam = new NgxParam();
ngxParam.addValue("listen 80");
ngxBlockWeb.addEntry(ngxParam);
ngxParam = new NgxParam();
ngxParam.addValue(String.format("server_name %s", webHost.getHost()));
ngxBlockWeb.addEntry(ngxParam);
} NgxBlock ngxBlockLocation = new NgxBlock();
ngxBlockLocation.addValue("location");
ngxBlockLocation.addValue("/");
NgxParam ngxParam = new NgxParam();
ngxParam.addValue("proxy_pass http://backend_http");
ngxBlockLocation.addEntry(ngxParam);
ngxParam = new NgxParam();
ngxParam.addValue("proxy_set_header Host $host");
ngxBlockLocation.addEntry(ngxParam);
ngxParam = new NgxParam();
ngxParam.addValue("proxy_set_header X-Real-IP $remote_addr");
ngxBlockLocation.addEntry(ngxParam);
ngxParam = new NgxParam();
ngxParam.addValue("proxy_set_header X-Forwarded-For $proxy_add_x_forwarded_for");
ngxBlockLocation.addEntry(ngxParam);
ngxBlockWeb.addEntry(ngxBlockLocation); String content = new NgxDumper(ngxConfig).dump();
log.info("{}", content);
return true;
} catch (IOException e) {
log.warn("write nginx.conf to file catch IOException!", e);
}
return false;
}

添加结果示例:

user nginx;
worker_processes auto;
error_log /var/log/nginx/error.log warn;
pid /var/run/nginx.pid;
events {
worker_connections 1025;
}
http {
include /etc/nginx/mime.types;
default_type application/octet-stream;
log_format main '$remote_addr - $remote_user [$time_local] "$request" ' '$status $body_bytes_sent "$http_referer" ' '"$http_user_agent" "$http_x_forwarded_for"';
access_log /var/log/nginx/access.log main;
sendfile on;
keepalive_timeout 65;
#gzip on;
upstream backend_http {
server 1.1.1.1:80 weight=2;
server 2.2.2.2:80 weight=2;
}
upstream backend_https {
server 1.1.1.1:443 weight=2;
server 2.2.2.2:443 weight=2;
}
server {
listen 80;
server_name aaaa.com;
location / {
proxy_pass http://backend_http;
proxy_set_header Host $host;
proxy_set_header X-Real-IP $remote_addr;
proxy_set_header X-Forwarded-For $proxy_add_x_forwarded_for;
}
}
server {
listen 443 ssl;
server_name eeee.com;
ssl_certificate /etc/nginx/cert/eeee.com.https.cert;
ssl_certificate_key /etc/nginx/key/eeee.com.https.key;
location / {
proxy_pass http://backend_http;
proxy_set_header Host $host;
proxy_set_header X-Real-IP $remote_addr;
proxy_set_header X-Forwarded-For $proxy_add_x_forwarded_for;
}
}
}

2、删除nginx配置

     public boolean deleteWebFromNginxConfig(String host, String fileName) {
if (Strings.isNullOrEmpty(host) || Strings.isNullOrEmpty(fileName)) {
return false;
}
try {
NgxConfig ngxConfig = NgxConfig.read(fileName);
NgxBlock ngxBlockHttp = ngxConfig.findBlock("http");
List<NgxEntry> serverList = ngxBlockHttp.findAll(NgxConfig.BLOCK,"server");
for (NgxEntry ngxEntry : serverList) {
NgxBlock ngxBlock = (NgxBlock) ngxEntry;
NgxParam ngxParam = ngxBlock.findParam("server_name");
if (host.equals(ngxParam.getValue())) {
ngxBlockHttp.remove(ngxBlock);
}
}
String content = new NgxDumper(ngxConfig).dump();
log.info("{}", content);
return true;
} catch (IOException e) {
log.warn("write nginx.conf to file catch IOException!", e);
}
return false;
}

JAVA 解析、编辑nginx.conf的更多相关文章

  1. Nginx的配置文件(nginx.conf)解析和领读官网

    步骤一:vi nginx.conf配置文件,参考本博文的最下面总结,自行去设置 最后nginx.conf内容为 步骤二:每次修改了nginx.conf配置文件后,都要reload下. index.ht ...

  2. Nginx的配置文件nginx.conf解析

    安装openresty的nginx.conf配置文件 0.ng运行的用户和用户组 1.ng进程数,设置为CPU总核心数 2.ng错误日志 3.进程文件,有时ng启动不了,将进程文件删除即可. 4.单进 ...

  3. nginx.conf 配置解析之 server配置

    server{} 包含在http{}内部,每一个server{}都是一个虚拟主机(站点) 以下为nginx.conf配置文件中server{  }部分的内容. server { listen ; // ...

  4. nginx.conf 配置解析之文件结构

    nginx.conf配置文件结构如下: ...... #主要定义nginx的全局配置 events{ #events(事件)块:主要配置网络连接相关 } http{ #http块:代理缓存和日志定义绝 ...

  5. ubuntu 13.04 nginx.conf 配置详解

    1.nginx.conf 文件,路径为:/etc/nginx/agin.conf #使用的用户和组 user www-data; #指定工作衍生进程数(一般等于CPU总核数或总核数的两倍) worke ...

  6. centos7下搭建JAVA项目运行环境。 JAVA+MYSQL+TOMCAT+NGINX

    环境: centos 7 64位 一.配置mysql 5.71.下载mysql源安装包wget http://dev.mysql.com/get/mysql57-community-release-e ...

  7. Linux(7)- Nginx.conf主配置文件、Nginx虚拟主机/访问日志/限制访问IP/错误页面优化、Nginx反向代理、Nginx负载均衡

    一.Nginx.conf主配置文件 Nginx主配置文件conf/nginx.conf是一个纯文本类型的文件,整个配置文件是以区块的形式组织的.一般,每个区块以一对大括号{}来表示开始与结束. 核心模 ...

  8. docker学习(6) docker中搭建java服务及nginx反向代理

    先看下容器规划: 上图中mysql容器的搭建见上篇博客,service1/2为java rest service,创建脚本如下: docker run -d -h service1 \ -v /Use ...

  9. CentOS下配置nginx conf/koi-win为同一文件的各类错误

    今天配置CentOS6.5下安装Nginx + php7 + mysql5.7.15遇到了一些坑.本来家里的电脑在配置环境的时候没有问题,拿去公司的电脑上就是到处报错.不知道是不是人品问题.今晚在家重 ...

随机推荐

  1. ELK 快速指南

    ELK 快速指南 概念 ELK 是什么 ELK 是 elastic 公司旗下三款产品 ElasticSearch .Logstash .Kibana 的首字母组合. ElasticSearch 是一个 ...

  2. 33.Linux-实现U盘自动挂载(详解)

    1.当我们每次插入u盘后,都会自动创键U盘的设备节点/dev/sda%d 这是因为里面调用了device_create()实现的, busybox的mdev机制就会根据主次设备号等信息,在/dev下创 ...

  3. P1457 城堡 The Castle

    轻度中毒 原题 :The Castle 以下为题解部分:明明辣么简单的一道题,硬是搞了1.5h,WTF?以下列出本题的一些要点. 搜索(DFS)嘛,染色嘛,统计大小嘛,很容易想,也很更易处理. 接下来 ...

  4. 调试利器:SSH隧道

    欢迎大家前往腾讯云社区,获取更多腾讯海量技术实践干货哦~ 本文作者:ivweb 吴浩麟 原文出处:IVWEB社区 未经同意,禁止转载 在开发微信公众号或小程序的时候,由于微信平台规则的限制,部分接口需 ...

  5. Git详解及 github与gitlab使用

    1.1 关于版本控制 1.1.1 本地版本控制 本地版本控制系统 许多人习惯用复制整个项目目录的方式来保存不同的版本,或许还会改名加上备份时间以示区别.这么做唯一的 好处就是简单,但是特别容易犯错.有 ...

  6. POJ3624--01背包

    Charm Bracelet Time Limit: 1000MS   Memory Limit: 65536K Total Submissions: 34013   Accepted: 15087 ...

  7. 天梯赛 L3-013 非常弹的球 找规律

    L3-013. 非常弹的球 时间限制 100 ms 内存限制 65536 kB 代码长度限制 8000 B 判题程序 Standard 作者 俞勇(上海交通大学) 刚上高一的森森为了学好物理,买了一个 ...

  8. redis秒杀

    用Redis轻松实现秒杀系统 秒杀系统的架构设计 秒杀系统,是典型的短时大量突发访问类问题.对这类问题,有三种优化性能的思路: 写入内存而不是写入硬盘 异步处理而不是同步处理 分布式处理 用上这三招, ...

  9. PHP求解一个值是否为质数

    /** * 求解一个值是否为质数 * * @param $a * @return int 0是 1不是 */ 1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 function ...

  10. sublime text 3 ctrl+b浏览器启动html

    sublime text 2 和3 都可以快速设置浏览器启动,本人在这里介绍如何不下插件启动浏览器.第一步:打开Tool-->build system  ---> new build sy ...