`

disconf源码解读

阅读更多
disconf 主要分为三个项目:
    1-disconf.core   主要是提供助手类http的resful 重试等等,zk wather封装,加强了重试机制,做的东西很薄。
   2-disconf.client  强依赖 spring,提供了 扫包,自定义annotation的解析装配,切面逻辑处理aspectj,获取远端配置,并落地  做的东西比较多  依赖也很多。
   3-disconf.web   是后台管理的web应用,spring mvc restful  api实现,前后端分离的开发模式,提供登录,后台管理的功能,业务的东西多一点,可能因为开源的原因,好多有些小功能上的bug,并没有提供权限管理的功能。


问题:private Map<String, DisconfCenterFile> confFileMap = new HashMap<String, DisconfCenterFile>();

内部实现是一个hashMap


"main" prio=5 tid=0x00007fa423805800 nid=0x1703 runnable [0x0000700000219000]
   java.lang.Thread.State: RUNNABLE
at java.util.HashMap.addEntry(HashMap.java:884)
at java.util.HashMap.put(HashMap.java:505)
at com.baidu.disconf.client.common.model.DisconfCenterFile.getKV(DisconfCenterFile.java:134)
at com.baidu.disconf.client.usertools.impl.DisconfDataGetterDefaultImpl.getByFile(DisconfDataGetterDefaultImpl.java:28)
at com.baidu.disconf.client.usertools.DisconfDataGetter.getByFile(DisconfDataGetter.java:22)
at com.example.disconf.demo.task.DisconfDemoTask$1.run(DisconfDemoTask.java:80)
at java.util.concurrent.ThreadPoolExecutor$CallerRunsPolicy.rejectedExecution(ThreadPoolExecutor.java:2025)
at java.util.concurrent.ThreadPoolExecutor.reject(ThreadPoolExecutor.java:821)
at java.util.concurrent.ThreadPoolExecutor.execute(ThreadPoolExecutor.java:1372)
at com.example.disconf.demo.task.DisconfDemoTask.run(DisconfDemoTask.java:77)
at com.example.disconf.demo.DisconfDemoMain.main(DisconfDemoMain.java:36)



aspctj 
"main" prio=5 tid=0x00007fd6ac007000 nid=0x1703 runnable [0x0000700000219000]
   java.lang.Thread.State: RUNNABLE
at java.lang.Class.forName0(Native Method)
at java.lang.Class.forName(Class.java:274)
at org.aspectj.weaver.reflect.Java15AnnotationFinder.getAnnotationFromMember(Java15AnnotationFinder.java:100)
at org.aspectj.weaver.reflect.ReflectionVar.getBindingAtJoinPoint(ReflectionVar.java:162)
at org.aspectj.weaver.reflect.ShadowMatchImpl.getPointcutParameters(ShadowMatchImpl.java:108)
at org.aspectj.weaver.reflect.ShadowMatchImpl.matchesJoinPoint(ShadowMatchImpl.java:88)
at org.springframework.aop.aspectj.AspectJExpressionPointcut.matches(AspectJExpressionPointcut.java:336)
at org.springframework.aop.framework.ReflectiveMethodInvocation.proceed(ReflectiveMethodInvocation.java:167)
at org.springframework.aop.interceptor.ExposeInvocationInterceptor.invoke(ExposeInvocationInterceptor.java:92)
at org.springframework.aop.framework.ReflectiveMethodInvocation.proceed(ReflectiveMethodInvocation.java:179)
at org.springframework.aop.framework.CglibAopProxy$DynamicAdvisedInterceptor.intercept(CglibAopProxy.java:653)
at com.example.disconf.demo.config.CodeConfig$$EnhancerBySpringCGLIB$$2495de40.getCodeError(<generated>)
at com.example.disconf.demo.task.DisconfDemoTask.run(DisconfDemoTask.java:71)
at com.example.disconf.demo.DisconfDemoMain.main(DisconfDemoMain.java:36)



java.lang.Thread.State: RUNNABLE
at sun.reflect.Reflection.getCallerClass(Native Method)
at java.lang.Class.getDeclaredFields(Class.java:1810)
at com.baidu.disconf.client.store.aspect.DisconfAspectJ.decideAccess(DisconfAspectJ.java:60)
at sun.reflect.GeneratedMethodAccessor5.invoke(Unknown Source)
at sun.reflect.DelegatingMethodAccessorImpl.invoke(DelegatingMethodAccessorImpl.java:43)
at java.lang.reflect.Method.invoke(Method.java:606)
at org.springframework.aop.aspectj.AbstractAspectJAdvice.invokeAdviceMethodWithGivenArgs(AbstractAspectJAdvice.java:621)
at org.springframework.aop.aspectj.AbstractAspectJAdvice.invokeAdviceMethod(AbstractAspectJAdvice.java:610)
at org.springframework.aop.aspectj.AspectJAroundAdvice.invoke(AspectJAroundAdvice.java:68)
at org.springframework.aop.framework.ReflectiveMethodInvocation.proceed(ReflectiveMethodInvocation.java:168)
at org.springframework.aop.interceptor.ExposeInvocationInterceptor.invoke(ExposeInvocationInterceptor.java:92)
at org.springframework.aop.framework.ReflectiveMethodInvocation.proceed(ReflectiveMethodInvocation.java:179)
at org.springframework.aop.framework.CglibAopProxy$DynamicAdvisedInterceptor.intercept(CglibAopProxy.java:653)
at com.example.disconf.demo.config.JedisConfig$$EnhancerBySpringCGLIB$$ce8fc02a.getPort(<generated>)
at com.example.disconf.demo.task.DisconfDemoTask.run(DisconfDemoTask.java:70)
at com.example.disconf.demo.DisconfDemoMain.main(DisconfDemoMain.java:36)

DISCCONF本身代码写的很糟糕,使用过程中经常的发生问题,不推荐使用。
分享到:
评论

相关推荐

    TMS320F28x源码解读 程序

    《TMS320F28x源码解读——深入理解数字信号处理器的精髓》 在数字信号处理领域,TMS320F28x系列芯片因其高性能、低功耗的特点,被广泛应用于各种复杂系统中,如工业自动化、电力控制、通信设备等。这些系统的核心...

    Postgresql源码解读.docx

    4500页的源码解读 光是SELECT语句相关实现,就阐述了300多页 看完了你就是postgreSQL达人了 章节明细,需要精读那个功能点就仔细看

    Netty5.0架构剖析和源码解读.pdf

    Netty5.0架构剖析和源码解读 本文档主要讲述了Netty5.0架构剖析和源码解读,涵盖了Netty的架构、源码分析、NIO入门等方面的知识点。 概述 JAVA 的 IO 演进是一个长期的过程,从传统的 BIO 通信到 NIO 的出现,都...

    源码解读:参照管理系统的功能实现.pptx

    源码解读是软件开发中的一项重要技能,它涉及到对程序源代码的深入理解和分析,以揭示系统的功能实现和设计思路。在《源码解读的基本原理》中,我们了解到源码解读能够帮助我们理解系统的运作机制,提升编程能力,并...

    菜鸟 Spring 源码解读 推荐流程

    首先,源码解读对于任何开发者来说都是提升技术能力的重要途径。通过阅读源码,我们可以更直观地了解框架的工作原理,从而更好地利用它。Spring框架的设计理念和实现方式对许多其他Java框架产生了深远影响,因此深入...

    Resin源码解读1

    《Resin源码解读》 Resin,作为一个高性能的Java应用服务器,其源码解析对于我们深入理解Web服务器的运行机制和优化技术具有重要的价值。本文将从日志分析、运行时调试、网络模型以及线程池模型四个方面进行深入...

    高清Netty5.0架构剖析和源码解读

    Netty5.0 架构剖析和源码解读 作者:李林锋 版权所有 email neu_lilinfeng@ © Netty5.0 架构剖析和源码解读1 1. 概述2 1.1. JAVA 的IO演进2 1.1.1. 传统BIO通信的弊端2 1.1.2. Linux 的网络IO模型简介4 1.1.3. IO...

    Spark-2.3.1源码解读

    Spark-2.3.1源码解读。 Spark Core源码阅读 Spark Context 阅读要点 Spark的缓存,变量,shuffle数据等清理及机制 Spark-submit关于参数及部署模式的部分解析 GroupByKey VS ReduceByKey OrderedRDDFunctions...

    STM32开发板三轴联动插补源码解读,直线圆弧加减速功能解析,基于STM32F1与STM32F4源码研究,附带大量中文注释,助力学习与实践应用,基于STM32开发板的三轴联动插补直线圆弧源码解读及基于

    STM32开发板三轴联动插补源码解读,直线圆弧加减速功能解析,基于STM32F1与STM32F4源码研究,附带大量中文注释,助力学习与实践应用,基于STM32开发板的三轴联动插补直线圆弧源码解读及基于STM32F系列加速减速功能...

    VxWorks源码解读.rar

    VxWorks以其高效、确定性和微秒级的响应时间著称,它的源码解读对于我们理解其工作原理、优化系统性能以及进行定制化开发具有重要意义。 首先,我们要了解VxWorks的核心组成部分,包括内核(Kernel)、文件系统...

    PX4源码解读

    在《PX4源码解读》中,我们可以深入探讨这个系统的核心组成部分和工作原理。首先,PX4的架构由几个关键模块组成: 1. **硬件抽象层**:这层代码确保了PX4可以适应各种硬件平台,包括不同类型的传感器、处理器和通信...

    第三节-springboot源码解析-王炸篇.pdf

    Spring Boot源码解析是深入了解Spring Boot内部工作原理和机制的重要途径。通过源码分析,开发者可以更好地理解Spring Boot的自动装配、启动流程以及如何自定义启动器。Spring Boot的自动装配原理涉及到Spring Boot...

    JEECMS2源码的解读

    JEECMS2源码的解读,介绍JEECMS2源码的结构,开发流程等

    OSG核心源码解析_osg_OSG核心源码解析_

    这本书旨在帮助开发者深入理解OSG的内部工作原理,通过详细解读源码,提升开发者的技能和应用能力。 OSG的核心源码解析主要包括以下几个关键部分: 1. **数据结构与设计模式**:OSG中大量使用了面向对象的设计模式...

    spring-boot-source-analysis-code:SpringBoot源码解读与原理分析小册测试代码-源码解析

    掘金《 SpringBoot源码解读与原理分析》小册测试和演示代码。 当初我写小册的时候,一直用的这一个工程,所以pom一直在变化(逃...),当然也由于研究原理通常最好是动手实践,所以我没做那种现成的,只要克隆下来就...

    HashMap之put方法源码解读.docx

    HashMap 之 put 方法源码解读 HashMap 是 Java 中一种常用的数据结构,用于存储键值对。其中,put 方法是 HashMap 中最重要的方法之一,负责将键值对存储到HashMap 中。在本文中,我们将对 HashMap 的 put 方法的...

    PyTorch 源码解读之分布式训练

    PyTorch 源码解读之分布式训练

    vue.2.5.1.js源码中关于生命周期钩子的源码解读

    vue.2.5.1.js源码中关于生命周期钩子的源码解读

    torchvision源码解读之transform.docx

    torchvision源码解读之transform.docx

Global site tag (gtag.js) - Google Analytics