还在crud?快来学习架构设计啦---微服务下的依赖管理(maven篇)

这篇具有很好参考价值的文章主要介绍了还在crud?快来学习架构设计啦---微服务下的依赖管理(maven篇)。希望对大家有所帮助。如果存在错误或未考虑完全的地方,请大家不吝赐教,您也可以点击"举报违法"按钮提交疑问。

一、前言

2023年口罩放开的第一年,大多数人都是想着重新开始,抓住金三银四的好时机,找到心仪的工作和符合岗位要求的人才,一起整装出发。我们理想的状态是,经济已经在恢复了,那么就业市场也应该恢复了。然而现实是残酷的,海投无回应依然是常态。据互联网第三方平台统计,企业用人需求每月新增10万+,Java人才缺口高达42.5万,并以每年20%左右的速度增长。然而招聘市场却割裂严重,HR抱怨招人难,程序员抱怨拿不到offer。这是为何?拨开现象看本质:无非是双方需求错位。
在IT业发展初始阶段,初级Java程序员足以满足企业需求,但IT业发展至今,行业细分越发精细,企业需求也随时改变,要求程序员 “来之即用”,拥有更多解决复杂问题的能力。

最直观的表现就是,企业招聘要求再度提高,并在薪资上不断加码。

以下是字节2020年和2022年发布的Java程序员招聘启事:
还在crud?快来学习架构设计啦---微服务下的依赖管理(maven篇)
单从招聘启事上可以看出,想要在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:
图一:
还在crud?快来学习架构设计啦---微服务下的依赖管理(maven篇)
如上图所示这是让我们先引入 springcloud包管理依赖的pom,这种写法并不会把springcloud 的所有包依赖引入我们的工程,相当于一个声明。当你的工程里需要用到某一个依赖的时候,只要需要像下图一样写上需要引入的包的 <groupId><artifactId>.
还在crud?快来学习架构设计啦---微服务下的依赖管理(maven篇)
可能有的友友就有点好奇这里我们并没有指定版本,maven能成功引入吗?还在crud?快来学习架构设计啦---微服务下的依赖管理(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 通知服务。
    还在crud?快来学习架构设计啦---微服务下的依赖管理(maven篇)

首选我们我们需要新建一个空的父工程用来管理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的版本。

还在crud?快来学习架构设计啦---微服务下的依赖管理(maven篇)

然后在工程里创建 GoodsEntity ,方便在 ratel-skywalking-order 调用 ratel-skywalking-goods 时 GoodsEntity的传递,而不是 分别在2个工程里定义2遍。后续只需要在 2个工程里引入 ratel-skywalking-common 工程即可。

还在crud?快来学习架构设计啦---微服务下的依赖管理(maven篇)

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 本次演示用不到可以不管了。想偷懒的小伙伴也可以直接把我上文的提到的源码下载下来,直接编译启动也行。还在crud?快来学习架构设计啦---微服务下的依赖管理(maven篇)

2.4 搭建启动环境

由于我们的服务是微服务,故还需要一个nacos,具体环境搭建可以参考 skywalking从入门到精通(一)-环境搭建,
启动脚本路径:\nacos-server-2.0.1\nacos\bin\startup-standalone.cmd
我们本机测试使用nacos的单机模式即可。
还在crud?快来学习架构设计啦---微服务下的依赖管理(maven篇)
启动以后打开浏览器访问 http://localhost:8848/nacos/#/login 登录即可。默认的账号密码: nacos / nacos
还在crud?快来学习架构设计啦---微服务下的依赖管理(maven篇)

2.5 启动程序开始验证

我们可以先启动 ratel-skywalking-gateway,然后启动 ratel-skywalking-orderratel-skywalking-goods,启动完成以后
我们在nacos上看到我们的三个服务均已启动成功。
还在crud?快来学习架构设计啦---微服务下的依赖管理(maven篇)
接下来我们就可以访问接口 :http://localhost:9010/ratel-order/order/getOrder 进行测试了。

三、总结

上面一系列讲解都是比较基础的微服务下的依赖管理方式, 希望大家能有所收获,大家如果有什么疑问可以评论留言告诉我,我看到都会及时解答各位的疑问。
还在crud?快来学习架构设计啦---微服务下的依赖管理(maven篇)文章来源地址https://www.toymoban.com/news/detail-418249.html

到了这里,关于还在crud?快来学习架构设计啦---微服务下的依赖管理(maven篇)的文章就介绍完了。如果您还想了解更多内容,请在右上角搜索TOY模板网以前的文章或继续浏览下面的相关文章,希望大家以后多多支持TOY模板网!

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处: 如若内容造成侵权/违法违规/事实不符,请点击违法举报进行投诉反馈,一经查实,立即删除!

领支付宝红包 赞助服务器费用

相关文章

  • 云原生环境下的安全风险与安全架构设计

    随着云计算和容器技术的发展,云原生应用已经成为企业和开发者的新选择。然而,云原生环境也给企业带来了一系列安全挑战。本文将分析云原生环境下的安全风险,并提出相应的安全架构设计策略。 一、云原生环境下的安全风险 云原生环境具有动态性、弹性和分布式的

    2024年02月15日
    浏览(36)
  • 微服务架构下的认证鉴权解决方案

    单体应用在向微服务化架构演进时,需要考虑如何解决服务认证授权的问题。如果处理不好,会引发架构的混乱,带来安全、性能、难以维护的问题。 以最典型的包含WEB页面的具备登录态管理的系统为例。在最初阶段,登录鉴权一般通过cookie+redis分布式session来实现。 ​在服

    2024年02月02日
    浏览(33)
  • SpringCloud Gateway 在微服务架构下的最佳实践

    作者:徐靖峰(岛风) 本文整理自云原生技术实践营广州站 Meetup 的分享,其中的经验来自于我们团队开发的阿里云 CSB 2.0 这款产品,其基于开源 SpringCloud Gateway 开发,在完全兼容开源用法的前提下,做了诸多企业级的改造,涉及功能特性、稳定性、安全、性能等方面。 从功

    2024年02月14日
    浏览(40)
  • Eureka注册中心:实现微服务架构下的服务发现与治理的艺术(一)

    本系列文章简介:         在本系列文章中,我们将深入探讨 Eureka 注册中心在微服务架构中的应用和实践。我们将介绍 Eureka的基本原理、关键特性以及配置和优化方法 。同时,我们还将分享如何通过 监控和日志分析 来保障Eureka注册中心的稳定运行。希望通过本文的阅

    2024年02月21日
    浏览(45)
  • Spring Boot与Feign:微服务架构下的优雅通信

    本文将详细介绍在Spring Boot框架中如何使用Feign进行微服务之间的优雅通信。我们将从Feign的基本原理讲起,然后逐步展开使用Feign的完整流程和步骤,包括代码示例和详细注释。通过本文,读者将能够轻松掌握Feign在Spring Boot微服务架构中的应用。 Feign是一个声明式的Web Servi

    2024年02月21日
    浏览(51)
  • 快速上手Spring Cloud 十一:微服务架构下的安全与权限管理

    快速上手Spring Cloud 一:Spring Cloud 简介 快速上手Spring Cloud 二:核心组件解析 快速上手Spring Cloud 三:API网关深入探索与实战应用 快速上手Spring Cloud 四:微服务治理与安全 快速上手Spring Cloud 五:Spring Cloud与持续集成/持续部署(CI/CD) 快速上手Spring Cloud 六:容器化与微服务化

    2024年04月22日
    浏览(44)
  • 《招聘 ERP 系统架构师指南:微服务、云计算与高负载下的挑战》

    在服装行业,ERP系统的顺畅运行对企业至关重要。为了确保您招聘到一位能够应对微服务架构、公有云环境以及高负载挑战的卓越架构师,以下是一份详细的面试指南。 技术深度与系统架构 微服务架构: 问题:请详细解释微服务架构在您设计的ERP系统中的应用,以及它如何

    2024年03月19日
    浏览(29)
  • 如何利用容器与中间件实现微服务架构下的高可用性和弹性扩展

    本文分享自天翼云开发者社区《如何利用容器与中间件实现微服务架构下的高可用性和弹性扩展》,作者:c****w 在当今的互联网时代,微服务架构已经成为许多企业选择的架构模式,它能够提高系统的灵活性、可维护性和可扩展性。然而,微服务架构下的高可用性和弹性扩展

    2024年01月19日
    浏览(61)
  • 【概念】还在为fabric而烦恼?这是在我理解下的fabric 关键概念,拥有这一篇就够了

    如果,非要在每一条链中评选出几个比较好用且概念简单的链的话,公有链就是Bitcoin(比特币网络) 和 Ethereum(以太坊),私有链也是以太坊,而联盟链可以说是很少很少国产的FISCO-BCOS算一个 咦?我们这不是hyperledger fabric(以下简称fabric)的专场吗?怎么没有他呢? 是这

    2024年02月12日
    浏览(40)
  • 【10秒开服】幻兽帕鲁全自动部署教程,难道你还想手动搭建游戏服务器吗?快来学习这个简单又快速的方法!

    在帕鲁的世界,你可以选择与神奇的生物「帕鲁」一同享受悠闲的生活,也可以投身于与偷猎者进行生死搏斗的冒险。帕鲁可以进行战斗、繁殖、协助你做农活,也可以为你在工厂工作。你也可以将它们进行售卖,或肢解后食用。 引用自:https://store.steampowered.com/app/1623730/P

    2024年02月19日
    浏览(44)

觉得文章有用就打赏一下文章作者

支付宝扫一扫打赏

博客赞助

微信扫一扫打赏

请作者喝杯咖啡吧~博客赞助

支付宝扫一扫领取红包,优惠每天领

二维码1

领取红包

二维码2

领红包