You are viewing a plain text version of this content. The canonical link for it is here.
Posted to dev@lucene.apache.org by "Greg Bowyer (JIRA)" <ji...@apache.org> on 2012/05/07 17:40:50 UTC

[jira] [Updated] (SOLR-3083) all JMX Mbeans are identified as java.lang.String even if numeric

     [ https://issues.apache.org/jira/browse/SOLR-3083?page=com.atlassian.jira.plugin.system.issuetabpanels:all-tabpanel ]

Greg Bowyer updated SOLR-3083:
------------------------------

    Attachment: SOLR-3083-Made-JMX-Mbean-information-use-numeric-typ.patch

Attempt to make numeric mbeans turn into numeric types from the viewpoint of JMX
                
> all JMX Mbeans are identified as java.lang.String even if numeric
> -----------------------------------------------------------------
>
>                 Key: SOLR-3083
>                 URL: https://issues.apache.org/jira/browse/SOLR-3083
>             Project: Solr
>          Issue Type: Bug
>          Components: SearchComponents - other
>    Affects Versions: 4.0
>            Reporter: Tagged Siteops
>            Priority: Minor
>              Labels: interoperability,, jmx, monitoring, statistics
>         Attachments: SOLR-3083-Made-JMX-Mbean-information-use-numeric-typ.patch, Screen shot 2012-01-31 at 2.19.06 PM.png
>
>
> When trying to monitor our Solr instances with JMXtrans (https://github.com/lookfirst/jmxtrans), we discovered that all the Mbeans were identifying themselves as java.lang.String.   This breaks the GangliaWriter in JMXtrans because the software decides it's a string instead of a numeric values and you can't graph a string.   Other software we are monitoring with JMXtrans (e.g. Kafka) correctly identify their numeric values as numbers (doubles in this case).
> For example, avgTimePerRequest in Solr is identified as a string which makes no sense.  This behavior makes Solr less interoperable with the rest of the Java ecosystem.
> The problem code is in JmxMonitoredMap.java
> NamedList dynamicStats = infoBean.getStatistics();
> if (dynamicStats != null) {
>   for (int i = 0; i < dynamicStats.size(); i++) {
>     String name = dynamicStats.getName(i);
>     if (!staticStats.contains(name))
>       attrInfoList.add(new MBeanAttributeInfo(dynamicStats.getName(i),
>               String.class.getName(), null, true, false, false));
>   }
> I will try to attach a screenshot. 
> Thanks for Solr!  We use the heck out of it, it's awesome.

--
This message is automatically generated by JIRA.
If you think it was sent incorrectly, please contact your JIRA administrators: https://issues.apache.org/jira/secure/ContactAdministrators!default.jspa
For more information on JIRA, see: http://www.atlassian.com/software/jira

        

---------------------------------------------------------------------
To unsubscribe, e-mail: dev-unsubscribe@lucene.apache.org
For additional commands, e-mail: dev-help@lucene.apache.org