文章目录
- 一、前言
- 二、实战
- 2.1 创建父工程统一依赖的版本管理
- 2.2 创建公共使用的 common工程
- 2.3 创建子工程并引入父工程的依赖以及公共工程
- 2.4 搭建启动环境
- 2.5 启动程序开始验证
- 三、总结
一、前言
2023年口罩放开的第一年,大多数人都是想着重新开始,抓住金三银四的好时机,找到心仪的工作和符合岗位要求的人才,一起整装出发。我们理想的状态是,经济已经在恢复了,那么就业市场也应该恢复了。然而现实是残酷的,海投无回应依然是常态。据互联网第三方平台统计,企业用人需求每月新增10万+,Java人才缺口高达42.5万,并以每年20%左右的速度增长。然而招聘市场却割裂严重,HR抱怨招人难,程序员抱怨拿不到offer。这是为何?拨开现象看本质:无非是双方需求错位。
在IT业发展初始阶段,初级Java程序员足以满足企业需求,但IT业发展至今,行业细分越发精细,企业需求也随时改变,要求程序员 “来之即用”,拥有更多解决复杂问题的能力。
最直观的表现就是,企业招聘要求再度提高,并在薪资上不断加码。
以下是字节2020年和2022年发布的Java程序员招聘启事:
单从招聘启事上可以看出,想要在2022年找到和2020年薪资、级别差不多的工作,Java程序员需要更加丰富的技能。(只会curd是不可能找到好工作了 )
互联网的已经今非昔比了,迭代极快,在这过程中,公司业务可能会发生颠覆式的调整,技术栈会随之改变。这仅仅是一家公司,互联网行业包罗万象,整体产品创新、迭代速度极快。随着新行业、新技术、新产品的出现,相应的业务需求也会不断衍生。
互联网行业 “不进则退,慢进亦退”,程序员亦是如此。对于用人要求持续增高的互联网企业来说,高级Java程序员才是当下市场最紧缺的。只会crud程序员 很有可能被现在的 GPT们(chatGPT,GPT4.0)取代了。可以看一下我之前让chatGPT 给我写的python程序,不得不说太厉害了。chatGPT对于一个python初学者有什么用?
前摇略长了 咳咳 ,接下来我们开始步入正题。maven想必大家都用过,不过一般我们一般做项目的时候,都是架构师搭好了框架,我们进去进行 crud 补充点业务逻辑就行了,长此以往,我们的架构设计能力就废了,当我们想跳槽涨薪时,毫无竞争力,故我们需要在工作之余学习一些架构设计相关的东西,比如我们最常用的依赖工具maven,maven的使用很简单。但是想用好还是需要一些学习的,本文将从现在的流行的微服务框架springcloud 依赖管理切入,深入剖析一些大厂微服务的包管理应该是怎么样的。
二、实战
学一门技术的最好的就是去官方文档里看看,比如我们要学习 SpringCloud 就可以看以下几个资源:
- springcloud的官网:https://spring.io/cloud
- springcloud官方文档:https://spring.io/projects/spring-cloud
我们在springcloud官方文档的 overview 中可以看到spring官方是如何建议我们使用的springcloud:
图一:
如上图所示这是让我们先引入 springcloud包管理依赖的pom,这种写法并不会把springcloud 的所有包依赖引入我们的工程,相当于一个声明。当你的工程里需要用到某一个依赖的时候,只要需要像下图一样写上需要引入的包的 <groupId>
和 <artifactId>
.
可能有的友友就有点好奇这里我们并没有指定版本,maven能成功引入吗?,其实是能引入成功的,因为我们在第一步的 引入 springcloud包管理依赖的pom
已经帮我们定义好了 springcloud <version>
.
2.1 创建父工程统一依赖的版本管理
这里拿一个我写过的项目做介绍,这是一个建议的商城项目,源代码地址: https://gitee.com/T-OPEN/skywalking-demo
- ratel-skywalking-common 项目的公共包,用来存放通用的工具类以及需要在各个服务之间需要传递的实体类。
- ratel-skywalking-gateway 网关。
- ratel-skywalking-goods 商品服务。
- ratel-skywalking-order 订单服务。订单服务会调用商品服务,来获取某一个订单里包含的商品详情。
- ratel-skywalking-notice 通知服务。
首选我们我们需要新建一个空的父工程用来管理pom,这里使用dependencyManagement统一管理子模块的依赖版本,版本号使用获取方式,方便后期修改维护:
<?xml version="1.0" encoding="UTF-8"?>
<project xmlns="http://maven.apache.org/POM/4.0.0" xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance"
xsi:schemaLocation="http://maven.apache.org/POM/4.0.0 https://maven.apache.org/xsd/maven-4.0.0.xsd">
<modelVersion>4.0.0</modelVersion>
<parent>
<groupId>org.springframework.boot</groupId>
<artifactId>spring-boot-starter-parent</artifactId>
<version>2.3.12.RELEASE</version>
<relativePath/> <!-- lookup parent from repository -->
</parent>
<groupId>com.ratel.skywalking</groupId>
<artifactId>ratel-skywalking-parent</artifactId>
<version>0.0.1-SNAPSHOT</version>
<name>ratel-skywalking-parent</name>
<description>Demo of Spring Cloud project for skywalking</description>
<packaging>pom</packaging>
<modules>
<module>ratel-skywalking-common</module>
<module>ratel-skywalking-gateway</module>
<module>ratel-skywalking-goods</module>
<module>ratel-skywalking-order</module>
<module>ratel-skywalking-notice</module>
</modules>
<properties>
<skywalking.demo.verion>0.0.1-SNAPSHOT</skywalking.demo.verion>
<java.version>1.8</java.version>
<spring.boot.version>2.3.12.RELEASE</spring.boot.version>
<spring.cloud.version>Hoxton.SR12</spring.cloud.version>
<spring.cloud.alibaba.version>2.2.8.RELEASE</spring.cloud.alibaba.version>
<lombok.version>1.18.20</lombok.version>
<hutool.version>5.8.11</hutool.version>
<skywalking.version>8.9.0</skywalking.version>
<knife4j.version>3.0.3</knife4j.version>
<ratel-skywalking.verion>0.0.1-SNAPSHOT</ratel-skywalking.verion>
</properties>
<dependencyManagement>
<dependencies>
<!-- 统一依赖管理 -->
<dependency>
<groupId>org.springframework.boot</groupId>
<artifactId>spring-boot-dependencies</artifactId>
<version>${spring.boot.version}</version>
<type>pom</type>
<scope>import</scope>
</dependency>
<dependency>
<groupId>org.springframework.cloud</groupId>
<artifactId>spring-cloud-dependencies</artifactId>
<version>${spring.cloud.version}</version>
<type>pom</type>
<scope>import</scope>
</dependency>
<dependency>
<groupId>com.alibaba.cloud</groupId>
<artifactId>spring-cloud-alibaba-dependencies</artifactId>
<version>${spring.cloud.alibaba.version}</version>
<type>pom</type>
<scope>import</scope>
</dependency>
<dependency>
<groupId>org.apache.skywalking</groupId>
<artifactId>apm-toolkit-logback-1.x</artifactId>
<version>${skywalking.version}</version>
</dependency>
<dependency>
<groupId>org.apache.skywalking</groupId>
<artifactId>apm-toolkit-trace</artifactId>
<version>${skywalking.version}</version>
</dependency>
<dependency>
<groupId>org.apache.skywalking</groupId>
<artifactId>apm-toolkit-opentracing</artifactId>
<version>${skywalking.version}</version>
</dependency>
<dependency>
<groupId>cn.hutool</groupId>
<artifactId>hutool-all</artifactId>
<version>${hutool.version}</version>
</dependency>
<dependency>
<groupId>com.github.xiaoymin</groupId>
<artifactId>knife4j-spring-boot-starter</artifactId>
<version>${knife4j.version}</version>
</dependency>
<dependency>
<groupId>com.ratel.skywalking</groupId>
<artifactId>ratel-skywalking-common</artifactId>
<version>${ratel-skywalking.verion}</version>
</dependency>
</dependencies>
</dependencyManagement>
<build>
<plugins>
<plugin>
<groupId>org.springframework.boot</groupId>
<artifactId>spring-boot-maven-plugin</artifactId>
</plugin>
</plugins>
</build>
</project>
2.2 创建公共使用的 common工程
ratel-skywalking-common
是整个工程的公共类的,他的pom内容如下,这里我们首选引入引入父工程依赖 方便依赖管理,为了方便开发 我们引入了 lombok
。
<?xml version="1.0" encoding="UTF-8"?>
<project xmlns="http://maven.apache.org/POM/4.0.0"
xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance"
xsi:schemaLocation="http://maven.apache.org/POM/4.0.0 http://maven.apache.org/xsd/maven-4.0.0.xsd">
<modelVersion>4.0.0</modelVersion>
<!--引入父工程依赖 方便依赖管理-->
<parent>
<groupId>com.ratel.skywalking</groupId>
<artifactId>ratel-skywalking-parent</artifactId>
<version>0.0.1-SNAPSHOT</version>
</parent>
<artifactId>ratel-skywalking-common</artifactId>
<packaging>jar</packaging>
<dependencies>
<!--lombok相关-->
<dependency>
<groupId>org.projectlombok</groupId>
<artifactId>lombok</artifactId>
<scope>provided</scope>
</dependency>
</dependencies>
<build>
<plugins>
<plugin>
<groupId>org.springframework.boot</groupId>
<artifactId>spring-boot-maven-plugin</artifactId>
<configuration>
<mainClass>none</mainClass> <!-- 取消查找本项目下的Main方法:为了解决Unable to find main class的问题 -->
<classifier>execute</classifier> <!-- 为了解决依赖模块找不到此模块中的类或属性 -->
<excludes>
<exclude>
<groupId>org.projectlombok</groupId>
<artifactId>lombok</artifactId>
</exclude>
</excludes>
</configuration>
</plugin>
</plugins>
</build>
</project>
大家可以注意我这里引入 lombok
时并没有 指定的 <version>
,但是查看依赖管理,已经成功引入的了 lombok,版本号是 1.18.20
,这也是正我们在 父工程pom中声明的lombok的版本。
然后在工程里创建 GoodsEntity ,方便在 ratel-skywalking-order 调用 ratel-skywalking-goods 时 GoodsEntity的传递,而不是 分别在2个工程里定义2遍。后续只需要在 2个工程里引入 ratel-skywalking-common 工程即可。
2.3 创建子工程并引入父工程的依赖以及公共工程
这里我们以 创建 ratel-skywalking-order
工程为例,剩下来的 ratel-skywalking-gateway,ratel-skywalking-goods, ratel-skywalking-notice
都差不多。pom内容如下:
<?xml version="1.0" encoding="UTF-8"?>
<project xmlns="http://maven.apache.org/POM/4.0.0" xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance"
xsi:schemaLocation="http://maven.apache.org/POM/4.0.0 https://maven.apache.org/xsd/maven-4.0.0.xsd">
<modelVersion>4.0.0</modelVersion>
<parent>
<groupId>com.ratel.skywalking</groupId>
<artifactId>ratel-skywalking-parent</artifactId>
<version>0.0.1-SNAPSHOT</version>
</parent>
<artifactId>ratel-skywalking-order</artifactId>
<name>ratel-skywalking-order</name>
<description>ratel-skywalking-order</description>
<properties>
<java.version>1.8</java.version>
</properties>
<dependencies>
<!--springboot相关-->
<dependency>
<groupId>org.springframework.boot</groupId>
<artifactId>spring-boot-starter-web</artifactId>
</dependency>
<dependency>
<groupId>org.springframework.boot</groupId>
<artifactId>spring-boot-starter-test</artifactId>
<scope>test</scope>
</dependency>
<!--nacos相关-->
<dependency>
<groupId>com.alibaba.cloud</groupId>
<artifactId>spring-cloud-starter-alibaba-nacos-discovery</artifactId>
</dependency>
<!--openfegin相关-->
<dependency>
<groupId>org.springframework.cloud</groupId>
<artifactId>spring-cloud-starter-openfeign</artifactId>
</dependency>
<!--lombok相关-->
<dependency>
<groupId>org.projectlombok</groupId>
<artifactId>lombok</artifactId>
<scope>provided</scope>
</dependency>
<!--skywalking相关-->
<dependency>
<groupId>org.apache.skywalking</groupId>
<artifactId>apm-toolkit-logback-1.x</artifactId>
</dependency>
<dependency>
<groupId>org.apache.skywalking</groupId>
<artifactId>apm-toolkit-trace</artifactId>
</dependency>
<dependency>
<groupId>org.apache.skywalking</groupId>
<artifactId>apm-toolkit-opentracing</artifactId>
</dependency>
<!--hutool工具包-->
<dependency>
<groupId>cn.hutool</groupId>
<artifactId>hutool-all</artifactId>
</dependency>
<!--knife4j接口文档-->
<dependency>
<groupId>com.github.xiaoymin</groupId>
<artifactId>knife4j-spring-boot-starter</artifactId>
</dependency>
<!--本项目的公共实体类,公共utils等 -->
<dependency>
<groupId>com.ratel.skywalking</groupId>
<artifactId>ratel-skywalking-common</artifactId>
</dependency>
<dependency>
<groupId>com.ratel.skywalking</groupId>
<artifactId>ratel-skywalking-goods-api</artifactId>
<version>${skywalking.demo.verion}</version>
</dependency>
</dependencies>
<build>
<plugins>
<plugin>
<groupId>org.springframework.boot</groupId>
<artifactId>spring-boot-maven-plugin</artifactId>
</plugin>
</plugins>
</build>
</project>
这里我们首选引入引入父工程依赖 ratel-skywalking-parent
方便依赖管理,然后引入公共工程:ratel-skywalking-common
和其他一些依赖。为了方便展示效果,这里我们只需要处理 按照同样的方法 新建ratel-skywalking-gateway,ratel-skywalking-goods,
, ratel-skywalking-notice
本次演示用不到可以不管了。想偷懒的小伙伴也可以直接把我上文的提到的源码下载下来,直接编译启动也行。
2.4 搭建启动环境
由于我们的服务是微服务,故还需要一个nacos,具体环境搭建可以参考 skywalking从入门到精通(一)-环境搭建,
启动脚本路径:\nacos-server-2.0.1\nacos\bin\startup-standalone.cmd
我们本机测试使用nacos的单机模式即可。
启动以后打开浏览器访问 http://localhost:8848/nacos/#/login 登录即可。默认的账号密码: nacos / nacos
2.5 启动程序开始验证
我们可以先启动 ratel-skywalking-gateway
,然后启动 ratel-skywalking-order
, ratel-skywalking-goods
,启动完成以后
我们在nacos上看到我们的三个服务均已启动成功。
接下来我们就可以访问接口 :http://localhost:9010/ratel-order/order/getOrder 进行测试了。
三、总结
上面一系列讲解都是比较基础的微服务下的依赖管理方式, 希望大家能有所收获,大家如果有什么疑问可以评论留言告诉我,我看到都会及时解答各位的疑问。