草庐IT

java - 什么是用于收集/存储/呈现应用程序指标/统计的 java 库?

coder 2023-05-15 原文

我有一个 Java 应用程序,它需要收集和报告关于各种实体的大量指标/运营测量/统计数据(不同的人使用不同的词 - 我将只使用指标)。指标可以是以下之一:

  1. 某个特定时间点的一些测量数值(当前登录系统的用户数,某些资源的利用率百分比)
  2. 给定时间间隔内的一些测量数值(过去 5 分钟内传输的消息数)
  3. 某个特定时间点的某个枚举值(某个实体的健康状态为 ONLINE/WARNING/FAILED/OFFLINE)

“实体”可以是物理设备(计算机、交换机、调制解调器),但通常是逻辑实体(通信 channel 4567、用户 123456、服务 A 的接口(interface))。此外,这些逻辑实体中的一些是静态的,因为它们是提前知道的,并且在应用程序的生命周期内不会改变,而其他的可能是暂时的(通信 channel 4567 可能只存在一段时间,然后被删除) .

我正在寻找有助于解决 2 个问题的库:

  1. 更容易收集这些信息并将其存储在服务器上。
  2. 以有用的方式向用户展示数据。

注意/要求:

  1. 产生数据的服务器应用程序基本上是一个作为守护进程运行的 Java 进程(即不是 web 应用程序)
  2. 将有 2 种不同类型的客户。
    1. 其中一个是 Java Swing 桌面应用程序,大部分“重度”使用都将用于该应用程序。丰富的实时图表和历史查询能力在这里很重要。
    2. 另一个是网页界面。我的要求在这里还不是 100% 明确,但是这个客户的需求将比 Swing 客户轻得多。这里需要开放标准(AJAX/HTML 而不是 Flash)
  3. 可以嵌入到专有软件中进行部署(即没有 GPL 许可)。商业或免费。

过去,我的公司曾尝试过几种“本土”解决方案来满足这一需求。基本上,数据以某种不一致的方式被插入数据库,客户端将数据提取出来,并能够使用自制或第 3 方图表包在固定时间段内绘制单个值。坦率地说,我们所有的解决方案都很糟糕。我希望第三方解决方案可以解决的一些问题是:

  1. 封装用于更新/记录指标的代码,以免污染实际测量值的类。
  2. 帮助管理指标的命名/识别。它们很容易有1000个;我自己想出了某种命名方案以确保唯一性是 PITA。
  3. 很好地处理历史数据。能够配置数据的保留时间以及归档或清除旧记录。
  4. 在客户端,内置图表和查询功能,能够在呈现给用户之前转换数据库中的一些原始数据。

抱歉,描述太长了。感谢您的帮助。

最佳答案

我可以推荐 Yammer 的这个 Java 库:https://github.com/dropwizard/metrics 它提供了一个很好的 API 来拥有计数器、计时、直方图等。 它可以通过检测 servlet 和 JVM(内存等)自动从 servlet 收集有趣的数据。

然后我们将数据存储在 Graphite 中:http://graphite.wikidot.com/

Graphite 将数据存储在类似于 RRD 的固定大小的数据库中,并且可以生成图表和仪表板。

关于java - 什么是用于收集/存储/呈现应用程序指标/统计的 java 库?,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/5489718/

