欧美bbbwbbbw肥妇,免费乱码人妻系列日韩,一级黄片

聊聊Druid register mbean error的問題

 更新時(shí)間:2021年11月19日 11:16:55   作者:ShadowWalker  
這篇文章主要介紹了Druid register mbean error的問題,本文給大家介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或工作具有一定的參考借鑒價(jià)值,需要的朋友可以參考下

key: [com.alibaba.druid.stat.DruidDataSourceStatManager.addDataSource(DruidDataSourceStatManager.java:154)]  register mbean error

在使用數(shù)據(jù)庫連接池時(shí)(本文通用于其他使用jmx mbean的應(yīng)用),運(yùn)行幾天后出現(xiàn)如下錯(cuò)誤

2014/11/18 10:31:00,617 [ERROR] [localhost-startStop-6] [com.alibaba.druid.stat.DruidDataSourceStatManager.addDataSource(DruidDataSourceStatManager.java:154)]  register mbean error
javax.management.InstanceAlreadyExistsException: com.alibaba.druid:type=DruidDataSource,id=Druid MySQL DB pool
        at com.sun.jmx.mbeanserver.Repository.addMBean(Repository.java:453)
        at com.sun.jmx.interceptor.DefaultMBeanServerInterceptor.internal_addObject(DefaultMBeanServerInterceptor.java:1484)
        at com.sun.jmx.interceptor.DefaultMBeanServerInterceptor.registerDynamicMBean(DefaultMBeanServerInterceptor.java:963)
        at com.sun.jmx.interceptor.DefaultMBeanServerInterceptor.registerObject(DefaultMBeanServerInterceptor.java:917)
        at com.sun.jmx.interceptor.DefaultMBeanServerInterceptor.registerMBean(DefaultMBeanServerInterceptor.java:312)
        at com.sun.jmx.mbeanserver.JmxMBeanServer.registerMBean(JmxMBeanServer.java:482)
        at com.alibaba.druid.stat.DruidDataSourceStatManager.addDataSource(DruidDataSourceStatManager.java:152)
        at com.alibaba.druid.pool.DruidDataSource$1.run(DruidDataSource.java:1298)
        at java.security.AccessController.doPrivileged(Native Method)
        at com.alibaba.druid.pool.DruidDataSource.registerMbean(DruidDataSource.java:1294)
        at com.alibaba.druid.pool.DruidDataSource.init(DruidDataSource.java:623)
        at com.longdai.data.ConnectionManagerDruid.<init>(ConnectionManagerDruid.java:68)
        at com.longdai.data.ConnectionManager.getInstance(ConnectionManager.java:86)
        at com.longdai.data.dao.Database.<clinit>(Database.java:22)
        at com.longdai.service.admin.CloseNetWorkService.getNetWorkById(CloseNetWorkService.java:87)
        at com.longdai.service.admin.CloseNetWorkService$$FastClassByCGLIB$$bbdb465c.invoke(<generated>)
        at net.sf.cglib.proxy.MethodProxy.invoke(MethodProxy.java:191)
        at org.springframework.aop.framework.Cglib2AopProxy$CglibMethodInvocation.invokeJoinpoint(Cglib2AopProxy.java:700)
        at org.springframework.aop.framework.ReflectiveMethodInvocation.proceed(ReflectiveMethodInvocation.java:149)
        at com.gozap.services.ServiceMethodInterceptor.invoke(ServiceMethodInterceptor.java:31)
        at org.springframework.aop.framework.ReflectiveMethodInvocation.proceed(ReflectiveMethodInvocation.java:171)
        at org.springframework.aop.interceptor.ExposeInvocationInterceptor.invoke(ExposeInvocationInterceptor.java:89)
        at org.springframework.aop.framework.ReflectiveMethodInvocation.proceed(ReflectiveMethodInvocation.java:171)
        at org.springframework.aop.framework.Cglib2AopProxy$DynamicAdvisedInterceptor.intercept(Cglib2AopProxy.java:635)
        at com.longdai.service.admin.CloseNetWorkService$$EnhancerByCGLIB$$19cbebaf.getNetWorkById(<generated>)
        at com.longdai.system.listener.CloseNetWorkConfigiListener.contextInitialized(CloseNetWorkConfigiListener.java:37)
        at org.apache.catalina.core.StandardContext.listenerStart(StandardContext.java:4791)
        at org.apache.catalina.core.StandardContext.startInternal(StandardContext.java:5285)
        at org.apache.catalina.util.LifecycleBase.start(LifecycleBase.java:150)
        at org.apache.catalina.core.ContainerBase.addChildInternal(ContainerBase.java:901)
        at org.apache.catalina.core.ContainerBase.addChild(ContainerBase.java:877)
        at org.apache.catalina.core.StandardHost.addChild(StandardHost.java:618)
        at org.apache.catalina.startup.HostConfig.deployWAR(HostConfig.java:963)
        at org.apache.catalina.startup.HostConfig$DeployWar.run(HostConfig.java:1600)
        at java.util.concurrent.Executors$RunnableAdapter.call(Executors.java:441)
        at java.util.concurrent.FutureTask$Sync.innerRun(FutureTask.java:303)
        at java.util.concurrent.FutureTask.run(FutureTask.java:138)
        at java.util.concurrent.ThreadPoolExecutor$Worker.runTask(ThreadPoolExecutor.java:886)
        at java.util.concurrent.ThreadPoolExecutor$Worker.run(ThreadPoolExecutor.java:908)
        at java.lang.Thread.run(Thread.java:619)

