`
gybin
  • 浏览: 270178 次
  • 性别: Icon_minigender_1
  • 来自: 北京
社区版块
存档分类
最新评论

Java开发:新工具、新框架、新思维

    博客分类:
  • Java
 
阅读更多

郑晔:这个话题可能与我个人的经历有关。我的职业生涯是从Java起步的,中间各种机缘,我做了很多其它不同类型的项目,接触过各种各样的程序设计语言。最近几年又重新把所有的注意力放回Java,我很惊讶地发现,现在许多程序员讨论的内容几乎和我十多年前刚开始做Java时几乎完全一样。要知道,我们生存的这个行业号称是变化飞快的。 其实,这十几年时间,在开发领域已经有了非常多的新内容涌现出来,即便是Java开发这个领域,也有了很多变化。我自己最近的几个Java项目,用到了不少十年前没有的东西。既然我有了这样的感觉,为什么不能尝试着总结一下呢? 于是,去年我在自己的blog上写了一个系列的《你应该更新的Java知识》。我自己真正总结出来的内容要远比写下来的多,在公司内部,我做了一个有十几节的课程,给自己的同事分享过。这次的QCon分享的主题,就是基于这个系列课程第一讲的概述部分。所以,我在演讲上也提到,如果想了解全部内容,就看以后还有没有机会在更多的大会上分享了,当然,如果想更完整地了解,可以专门联系我,呵呵。

 

InfoQ:在演讲中您提到,您向大家推荐了很多比较好用的Java开源软件,比如Guava,能详细说说吗?

郑晔:我推荐的程序库有一个的原则,它们必须有很易用的API,而不仅仅为了实现功能。下面是我在演讲里列出的几个我愿意推荐给大家的程序库。

我对Guava的一个评价是,只要你做的是Java项目,就应该用Guava。Guava某种程度上是弥补了JDK的不足,我们都知道,JDK是为了给Java开发人员提供一个基础的开发包,但是,JDK基本上定位于功能实现。这在10多年前,没有问题,但现在,随着人们对于代码编写认识的加深,仅仅有功能已经不够了,还要有一个易用的接口。举个简单的例子,把文件读到一个字符串里,如果用JDK实现,光想着异常处理都回让人头疼不已。Guava是一个现代的程序库,它有着更易用的API。当然,Guava也有一些新增功能,比如,一些集合类、缓存等等。Guava做得怎么样?看一下Java 8的文档就可以知道,有一些API几乎就是原封不动地从Guava上借鉴来的。

Joda Time是我提到的另一个程序库。它现在的位置很有趣,我们都知道JDK中原有的日期库设计的非常糟糕,Joda Time就是为了让我们躲开Java的日期库。但是,因为它设计得很好,它也被JDK借鉴了,于是有了JSR 310,现在已经是Java 8的一部分。不过,从技术发展来看,Java 8广泛使用起来还有很长的路要走。大多数人还会继续与Java 6做斗争,所以,我还是把它列了出来。

Hamcrest和Mockito,是两个用来测试的库。Hamcrest让我们更好地写断言,而Mockito让我们更好地编写Mock对象。

DropWizard,我们可以把它理解一个开发REST服务的框架,但其实它什么都没做,只是把一些已有框架集成到了一起。它同前面几个程序库有很大的不同,它更多地是代表了一种的开放方式:轻量级部署风格,抛开沉重的应用服务器。它未必会是未来的赢家,但值得了解。

其实,还有一些不错的程序库值得推荐,比如,像实现了Actor的Akka,但这些库往往是代表了一种特定的程序设计风格,所以,我没有特意列出。 近些年,Java世界里出现的“新”工具“新”框架,在学习这些工具框架方面,您有什么好的方法提供给大家?

InfoQ:对于这些新工具、新框架的学习,您有什么好的方法分享给大家?

郑晔:软件开发行业是一个发展变化很快的行业,尽管很多思想层面的东西变动不大,但在具体操作层面上,总会有新的东西层出不穷。作为一个程序员,如果不希望为这个时代淘汰,一个开放的心态必不可少。就我个人而言,我会一直开着自己的雷达,了解各种新技术、新知识的。至于到具体的工具框架学习,没有什么特别的,文档是最好的老师。基本上,文档会把功能性的东西都告诉你。

InfoQ:在实际的开发中,同一个功能往往有不同的框架做了实现,比如MVC的实现就有Struts、SpringMVC等。在遇到类似的情况时,您是怎么选择框架的?

郑晔:在功能类似的情况下,我会选择更符合技术发展方向、API设计更好的库。

举个例子,如果开发一个Web应用,以前的做法是用Spring MVC一个一个页面写,但现在我不会这么做了。我会倾向于基于微服务的架构,这是一个符合技术发展方向的做法。更容易理解的说法是,后台提供基于REST的API,由前台页面进行访问。这样原来传统的方式就显得笨拙了,它们是为了由后台渲染页面准备的,所以,后台框架我会选择一个更容易做REST API的框架,比如用Jersey加上Jackson。

再举一个API影响选型的例子,我们常用的Log库,以前我们都会选择Commons Logging,但是使用这个库,通常我们的代码都是在正式地写日志之前,先判断一下isXXXEnabled。因为这个库是Java 5之前设计的,之所以这么做,有许多性能之类的考量。而现在,我的首选Log库是SLF4J,就省去了那些不必要的代码,非常清爽。

InfoQ:在演讲中,你还重点讲了自动化。那么,在这方面您是怎么做的?

郑晔:对于自动化,我的基本理念是,尽可能自动化一切能够自动化的东西。十几年前,我们提到自动化,基本上就是编译、打包,而现在自动化的范围比以前大得多。我在2011年曾在InfoQ上发表了一篇名为《软件开发地基》的文章,里面谈到了我在项目里所做的一些基本的自动化工作。时隔三年再来看这篇文章,大部分内容依然是适用的。而现在,当我们谈到自动化,应该比那篇文章的范围还大,在我自己的项目里面,我们会把一些环境部署的过程也自动化起来,按照现在流行的说法,目标是要做持续交付。

在Java自动化领域,最近几年一个比较大的变化发生在工具领域。我在演讲中提到了,如果你现在还在用Ant和Maven,你就落伍了,Ant做简单的事不简单,Maven做复杂的事情很困难。现在的趋势是,以全功能语言做自动化脚本。《软件开发地基》那篇文章里,我用的工具是buildr,它依赖于Ruby语言。最近几年Java领域表现最活跃的自动化工具是Gradle,它现在几乎是我做Java项目的默认之选,其基础是Groovy。

InfoQ:您讲到轻量级部署相关的一些建议,能详细说说吗?

郑晔:一说起Java应用的部署,大家直觉上就会想到“打个包,部署到应用服务器”。这也是几乎十多年前就定型下来的开发方式。但对于开发人员来说,这就几乎就意味着各种开发的噩梦。为了在开发阶段定位一些问题,我们就不得不在“本地”进行用上“远程”调试。

应用服务器是一个“老大哥”年代的产物,那时候大公司要卖应用服务器,更要卖硬件,所以,它们炮制出复杂的业务场景。但是,对于许多团队来说,你可能一辈子都碰不到这样复杂的情况。当年,EJB的破产已经让我们见识了这种虚幻的需求在程序员社区里是站不住脚的。现在,轮到应用服务器本身了。我在演讲里曾经举过一个例子,说明这个应用服务器中一个虚幻的需求,在一台应用服务器上部署多个应用。现在我们看到,大多数应用多个应用服务器都不够,一个应用服务器部署多个应用除了测试玩玩,在实际的场景中,几乎就是站不住脚的。开源社区的兴起让普通程序员有机会见到高手是如何工作的,高水平程序员总会追求更“简单”的工作方式,吸引更多程序员走入这种方式中。我很高兴地看到,我们的开发方式不再是由老大哥主导了。

最近几年,随着云和移动开发的兴起,微服务的概念逐渐进入了我们的视野,随之而来的就是社区对于开发和部署的反思。前面提到的DropWizard的就是一个很好的例子,通过它,我们只要打出一个JAR包,和传统的方式不同的是,这个JAR包直接就是一个可运行的应用。是的,它是有Main函数的。有Main函数就意味着,我们可以很方便地在IDE里做我们想做的一切,包括调试。这样一来,对比从前那种笨拙的方式,开发人员可以做到“易者易为”。

关于部署,现在的一个方向是部署的自动化,有很多工具可以支持我们做到这一点,比如Chef、Puppet,我最近的一个项目上用了Docker。有了这些基础,我们可以一键式在一台空机器上建立起一个完整的应用。这就是持续交付中一个很重要的基础。再进一步,我们可以把这种部署同虚拟化和云结合起来,用自动化工具在云端一个节点部署出我们的应用。你可以想一下,如果我需要测试一下我的应用,或是在产品环境上增加一个新节点,我只要用一条命令,就会自动在云端的某个节点上建出我们所需的全部内容。传统做法仅仅是申请机器就是一个漫长的过程,遑论手工安装应用,配置参数这些麻烦事。这不是对未来美好生活的畅想,实际上,我们公司的许多项目已经做到了这一点。

把部署自动化和轻量级部署、微服务结合起来,我们的开发方式就是,在本地编写好一个服务,调测好,再部署到云端,由其它人进一步测试。这才是一种简单的开发方式。程序员应该追求简单,包括我们个人开发方式

分享到:
评论

相关推荐

    Java思维导图

    在深入探讨Java的思维导图之前,让我们先理解每个文件名所代表的知识点。 1. **Java知识思维导图.jpg** 这张图很可能包含了Java语言的基础知识架构,包括但不限于: - **基础语法**:变量、数据类型、运算符、...

    Spring框架在Java开发中的应用与心得

    ### Spring框架在Java开发中的应用与心得 #### 一、Spring框架概述 Spring框架自2004年发布以来,迅速成为了Java开发领域中最受欢迎的企业级应用开发框架之一。其核心设计思想旨在解决传统Java应用开发中存在的...

    java思维导图.rar

    Java编程语言是软件开发领域中的重要工具,尤其在企业级应用和互联网服务中占据着核心地位。本资源“java思维导图.rar”提供了一个详细的学习路径,帮助初学者和有经验的开发者更好地理解和掌握Java的核心概念。这个...

    Java 最全学习思维导图.zip

    10. **框架**:Spring、MyBatis、Hibernate等,是现代Java开发中常用的工具。 11. **设计模式**:23种经典设计模式,它们是解决常见问题的最佳实践。 12. **单元测试**:JUnit或TestNG,用于确保代码的质量。 13....

    java实用系统开发指南-1

    还有工程方法、设计思维的创新,如何使用全新的OO思维设计开发Java/J2EE项目,该书指引了正确的方法和路径,这在同类书籍包括进口书籍中是不多见的。  更难能可贵的是,作者通过8个系统不同架构技术的选择展现了...

    三年java开发经验简历模板

    【Java开发经验】 在三年的Java开发经验中,涵盖了多个关键技术和项目实践。首先,开发者熟练掌握了JavaWeb基础,包括jsp、Servlet、javabean和JDBC的开发模式,这是构建动态Web应用的基础。此外,熟悉Struts2、...

    思维导图-Java基础

    思维导图是一种有效的学习工具,它能帮助我们系统地整理知识结构,加深理解和记忆。在这个"思维导图-Java基础"中,我们可以预期涵盖以下几个关键知识点: 1. **Java简介**:Java是由Sun Microsystems开发,后被...

    java面试题,面试题收集,对刁钻面试题的回答.

    Java面试是每位Java开发者职业生涯中的重要环节,它不仅测试你的技术实力,还考察你的问题解决能力和思维方式。以下是一些常见的Java面试知识点,涵盖了基础、进阶到设计模式等多个方面: 1. **Java基础**: - ...

    java开发岗位职责.docx

    3. **编程技能与框架应用**:Java开发人员需精通Java编程,熟悉J2EE平台以及Spring、MyBatis、Memcache、Redis、MySQL、MongoDB、ActiveMQ、Solr等常用框架。同时,至少3年的Java开发经验是大多数岗位的基本要求。 ...

    java成神之路思维导图——Hollis.zip

    10. **框架**:如Spring、MyBatis、Hibernate等流行的Java开发框架,它们简化了开发过程并提高了效率。 11. **测试**:单元测试和集成测试的重要性,如何使用JUnit或TestNG进行测试。 12. **持续集成/持续部署(CI/...

    202303-Java异常面试题(2023最新版)思维导图.zip

    5. 框架和工具: - MyBatis - Hibernate - Maven、Gradle - Git、SVN - IntelliJ IDEA、Eclipse 6. 微服务: - RESTful API - Spring Cloud Netflix - Docker、Kubernetes 7. 缓存: - Redis - ...

    202302-Java集合容器面试题(2023最新版)思维导图.zip

    5. 框架和工具: - MyBatis - Hibernate - Maven、Gradle - Git、SVN - IntelliJ IDEA、Eclipse 6. 微服务: - RESTful API - Spring Cloud Netflix - Docker、Kubernetes 7. 缓存: - Redis - ...

    202301-Java基础知识面试题(2023最新版)思维导图.zip

    5. 框架和工具: - MyBatis - Hibernate - Maven、Gradle - Git、SVN - IntelliJ IDEA、Eclipse 6. 微服务: - RESTful API - Spring Cloud Netflix - Docker、Kubernetes 7. 缓存: - Redis - ...

    java\CoreJava笔记\CoreJAVA_day01

    - 类库:Java提供了丰富的标准类库,如集合框架、I/O流、网络编程、多线程等,这些是开发中常用的工具。 4. **开发环境**: - IDE(Integrated Development Environment):如Eclipse、NetBeans、IntelliJ IDEA等...

    java案例开发集锦

    Java案例开发集锦是针对Java编程语言的一份综合性学习资源,旨在帮助开发者深入理解和实践Java技术。这份资料可能包含了各种类型的Java项目实例,涵盖了基础到高级的多种应用场景,是提升Java技能的重要参考资料。 ...

    202308-Java虚拟机(JVM)面试题(2023最新版)思维导图.zip

    5. 框架和工具: - MyBatis - Hibernate - Maven、Gradle - Git、SVN - IntelliJ IDEA、Eclipse 6. 微服务: - RESTful API - Spring Cloud Netflix - Docker、Kubernetes 7. 缓存: - Redis - ...

    十来年java开发程序员,对自己学习经验的分享

    10. **Spring框架**:Spring是Java开发中常用的框架,它提供了依赖注入、AOP(面向切面编程)、MVC等特性,是企业级开发的基石。 11. **数据库技术**:SQL基础和数据库设计,如关系型数据库MySQL或Oracle,以及...

    Java-MindManager:Java思维导图汇总

    11. **Java框架**:Spring框架是企业级应用开发的常用工具,包括依赖注入、AOP、MVC、数据访问等模块。MyBatis是轻量级的持久层框架,简化了SQL操作。 12. **Java EE**:Java企业版(Java EE)扩展了Java SE,提供...

    蓝桥杯第三届JAVA软件开发本科B组个人赛选拔赛真题

    这类竞赛通常包括但不限于基础语法、面向对象编程、数据结构、算法设计、多线程、网络编程、数据库操作等Java开发的关键知识点。 【标签】:“蓝桥杯JAVA”标签表明了比赛的重点是JAVA语言,意味着我们需要深入理解...

Global site tag (gtag.js) - Google Analytics