入职阿里啦!16步快速搭建Java开发项目模板,拒绝重复性工作

  • 测试策略:自动化测试如何分类,哪些必须写测试,哪些没有必要写测试;

  • 技术架构:技术架构图;

  • 部署架构:部署架构图;

  • 外部依赖:项目运行时所依赖的外部集成方,比如订单系统会依赖于会员系统;

  • 环境信息:各个环境的访问方式,数据库连接等;

  • 编码实践:统一的编码实践,比如异常处理原则、分页封装等;

  • FAQ:开发过程中常见问题的解答。

需要注意的是,README中的信息可能随着项目的演进而改变(比如引入了新的技术栈或者加入了新的领域模型),因此也是需要持续更新的。虽然我们知道,软件文档的一个痛点便是无法与项目实际进展保持同步,但是就README这点信息来讲,还是建议开发者们不要吝啬那一点点敲键盘的时间。

此外,除了保持README的持续更新,一些重要的架构决定可以通过示例代码的形式记录在代码库中,新开发者可以通过直接阅读这些示例代码快速了解项目的通用实践方式以及架构选择,请参考ThoughtWorks的技术雷达。

一键式本地构建


为了避免诸如前文中所提到的“请教了3位同事才本地构建成功”的尴尬,为了减少“懒惰”的程序员们的手动操作,也为了为所有开发者提供一种一致的开发体验,我们希望用一个命令就可以完成所有的事情。这里,对于不同的场景我总结出了以下命令:

  • 生成IDE工程:idea.sh,生成IntelliJ工程文件并自动打开IntelliJ

  • 本地运行:run.sh,本地启动项目,自动启动本地数据库,监听调试端口5005

  • 本地构建:local-build.sh,只有本地构建成功才能提交代码

以上3个命令基本上可以完成日常开发之所需,此时,对于新人的开发流程大致为:

  1. 拉取代码;

  2. 运行idea.sh,自动打开IntelliJ;

  3. 编写代码,包含业务代码和自动化测试;

  4. 运行run.sh,进行本地调试或必要的手动测试(本步骤不是必需);

  5. 运行local-build.sh,完成本地构建;

  6. 再次拉取代码,保证local-build.sh成功,提交代码。

事实上,这些命令脚本的内容非常简单,比如run.sh文件内容为:


#!/usr/bin/env bash

./gradlew clean bootRun 

然而,这种显式化的命令却可以减少新人的恐惧感,因为他们只需要知道运行这3个命令就可以搞开发了。另外,一个小小的细节:本地构建的local-build.sh命令本来可以重命名为更简单的build.sh,但是当我们在命令行中使用Tab键自动补全的时候,会发现自动补全到了build目录,而不是build.sh命令,并不方便,因此命名为了local-build.sh。细节虽小,但是却体现了一个宗旨,即我们希望给开发者一种极简的开发体验,我把这些看似微不足道的东西称作是对程序员的“人文关怀”。

目录结构


Maven所提倡的目录结构当前已经成为事实上的行业标准,Gradle在默认情况下也采用了Maven的目录结构,这对于多数项目来说已经足够了。此外,除了Java代码,项目中还存在其他类型的文件,比如Gradle插件的配置、工具脚本和部署配置等。无论如何,项目目录结构的原则是简单而有条理,不要随意地增加多余的文件夹,并且也需要及时重构。

在示例项目中,顶层只有2个文件夹,一个是用于放置Java源代码和项目配置的src文件夹,另一个是用于放置所有Gradle配置的gradle文件夹,此外,为了方便开发人员使用,将上文提到的3个常用脚本直接放到根目录下:


└── order-backend

    ├── gradle // 文件夹,用于放置所有Gradle配置

    ├── src // 文件夹,Java源代码

    ├── idea.sh //生成IntelliJ工程

    ├── local-build.sh // 提交之前的本地构建

    └── run.sh // 本地运行 

对于gradle而言,我们刻意地将Gradle插件脚本与插件配置放到了一起,比如Checkstyle:


├── gradle

│   ├── checkstyle

│   │   ├── checkstyle.gradle

│   │   └── checkstyle.xml 

事实上,在默认情况下Checkstyle插件会从项目根目录下的config目录查找checkstyle.xml配置文件,但是这一方面增加了多余的文件夹,另一方面与该插件相关的设施分散在了不同的地方,违背了广义上的内聚原则。

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
当你作为一名Java开发工程师即将时,以下是一个可能的学习计划: 第一周: 1. 熟悉公司的开发环境和工具,例如IDE(如IntelliJ IDEA或Eclipse)、版本控制系统(如Git)等。 2. 学习公司的开发流程和代码规范,了解团队的工作方式和项目组织结构。 3. 复习Java的基础知识,包括语法、面向对象编程、异常处理等。 第二周: 1. 学习常用Java类库和框架,如集合框架、IO操作、多线程等。 2. 掌握常用的设计模式,例如单例模式、工厂模式等。 3. 练习编写简单的Java应用程序,加深对Java基础知识的理解。 第三周: 1. 学习Java Web开发的基础知识,包括Servlet、JSP、MVC架构等。 2. 掌握常用的Web开发框架,如Spring、Spring MVC和Hibernate等。 3. 开始进行简单的Web开发实践,例如创建一个简单的CRUD应用程序。 第四周: 1. 深学习数据库相关知识,包括SQL语法、数据库设计和优化等。 2. 学习使用JDBC进行数据库连接和操作。 3. 进行更复杂的Web开发实践,例如与数据库交互的应用程序。 第五周: 1. 学习常用的前端技术,如HTML、CSS和JavaScript。 2. 掌握前端框架,如React或Vue.js,以提高用户界面的开发效率。 3. 结合前后端技术,完成一个完整的Web应用程序。 第六周及以后: 1. 深学习Java高级特性,如Lambda表达式、Stream API等。 2. 学习微服务架构和相关技术,如Spring Cloud、Docker等。 3. 持续学习和实践,参与团队的项目开发,积累经验并不断提升自己的技能。 以上是一个简要的Java开发学习计划,具体的学习进度和内容可以根据个人情况和公司要求进行调整。重要的是坚持学习和实践,与团队成员进行积极的交流和合作,不断提升自己的技术能力和软技能。祝你在新的岗位上取得成功!

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值