你应当知道的7个Java工具

标签: 基础技术 elasticsearch Java 工具 | 发表时间:2014-11-15 08:44 | 作者:张涛
出处:http://www.importnew.com

Alex Zhitnitsky告诉我们这7个辅助工具的主要功能特点,这些工具每个java程序员都应该了解一下。这篇文章最初发表在takipi的博客–Java与Scala异常分析和性能监控.

在准备进行锁和负载测试之前,应该对一些最新的最具创新性的工具有一个快速了解。为了防止你错过这些信息,rebellabs最近公布了对Java工具和技术全景的一个全球性调查 结果。除了一些已有的或知名度很高的工具,现在市场上还充满了很多不为人知的全新的工具和框架。

在这篇文章中我们决定收集制作一个关于这类 工具的简略名单,他们中的大多数工具只是最近推出的。其中一些工具是为Java定制的,但也有一些是支持其他语言。但对于Java项目而言,他们都是非常好的,并且拥有同一个愿景:简单化。让我们开始吧。

1. JClarity – 性能监测工具
它发布于去年9月。围绕java性能,当前这款工具提供了两个产品:Illuminate 和 Censum。
Illuminate是一款性能监测工具,而censum是一种聚焦于垃圾收集日志分析的应用。
它不仅仅提供了数据收集功能和可视化,对于检测到的问题,这两个工具能够提供具有实践性强的建议,帮助开发人员去解决问题。
“我们要做的是把问题从数据收集阶段转移到数据分析和观察阶段”– JClarity Co-Founder Ben Evans.

主要特性:

  1. 瓶颈检测(磁盘I/O,垃圾收集,死锁等)
  2. 实施计划–提出解决问题的具体建议,如“应用程序需要增加活动线程数”。
  3. 解释–一般性问题的定义以及引起该问题的常见原因,例如“垃圾回收时停顿时间耗时比例过高,可能意味着堆内存不够,太小了”。

独特之处 : 进行监测和性能问题确认后,他会立即提供可行性的意见来解决这些问题
幕后故事: JClarity是在伦敦建立的,他的创始人包括Martijn Verburg, Kirk Pepperdin 和 Ben Evans,都是在java性能领域有着非常丰富经验的人。
想要获取更多关于JClarity的信息,点击 这里

2. Bintray-二元次的社交平台
当从一些”匿名”仓库中导入库文件时,Java开发人员在某种程度上被蒙在鼓里。Bintray给这些代码添了“一张脸”,作为一个社会化平台为java开发者服务,分享开源的软件包(会不会有人说这是二元次的github?).它拥有超过85000个文件包,涵盖18000个库,展示了当前流行的和新版本的包。

主要特性:

  1. 上传你的二进制文件,让全世界都可以看到,并且可以和其他开发者进行交流,并得到一些反馈。
  2. 使用 Gradle / Maven / Yum / Apt工具下载包文件,或者直接从平台下载。
  3. 管理包的版本说明和相关文档
  4. REST风格的API -查询/检索 文件接口 和 自动分发接口

独特之处:Bintray的基础功能类似于 maven中央仓库。但他增加了一个社交层,提供了一个将文件分发到CDN服务器的简单办法。

幕后故事:JFrog基于Israel 和California,开发了Bintray。该工具是去年4月公开的,并在上次JavaOne大会上赢得了 Duke’s choice award奖项
JFrog也开发 Artifactory,Artifactory当然也是跑在Bintray上的。

3. Librato–监控和可视化云服务

Librato作为一个监控和管理云应用的托管服务,它可以瞬间完成自定义面板的创建,而不需要用户去配置或者安装任何软件。
相比其他面板,他的外观和感受如黄油般顺滑。
“仅当你能够从数据中获得具有实际意义的信息时,数据才是有价值的”—Joe Ruscio, Co-Founder & CTO

主要特性:

  • 数据收集:集成了Heroku、AWS、数十种集成代理,以及绑定了java、Clojure等语言 。
  • 自定义报告:性能指标和告警可以通过邮件、HipChat、 Campfire以及HTTP POST请求 与你所想到的任何东西进行整合
  • 数据可视化:带有注释、相关性分析,共享和嵌入选项的美观的图片展示
  • 告警 :当指标超过一定阈值时会自动发出通知告警

特别之处:很难找到任何Librato不知道如何表述以及对数据的理解。
幕后故事:Fred van den Bosch, Joe Ruscio, Mike Heffner and Dan Stodin 几个人在San Francisco 创建了Librato

