• XML文件解析实践(DOM解析)


    昨天完成了基于DOM的XML文件解析类,今天赶紧实践了一下,不得不说,实践中的坑还是很多的。

    本来这个项目就是为了规范各个服务在使用MySQL数据库时候的配置项,由于之前我接触的都是Java服务,对于这些服务也算比较了解,大家的配置项基本还算是保持一致,今天解析所有服务的配置项,大开眼界。

    • 不看不知道,世界真奇妙。

    首先是配置项的层级结构,一般来讲,一个root作为根节点,然后子节点都是各个服务节点,在服务节点下面是服务版本节点,然后是changeunchange两个节点,然后是具体的内容。奈何人算不如天算,算来算去不如狗带。

    先看图:

    zk配置截图

    居然所有节点都是zknode,这是其一,在每个版本下面还有不同的配置模块,然后子节点配置具体信息。

    zk配置截图

    居然还有没有value的配置项,我真实要狗带了。

    然后就是MySQL配置,简直刷新世界观。

    下面是我从XML总的配置文件截取的内容:

    
                    <zknode name="datadb.username" value="****"/>
                    <zknode name="db.host.r" value="****"/>
                    <zknode name="dbdata.host.w" value="*"/>
                    <zknode name="datadb.port" value="*"/>
                    <zknode name="datadb.databasev3" value="*****"/>
                    <zknode name="datadb.host.w" value="*****"/>
    
    
                   <zknode name="v3.db" value="******"/>
                    <zknode name="v3.user" value="******"/>
                    <zknode name="work.db" value="******"/>
                    <zknode name="work.host" value="******"/>
                    <zknode name="v3.passwd" value="******"/>
    
                    <zknode name="DB_CONNECTION" value="******"/>
                    <zknode name="DB_HOST" value="******"/>
                    <zknode name="DB_DATABASE" value="******"/>
                    <zknode name="DB_PASSWORD" value="******"/>
    
                    <zknode name="mysql.DB_DATABASE" value="***"/>
                    <zknode name="redis.REDIS_PORT" value="***"/>
    
                    <zknode name="ds.druid.username" value="****"/>
                    <zknode name="ds.druid.url"  value="****"/>
    

    此处省略100种数据库配置

    痛定思痛,该吐槽已经吐槽完了,活儿还是得干完的。经过不断尝试,终于完成了一种解决的脚本。

    我觉得需要一个宽屏显示器了。

    
    package com.fun.ztest.groovy
    
    import com.fun.frame.httpclient.FanLibrary
    import com.fun.utils.XMLUtil
    import org.slf4j.Logger
    import org.slf4j.LoggerFactory
    
    class Td extends FanLibrary {
    
        private static Logger logger = LoggerFactory.getLogger(Td.class)
    
        public static void main(String[] args) {
    
    
            def xml = XMLUtil.parseXml("/Users/fv/Downloads/d.xml", "root")
            xml.get(0).getChildren().each {
                logger.error("服务名:{}", it.getAttrs().get(0).getValue())
                def children = it.getChildren()
                children.each {
                    def attr1 = it.getAttrs()
                    def name = attr1.get(0).getValue()
                    if (name ==~ /[vV]d.d+/) {
                        logger.error("zk版本:${name}")
                        def children1 = it.getChildren()
                        children1.each {
                            def children2 = it.getChildren()
                            children2.each {
                                def attrs = it.getAttrs()
                                if (attrs.size() > 1) {
                                    def var = attrs.get(0).getValue()
                                    def value = attrs.get(1).getValue()
                                    if (!(value ==~ /d+/)) {
                                        if (var.contains("druid") || var.contains("db") || var.contains("user") || value.contains("mysql") || value.contains("neworiental") || value.contains("neworiental")) {
                                            if (!value.contains("{") && !value.contains(".txt") && !var.contains("service") && !var.contains("maill") && !var.contains("host") && !var.contains("driver") && !var.contains("filters") && !var.contains("center") && !var.contains("rabbit") && !var.contains("order") && !value.contains("http"))
                                                logger.info("key: {},value: {}", var, value)
                                        }
                                    }
                                }
                            }
                        }
                    }
                }
            }
    
            testOver()
        }
    
    
    }
    
    

    公众号FunTester首发,原创分享爱好者,腾讯云和掘金社区首页推荐,知乎七级原创作者,欢迎关注、交流,禁止第三方擅自转载。

    FunTester热文精选

  • 相关阅读:
    基于windows的mysql读写分离和amoeba配置
    windows环境下mysql主从配置
    Mysql主从报错锦集
    Nginx流控
    windows_windows下的rsync
    Kafka+ZooKeeper高可用集群部署
    通过Nginx、Consul、Upsync实现动态负载均衡和服务平滑发布
    Redis性能指标监控
    MongoDB用户权限管理
    ZooKeeper原理详解及常用操作
  • 原文地址:https://www.cnblogs.com/FunTester/p/13760275.html
Copyright © 2020-2023  润新知