查看源碼,一直跟蹤到

at com.sun.jmx.mbeanserver.Repository.addMBean(Repository.java:453)
        at com.sun.jmx.interceptor.DefaultMBeanServerInterceptor.internal_addObject(DefaultMBeanServerInterceptor.java:1484) // 這里
        at com.sun.jmx.interceptor.DefaultMBeanServerInterceptor.registerDynamicMBean(DefaultMBeanServerInterceptor.java:963)
        at com.sun.jmx.interceptor.DefaultMBeanServerInterceptor.registerObject(DefaultMBeanServerInterceptor.java:917)
        at com.sun.jmx.interceptor.DefaultMBeanServerInterceptor.registerMBean(DefaultMBeanServerInterceptor.java:312) //這里入口

一路跟蹤源碼,傳入的參數(shù)一直是name屬性,查看上層 DruidDataSourceStatManager.java  addDataSource(Object dataSource, String name) 

在看上層: DruidDataSource.java line:1298

這里傳入了數(shù)據(jù)源的name屬性,經(jīng)過上面的分析,是利用DataSource的name屬性拼接成一個(gè)id,然后用次id注冊(cè)mbean, 然而,druid的name屬性寫成了一個(gè)默認(rèn)值

故此注冊(cè)失敗。

現(xiàn)在知道了原因,為什么運(yùn)行幾天后才出現(xiàn)這個(gè)錯(cuò)誤,并且運(yùn)維說有回滾到了上個(gè)版本,在部署(直接重新部署,并沒有重啟tomcat/jvm)的時(shí)候就直接報(bào)這個(gè)錯(cuò)誤,經(jīng)過上面的推斷是jvm中已經(jīng)有一個(gè)此id的mbean了,故此即使重新部署還是失敗,我給想了個(gè)辦法,重啟tomcat,搞定,果然奏效。

在來看看druid的wiki中,雖然提示了配置name屬性,但是在配置文件中配置后是不起作用的,經(jīng)過查看源碼發(fā)現(xiàn)并沒有加載次屬性,所以配置了沒用,后來我在代碼中獲取配置文件的name屬性,然后dataSource.setName(name),雖然名字設(shè)置成功了,在druid的監(jiān)控頁面也可以看的自定義的名字,但是不幸的是druid運(yùn)行幾天出錯(cuò)了或者重新部署,然后重新向jvm注冊(cè)mbean,導(dǎo)致了出錯(cuò)。

再來看看datasource的name的默認(rèn)值是怎么設(shè)置的DruidAbstractDataSource.java line: 849

可以看到在getName屬性中是DataSource-加上計(jì)算的一個(gè)hash值,但是此方法只在getName時(shí)返回,而在注冊(cè)mbean時(shí)druid的name默認(rèn)是null, 在注冊(cè)mbean時(shí)分析下面的代碼DruidDataSourceStatManager.java line: 161

代碼顯示是根據(jù)dataSource計(jì)算出來莪一個(gè)hash值,然后進(jìn)行注冊(cè)mbean。

經(jīng)過上面的分析在注冊(cè)mbean時(shí),一定要保證registerMBean的name參數(shù)唯一,還要在上層攔截異常

InstanceAlreadyExistsException,然后自動(dòng)處理異常

總結(jié):在使用Druid的時(shí)候,不要使用name屬性,druid官網(wǎng)并沒有給出說明,本文在此給大家一個(gè)解釋和處理方法。另外1.0.5版本配置后是不起作用的,需要自己強(qiáng)行setName。如自己配置了name,為防止出錯(cuò),最好修改Druid源碼  DruidDataSourceStatManager.java  addDataSource(Object dataSource, String name) ,在生成objectName是在加一個(gè) hash(參考161)。另外大家在注冊(cè)MBean時(shí),一定要保證id的唯一,以及重復(fù)的處理方式。如果出現(xiàn)了這個(gè)錯(cuò)誤,就將與本項(xiàng)目使用的同一個(gè)jvm的項(xiàng)目都關(guān)掉,清理掉本jvm,然后重啟服務(wù)