4.  Takipi的建立基于一个简单的目的:告诉开发人员到底在何时什么原因代码出现异常。每当一个新的异常抛出,或者一个错误日志发生,Takipi就会捕获它,给用户展示可能引起该异常的变量状态,经过的方法和设备。Takipi在错误发生时刻将会覆盖实际执行代码—所以在你分析异常时,就如同当异常发生时你正好在场。

主要特性

  • 监控-捕获/未捕获的异常,http错误,和被日志记录的错误
  • 优先排序- 如果异常错误涉及到新增的代码或者修改过的代码,工具会统计集群中这样的错误发生的频率,以及错误发生的概率是否在递增。
  • 分析-观测实际代码和变量状态,甚至跨越不同的机器和应用

独特之处:

生产环境的God Mode模式。错误发生时展示实际执行的异常代码和变量状态。这样你分析异常时,就如同当异常发生时你在场。

幕后故事: Takipi创建于2012年的San Francisco 和Tel Aviv。每种异常类型和错误都有唯一的怪物来代表他。

5. Elasticsearch – 搜索和分析平台

Elasticsearch已经存在一段时间了,但是他的1.0.0版本在2月份才发布。他是一个基于 lucene的,托管在github上的开源项目,他有200位开发者。你可以从 check out出代码. Elasticsearch提供的主要特性 是易于使用的,可扩展的,分布式的,rest风格的检索。

主要特性

  • 实时文档存储,文档对象的每个field都建立了索引,都能被检索
  • 构建适应于不同规模的应用的体系结构,在此之上实现分布式搜索。
  • 为其他平台系统提供了具有rest风格的和原生java api。他也有hadoop的依赖包
  • 简单可用性强,不需要对搜索原理有深入的理解。该平台有免费模式,所以你可以快速开始应用起来。

独特之处:如他所说,他具有可伸缩性,灵活的构建和易用性。提供一个易用性的平台,进行规模扩展时无需考虑核心功能与用户自定义选项间妥协。

幕后故事:Elasticsearch由 Shay Banon back创建于2010年,最近募集到了 7000万刀的资金。在创建该项目前,Banon就经营一个 Compass的开源项目,现在他是一个著名的搜索专家。那他进入搜索领域的动机呢?原来是为了让他妻子能够保存和检索所喜欢的食谱,进而开发的一个应用。

6. Spark – 微型Web框架

回到java语言,Spark是一个极具自由灵感的,能够快速创建Web应用程序的微型Web框架。为了支持java8和lambdas,今年早些时候他被重写了。Spark是一个开源项目,源代码可以在github上可以看到(请点击 这里),目前开发该框架的人是Per Wendel和 过去几年为了实现只需要付出很小的努力,便可以快速构建一个web应用这样使命的一小撮人。

主要特性:

  • 快速上手,配置简单
  • 直观的路由匹配器
  • 创建可复用组建的模板引擎,它支持Freemarker, Apache Velocity 和 Mustache
  • Spark可以运行在Jetty上,也可以在tomcat上跑

独特之处:图片胜过千言万语,图片更加直观,把代码check出来感受一下吧
幕后故事:Spark的创始人是Per Wendel,瑞典人。目前与其他20个人开发Spark。去看看 讨论组,学习更多的关于Spark的知识,了解如何去给这个开源项目做贡献,解决bug。

7. Plumbr – 内存泄漏检测

深入研究java虚拟机,其中的GC(Garbage Collector 垃圾收集器)将那些不再使用的对象进行回收,释放内存。尽管如此,有时候,开发人员仍旧会持有那些不再使用的对象引用,占用内存。这样就会发生内存泄漏,这个时候,Plumer就该登场了。如果应用发生了内存泄漏问题,Plumer就会进行检测,生成报告,并且提供切实可行的方案去fix掉这个问题。

主要特性

  • 实时的内存泄漏检测和告警
  • 一份包含时间,内存大小,速度(MB/h) 以及泄漏事件的重要级别的报告。
  • 内存泄漏的代码位置

独特之处:快,切中要点,从代码中分析并给出建议帮你修复Bug

幕后故事:Plumbr创建于Estonia,创始人是Priit Potter, Ivo Mägi, Nikita Salnikov-Tarnovski 和 Vladimir Šor。加入这样一个拥有非常丰富经验的java团队吧,这些家伙都是非常厉害的救火队员。嗯,是这样的