有关java - 什么是用于收集/存储/呈现应用程序指标/统计的 java 库?的更多相关文章

  1. ruby - 为什么我可以在 Ruby 中使用 Object#send 访问私有(private)/ protected 方法? - 2

    类classAprivatedeffooputs:fooendpublicdefbarputs:barendprivatedefzimputs:zimendprotecteddefdibputs:dibendendA的实例a=A.new测试a.foorescueputs:faila.barrescueputs:faila.zimrescueputs:faila.dibrescueputs:faila.gazrescueputs:fail测试输出failbarfailfailfail.发送测试[:foo,:bar,:zim,:dib,:gaz].each{|m|a.send(m)resc

  2. ruby - 在 Ruby 程序执行时阻止 Windows 7 PC 进入休眠状态 - 2

    我需要在客户计算机上运行Ruby应用程序。通常需要几天才能完成(复制大备份文件)。问题是如果启用sleep,它会中断应用程序。否则,计算机将持续运行数周,直到我下次访问为止。有什么方法可以防止执行期间休眠并让Windows在执行后休眠吗?欢迎任何疯狂的想法;-) 最佳答案 Here建议使用SetThreadExecutionStateWinAPI函数,使应用程序能够通知系统它正在使用中,从而防止系统在应用程序运行时进入休眠状态或关闭显示。像这样的东西:require'Win32API'ES_AWAYMODE_REQUIRED=0x0

  3. ruby-on-rails - Rails - 子类化模型的设计模式是什么? - 2

    我有一个模型:classItem项目有一个属性“商店”基于存储的值,我希望Item对象对特定方法具有不同的行为。Rails中是否有针对此的通用设计模式?如果方法中没有大的if-else语句,这是如何干净利落地完成的? 最佳答案 通常通过Single-TableInheritance. 关于ruby-on-rails-Rails-子类化模型的设计模式是什么?,我们在StackOverflow上找到一个类似的问题: https://stackoverflow.co

  4. ruby - 将差异补丁应用于字符串/文件 - 2

    对于具有离线功能的智能手机应用程序,我正在为Xml文件创建单向文本同步。我希望我的服务器将增量/差异(例如GNU差异补丁)发送到目标设备。这是计划:Time=0Server:hasversion_1ofXmlfile(~800kiB)Client:hasversion_1ofXmlfile(~800kiB)Time=1Server:hasversion_1andversion_2ofXmlfile(each~800kiB)computesdeltaoftheseversions(=patch)(~10kiB)sendspatchtoClient(~10kiBtransferred)Cl

  5. ruby-on-rails - Rails 常用字符串(用于通知和错误信息等) - 2

    大约一年前,我决定确保每个包含非唯一文本的Flash通知都将从模块中的方法中获取文本。我这样做的最初原因是为了避免一遍又一遍地输入相同的字符串。如果我想更改措辞,我可以在一个地方轻松完成,而且一遍又一遍地重复同一件事而出现拼写错误的可能性也会降低。我最终得到的是这样的:moduleMessagesdefformat_error_messages(errors)errors.map{|attribute,message|"Error:#{attribute.to_s.titleize}#{message}."}enddeferror_message_could_not_find(obje

  6. ruby - 什么是填充的 Base64 编码字符串以及如何在 ruby​​ 中生成它们? - 2

    我正在使用的第三方API的文档状态:"[O]urAPIonlyacceptspaddedBase64encodedstrings."什么是“填充的Base64编码字符串”以及如何在Ruby中生成它们。下面的代码是我第一次尝试创建转换为Base64的JSON格式数据。xa=Base64.encode64(a.to_json) 最佳答案 他们说的padding其实就是Base64本身的一部分。它是末尾的“=”和“==”。Base64将3个字节的数据包编码为4个编码字符。所以如果你的输入数据有长度n和n%3=1=>"=="末尾用于填充n%

  7. ruby - 解析 RDFa、微数据等的最佳方式是什么,使用统一的模式/词汇(例如 schema.org)存储和显示信息 - 2

    我主要使用Ruby来执行此操作,但到目前为止我的攻击计划如下:使用gemsrdf、rdf-rdfa和rdf-microdata或mida来解析给定任何URI的数据。我认为最好映射到像schema.org这样的统一模式,例如使用这个yaml文件,它试图描述数据词汇表和opengraph到schema.org之间的转换:#SchemaXtoschema.orgconversion#data-vocabularyDV:name:namestreet-address:streetAddressregion:addressRegionlocality:addressLocalityphoto:i

  8. ruby - 如何指定 Rack 处理程序 - 2

    Rackup通过Rack的默认处理程序成功运行任何Rack应用程序。例如:classRackAppdefcall(environment)['200',{'Content-Type'=>'text/html'},["Helloworld"]]endendrunRackApp.new但是当最后一行更改为使用Rack的内置CGI处理程序时,rackup给出“NoMethodErrorat/undefinedmethod`call'fornil:NilClass”:Rack::Handler::CGI.runRackApp.newRack的其他内置处理程序也提出了同样的反对意见。例如Rack

  9. ruby - 在 Ruby 中编写命令行实用程序 - 2

    我想用ruby​​编写一个小的命令行实用程序并将其作为gem分发。我知道安装后,Guard、Sass和Thor等某些gem可以从命令行自行运行。为了让gem像二进制文件一样可用,我需要在我的gemspec中指定什么。 最佳答案 Gem::Specification.newdo|s|...s.executable='name_of_executable'...endhttp://docs.rubygems.org/read/chapter/20 关于ruby-在Ruby中编写命令行实用程序

  10. ruby - 为什么 4.1%2 使用 Ruby 返回 0.0999999999999996?但是 4.2%2==0.2 - 2

    为什么4.1%2返回0.0999999999999996?但是4.2%2==0.2。 最佳答案 参见此处:WhatEveryProgrammerShouldKnowAboutFloating-PointArithmetic实数是无限的。计算机使用的位数有限(今天是32位、64位)。因此计算机进行的浮点运算不能代表所有的实数。0.1是这些数字之一。请注意,这不是与Ruby相关的问题,而是与所有编程语言相关的问题,因为它来自计算机表示实数的方式。 关于ruby-为什么4.1%2使用Ruby返

随机推荐