附: https://github.com/alibaba/druid

到此這篇關(guān)于聊聊Druid register mbean error的問題的文章就介紹到這了,更多相關(guān)Druid register mbean error內(nèi)容請(qǐng)搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持腳本之家!

相關(guān)文章

  • 深入探究ChatGPT的工作原理

    深入探究ChatGPT的工作原理

    這篇文章主要探討了ChatGPT的工作原理,ChatGPT是基于OpenAI開發(fā)的GPT-4架構(gòu)的大型語言模型,文中圖文介紹的非常詳細(xì),感興趣的同學(xué)跟著小編一起來學(xué)習(xí)吧
    2023-06-06
  • 解決maven第一次創(chuàng)建項(xiàng)目太慢的問題

    解決maven第一次創(chuàng)建項(xiàng)目太慢的問題

    Maven是 Apache 下的一個(gè)純 Java 開發(fā)的開源項(xiàng)目,是一個(gè)項(xiàng)目構(gòu)建和管理的工具;它提供了幫助管理 構(gòu)建、文檔、報(bào)告、依賴、scms、發(fā)布、分發(fā)的方法。這篇文章主要介紹了maven第一次創(chuàng)建項(xiàng)目太慢的解決方法,需要的朋友可以參考下
    2020-02-02
  • 微信小程序(應(yīng)用號(hào))組件詳細(xì)介紹

    微信小程序(應(yīng)用號(hào))組件詳細(xì)介紹

    這篇文章主要介紹了微信小程序(應(yīng)用號(hào))組件詳細(xì)介紹的相關(guān)資料,需要的朋友可以參考下
    2016-09-09
  • vscode中使用Autoprefixer3.0無效的解決方法

    vscode中使用Autoprefixer3.0無效的解決方法

    這篇文章主要介紹了vscode中使用Autoprefixer3.0無效的解決方法,文中通過示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面隨著小編來一起學(xué)習(xí)學(xué)習(xí)吧
    2020-06-06
  • 使用MobaXterm連接到遠(yuǎn)程服務(wù)器的圖文教程

    使用MobaXterm連接到遠(yuǎn)程服務(wù)器的圖文教程

    這篇文章主要為大家詳細(xì)為大家介紹了如何使用MobaXterm連接到遠(yuǎn)程服務(wù)器,文中通過圖文進(jìn)行了詳細(xì)的講解,有需要的小伙伴可以參考一下
    2023-09-09
  • Git版本控制服務(wù)器詳解

    Git版本控制服務(wù)器詳解

    這篇文章主要為大家介紹了Git版本控制服務(wù)器詳解,有需要的朋友可以借鑒參考下,希望能夠有所幫助,祝大家多多進(jìn)步,早日升職加薪
    2022-05-05
  • GitHub配置SSH?Key的完整步驟

    GitHub配置SSH?Key的完整步驟

    ssh是一種通信方式,在本地電腦生成ssh key之后,配置到github里,就不用像http協(xié)議那樣每次都輸入賬戶密碼了,這篇文章主要給大家介紹了關(guān)于GitHub配置SSH?Key的完整步驟,需要的朋友可以參考下
    2022-03-03
  • 最新idea2021最新激活超詳細(xì)教程

    最新idea2021最新激活超詳細(xì)教程

    最近有朋友向小編反應(yīng)idea激活碼失效的問題,今天小編給大家推薦使用通過無限重置試用期持續(xù)激活,需要的朋友參考下吧
    2020-09-09
  • Git基礎(chǔ)之git在項(xiàng)目中的協(xié)作模式

    Git基礎(chǔ)之git在項(xiàng)目中的協(xié)作模式

    這篇文章主要為大家介紹了Git基礎(chǔ)之git在項(xiàng)目中的協(xié)作模式,有需要的朋友可以借鑒參考下,希望能夠有所幫助,祝大家多多進(jìn)步,早日升職加薪
    2022-04-04
  • 詳解使用IDEA模擬git命令使用的常見場(chǎng)景

    詳解使用IDEA模擬git命令使用的常見場(chǎng)景

    這篇文章主要介紹了詳解使用IDEA模擬git命令使用的常見場(chǎng)景,文中通過示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面隨著小編來一起學(xué)習(xí)學(xué)習(xí)吧
    2021-04-04

最新評(píng)論