相关文章

相关 [知道 java 工具] 推荐:

你应当知道的7个Java工具

- - ImportNew
Alex Zhitnitsky告诉我们这7个辅助工具的主要功能特点,这些工具每个java程序员都应该了解一下. 这篇文章最初发表在takipi的博客–Java与Scala异常分析和性能监控.. 在准备进行锁和负载测试之前,应该对一些最新的最具创新性的工具有一个快速了解. 为了防止你错过这些信息,rebellabs最近公布了对Java工具和技术全景的一个全球性调查 结果.

[iteye]每个Java开发者都应该知道的5个JDK工具

- - PHP & Java
【编者按】JDK是Java语言的软件开发工具包,没有它就无法编译Java程序. 目前,有许许多多的JDK工具呈现在大家面前,但最常用的莫过于java.exe、javac.exe、jar等. 本文作者Joe拥有多年的Java开发经验,其在博客上分享了一篇文章: 5 JDK Tools Every Java Developer Should Know,笔者对其进行了编译,以下为译文.

Java开源建站工具

- Amom - 阮一峰的网络日志
美国程序员Jon Scott Stevens,公布了他的创业公司所使用的开发工具清单. 他的语言平台是Java,开发项目是一个网站(还未上线). 所用到的工具都是开源的,可以免费得到. 在目前的创业者之中,用Java作为网站开发语言的人似乎很少. 这当然不是没有原因的,Java看上去确实不像是最便捷的网站开发工具,给人的感觉是用起来麻烦又费事.

java监测工具之jstat

- - 开源软件 - ITeye博客
用以判断JVM是否存在内存问题呢. 如何判断JVM垃圾回收是否正常. 一般的top指令基本上满足不了这样的需求,因为它主要监控的是总体的系统资源,很难定位到java应用程序. Jstat是JDK自带的一个轻量级小工具. 全称“Java Virtual Machine statistics monitoring tool”,它位于java的bin目录下,主要利用JVM内建的指令对Java应用程序的资源和性能进行实时的命令行的监控,包括了对Heap size和垃圾回收状况的监控.

java图片处理工具

- - CSDN博客推荐文章
作者:kuanghongjiang 发表于2015-2-1 15:45:51 原文链接. 阅读:0 评论:0 查看评论.

Java常用工具包 Jodd

- - Java - 编程语言 - ITeye博客
Jodd 是一个开源的 Java 工具集, 包含一些实用的工具类和小型框架. Jodd 被分成众多模块,按需选择,其中. jodd-core        一些工具类,包括. Fast buffers等等. jodd-bean        BeanUtil以及类型检查转换工具. jodd-props       更强大的Java Properties替代.

Java监控常用工具

- - 编程语言 - ITeye博客
Java的安装包自带了很多优秀的工具,善用这些工具对于监控和调试Java程序非常有帮助. 用途:jps用来查看JVM里面所有进程的具体状态, 包括进程ID,进程启动的路径等等. -l: 输出完成的包名称;. -m: 输出程序的命令行输入参数;. -v: 输出完整的JVM参数. 用途:1)查看java程序崩溃生成core文件,获得core文件的java stack和native stack的信息;2)查看正在运行的java程序的java stack和native stack的信息:a) 查看运行的java程序呈现hung的状态;b) 跟踪Java的调用栈,剖析程序.

Java并发工具类CyclicBarrier

- - CSDN博客编程语言推荐文章
CyclicBarrier同步屏障. java并发工具类中有一个叫做CyclicBarrier的类,与CountDownLatch类似,都可以实现线程间的同步,但是差别是CyclicBarrier是可重置的同步屏障. 想象一个场景,有N个人不同时间走到一扇门,因为门需要N个人合力才能推开,所以人不足N个时,只能阻塞在此,等到N个人都到了之后,可以推开门,继续进行之前的工作.

Java你不知道的那些事儿—Java隐藏特性(上)

- - Java - 编程语言 - ITeye博客
每种语言都很强大,不管你是像我一样的初学者还是有过N年项目经验的大神,总会有你不知道的东西. 就其语言本身而言,比如Java,也许你用Java开发 了好几年,对其可以说是烂熟于心,但你能保证Java所有的用法你都知道吗. 今天没事就来整理下Java中有哪些隐藏的特性呢. 一、双括号初始化语法( DoubleBraceInitialization)(这里指的是大括号{}).