3大关键点教你用Java和Spring Boot快速构建微服务架构:从零开发到高效服务注册与发现的逆袭之路

在这里插入图片描述

你好,我是忆~遂愿,全网3w+粉丝,《遂愿盈创》社群主理人。
副业启航① | 遂愿盈创(对副业感兴趣免费可入,多种赚钱实战项目等你来,一起探寻副业快速变现的途径;以及对接互联网大厂商务合作,一起来搞点小外快,认识更多互联网大咖)
目前群里已经带很多小伙伴(大部分大学生)变现几百块啦,程序员搞副业有额外加成~ 对副业感兴趣可+V : suiyuan2ying 拉你进群。

文章目录

    • 1 初入微服务架构
    • 2 技术栈选型
    • 3 服务注册与发现
      • 3.1 Eureka Server配置
      • 3.2 微服务配置
      • 3.3 用户服务接口
    • 4 服务调用
      • 4.1 服务配置
      • 4.2 服务接口
    • 5 微服务架构测试
    • 6 实际案例
      • 6.1 创建Eureka Server
      • 6.2 创建用户服务
      • 6.3 创建订单服务
      • 6.4 服务测试
    • 7 总结与展望

本文将使用过去的商业项目来探讨如何使用Java和Spring Boot框架设计一个微服务架构,重点实现服务的注册、发现和调用,很多打码了,请见谅,最后会有一个简单的demo。

1 初入微服务架构

微服务架构是一种将单一应用程序划分为一组小的、独立服务的架构风格。每个微服务负责特定功能,并通过轻量级的协议(如HTTP REST)进行通信。

在当今快速发展的Java开发领域, 微服务架构因其灵活性、可扩展性及快速迭代能力而受到广泛关注。

2 技术栈选型

在过去的实战项目用Spring Boot来搭建微服务架构,同时利用Spring Cloud来处理服务的注册、发现和治理。

当时选择的是 Java8 + Spring Boot 能快速构建微服务,减少配置麻烦,以及使用Spring Cloud提供的工具,比如Eureka、Ribbon、 Hystrix 等组件,让服务管理变得简单。

其它的细节这里就不具体展开了,主要围绕本篇文章Eureka注册中心进行展开。

3 服务注册与发现

在微服务架构中,服务注册与发现是实现服务间通信的基础,下文使用项目中的Spring Cloud Eureka来复现这一功能。

3.1 Eureka Server配置

  1. 引入依赖

在这里插入图片描述

  1. application.yml文件配置

在这里插入图片描述

  1. 在主类中添加@EnableEurekaServer注解启动Eureka Server

在这里插入图片描述

3.2 微服务配置

  1. 引入依赖

在这里插入图片描述

  1. application.yml文件中配置Eureka客户端

在这里插入图片描述

  1. 在主类中添加@EnableEurekaClient注解启动Eureka 客户端

在这里插入图片描述

3.3 用户服务接口

  1. 项目一个大模块下小模块的接口示例。

在这里插入图片描述

4 服务调用

4.1 服务配置

使用声明式HTTP客户端 Feign,来简化RESTful服务的调用,使代码更为简洁。

  1. 引入依赖

在这里插入图片描述

  1. 开启客户端

在这里插入图片描述

  1. Eureka配置

在这里插入图片描述

4.2 服务接口

其中一个获取登录账户接口

在这里插入图片描述

5 微服务架构测试

在完成上述配置后,可以通过启动所有的微服务来测试微服务架构。访问Eureka Dashboard(我本地部署是在http://localhost:8082)可以看到已注册的服务。

后面可以通过HTTP客户端(如Postman)发送请求来进行测试,这里我就不掩饰了,接下来我用一个简单的案例,感兴趣的小伙伴可以自己去尝试部署跑通。

6 实际案例

使用两个简单的微服务来实现。

一个用户服务和一个订单服务。用户服务将注册到Eureka服务器上,而订单服务将通过Eureka发现用户服务并进行调用。

6.1 创建Eureka Server

  1. 创建Spring Boot项目,选择相应的依赖项。

  2. 配置Eureka Server,在application.yml中添加如下配置:

server:
  port: 8082

eureka:
  client:
    register-with-eureka: false
    fetch-registry: false
  1. 在主类中添加@EnableEurekaServer注解:
@SpringBootApplication
@EnableEurekaServer
public class EurekaServerApplication {
    public static void main(String[] args) {
        SpringApplication.run(EurekaServerApplication.class, args);
    }
}

6.2 创建用户服务

  1. 创建Spring Boot项目,选择相应的依赖项。

  2. 配置用户服务, 在application.yml中添加如下配置:

server:
  port: 8083

spring:
  application:
    name: user-service
  eureka:
    client:
      service-url:
        defaultZone: http://localhost:8082/eureka/
  1. 创建一个简单的用户控制器 :
@RestController
@RequestMapping("/users")
public class UserController {

    private Map<Long, String> users = new HashMap<>();

    @PostMapping
    public void createUser(@RequestParam Long id, @RequestParam String name) {
        users.put(id, name);
    }

    @GetMapping("/{id}")
    public String getUser(@PathVariable Long id) {
        return users.getOrDefault(id, "User not found");
    }
}

6.3 创建订单服务

  1. 创建Spring Boot项目,选择相应的依赖项。

  2. 配置订单服务, 在application.yml中添加如下配置:

server:
  port: 8084

spring:
  application:
    name: order-service
  eureka:
    client:
      service-url:
        defaultZone: http://localhost:8082/eureka/
  1. 创建一个订单控制器调用用户服务:
@RestController
@RequestMapping("/orders")
public class OrderController {

    @Autowired
    private RestTemplate restTemplate;

    @PostMapping("/{userId}")
    public String createOrder(@PathVariable Long userId) {
        String user = restTemplate.getForObject("http://user-service/users/" + userId, String.class);
        return "Order created for user: " + user;
    }
}
  1. 在订单服务的主类中配置RestTemplate
@SpringBootApplication
@EnableDiscoveryClient
public class OrderServiceApplication {

    @Bean
    public RestTemplate restTemplate() {
        return new RestTemplate();
    }

    public static void main(String[] args) {
        SpringApplication.run(OrderServiceApplication.class, args);
    }
}
  1. 将Eureka Server,用户服务,订单服务启动。

6.4 服务测试

  1. 测试用户服务
// 使用Postman或curl创建用户
POST http://localhost:8083/users?id=1&name=John

// 查询用户
GET http://localhost:8083/users/1
  1. 测试订单服务
// 创建订单,查询用户信息:
POST http://localhost:8081/orders/1

// 结果
Order created for user: John
  1. 验证Eureka Dashboard

打开浏览器,访问http://localhost:8082,可以看到user-serviceorder-service的注册信息。

7 总结与展望

通过本文的示例,展示了如何使用Java和Spring Boot框架设计一个微服务架构,并实现服务的注册、发现和调用。

对于这种架构设计来说,不仅提升了系统的可维护性和可扩展性,还使得团队能够更快速地响应业务需求。

希望本文能为有志于微服务架构设计的开发者提供一些启示和帮助。

必须从过去的错误学习教训而非依赖过去的成功

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:/a/908806.html

如若内容造成侵权/违法违规/事实不符,请联系我们进行投诉反馈qq邮箱809451989@qq.com,一经查实,立即删除!

相关文章

ubuntu下使用pocketsphinx进行语音识别

文章目录 前言一、pocketsphinx的介绍二、ubuntu下编译三、使用示例1.模型选择2.代码示例3.自定义字典 四、交叉编译总结 前言 由于工作需要语音识别的功能&#xff0c;环境是在linux arm版上&#xff0c;所以想先在ubuntu上跑起来看一看&#xff0c;就找了一下语音识别的开源…

Redis的持久化以及性能管理

目录 一、Redis持久化概述 1.什么是Redis持久化 2.持久化方式 3.RDB持久化 3.1概念 3.2触发条件 3.3执行流程 3.4启动时加载 4. AOF持久化 4.1概念 4.2启动AOF 4.3执行流程 4.4启动时加载 5.RDB和AOF的优缺点 二、Redis性能管理 1.查看Redis内存使用 2…

科研绘图系列:R语言组合连线图和箱线图(linechart+boxplot)

文章目录 介绍加载R包数据数据预处理画图1画图2系统信息介绍 连线图(Line Chart)是一种常用的数据可视化图表,它通过将一系列数据点用直线段连接起来来展示数据随时间或有序类别变化的趋势。以下是连线图可以表示的一些内容: 时间序列数据:展示数据随时间变化的趋势,例如…

Webserver(3.1)线程

目录 创建线程终止线程连接已终止的进程二级指针 线程分离线程取消线程属性线程同步多线程卖票 创建线程 编译时需要加-pthread gcc pthread_create.c -o create -pthread#include<pthread.h> #include<stdio.h> #include<string.h> #include<unistd.h&…

WPS实现手机电脑同步文件

复制链接&#xff0c;发送微信&#xff0c;即可在手机端打开同步编辑文档。 当手机编辑文档后&#xff0c;会有如下提示: 根据提示&#xff0c;可选择文件更新版本。

ES海量数据插入如何优化性能?

2024年10月NJSD技术盛典暨第十届NJSD软件开发者大会、第八届IAS互联网架构大会在南京召开。百度文心快码总经理臧志分享了《AI原生研发新范式的实践与思考》&#xff0c;探讨了大模型赋能下的研发变革及如何在公司和行业中落地&#xff0c;AI原生研发新范式的内涵和推动经验。 …

【linux】HTTPS 协议原理

1. 了解 HTTPS 协议原理 &#xff08;一&#xff09;认识 HTTPS HTTPS 也是一种应用层协议&#xff0c;是在 HTTP 协议的基础上引入了一个加密层 因为 HTTP协议的内容都是按照文本的方式进行传输的&#xff0c;这个过程中&#xff0c;可能会出现一些篡改的情况 &#xff08;…

labview学习总结

labview学习总结 安装labview的特点一、图形化编程范式二、并行执行机制三、硬件集成能力四、应用领域优势五、开发效率六、系统集成能力**labview基本组成示意图****常用程序结构图解**结语 基础知识介绍界面前后面板的概念平铺式和层叠式 帧的概念结构类型顺序结构for循环whi…

PostgreSQL技术内幕17:PG分区表

文章目录 0.简介1.概念介绍2.分区表技术产生的背景3.分区类型及使用方式4.实现原理4.1 分区表创建4.2 分区表查询4.3 分区表写入4.4 分区表删除 0.简介 本文主要介绍PG中分区表的概念&#xff0c;产生分区表技术的原因&#xff0c;使用方式和其内部实现原理&#xff0c;旨在能…

RHCSA课后练习3(网络与磁盘)

1、配置网络&#xff1a;为网卡添加一个本网段IPV4地址&#xff0c;x.x.x.123 涉及的知识点 配置网络&#xff1a; ens160&#xff1a;en---表示以太网 wl---表示无线局域网 ww---表示无线广域网 注意&#xff1a;一个网络接口&#xff0c;可以有多个网络连接&#xff0c;但…

开发人员需要知道的 20个Git命令行技巧

前言 大多数开发人员每天都会使用 Git&#xff0c;但许多人只是对其功能略知一二。 学习一些 git 命令行技巧可以改变游戏规则&#xff0c;让你更高效、更有成效&#xff0c;对版本控制更有信心。 那么&#xff0c;让我们深入了解每个开发人员工具包中都应该有的 20 个 Git …

第十一章 综合案例--“精品课程网站“开发

1.网站的开发流程 网站开发流程通常分为几个关键阶段&#xff0c;每个阶段都有其特定的任务和目标。以下是一个典型的网站开发流程&#xff1a; 1. 需求分析 目标设定&#xff1a;明确网站的目标和目的。 受众研究&#xff1a;确定目标用户&#xff0c;了解他们的需求和偏好。…

VSCode 1.82之后的vscode server离线安装

概述 因为今天在公司开发项目的时候&#xff0c;需要离线配置vscode远程开发环境&#xff0c; 根据参考链接1配置了一遍&#xff0c;不管怎么重启&#xff0c;VSCODE都还是提示下载vscode server&#xff0c;后面在官方issue上找到了解决方案 解决方案 修改Remote SSH的配置…

Linux和,FreeRTOS 任务调度原理,r0-r15寄存器,以及移植freertos(一)

目录、 1、r0-r15寄存器&#xff0c;保护现场&#xff0c;任务切换的原理 2、freertos移植 3、freertos的任务管理。 一、前言 写这篇文章的目的&#xff0c;是之前面试官&#xff0c;刚好问到我&#xff0c;移植FreeRTOS 到mcu&#xff0c;需要做哪些步骤&#xff0c;当时回…

「Mac畅玩鸿蒙与硬件28」UI互动应用篇5 - 滑动选择器实现

本篇将带你实现一个滑动选择器应用&#xff0c;用户可以通过滑动条选择不同的数值&#xff0c;并实时查看选定的值和提示。这是一个学习如何使用 Slider 组件、状态管理和动态文本更新的良好实践。 关键词 UI互动应用Slider 组件状态管理动态数值更新用户交互 一、功能说明 在…

云服务器防火墙设置方法

云服务器防火墙设置方法通常包括&#xff1a;第一步&#xff1a;登录控制台&#xff0c;第二步&#xff1a;配置安全组规则&#xff0c;第三步&#xff1a;添加和编辑规则&#xff0c;第四步&#xff1a;启用或停用规则&#xff0c;第五步&#xff1a;保存并应用配置。云服务器…

数据中台一键大解析!

自从互联玩企业掀起了数据中台风&#xff0c;数据中台这个点马上就火起来了&#xff0c;短短几年数据中台就得到了极高的热度&#xff0c;一大堆企业也在跟风做数据中台&#xff0c;都把数据中台作为企业数字化转型的救命稻草&#xff0c;可是如果我告诉你数据中台并不是万能钥…

【第一个qt项目的实现和介绍以及程序分析】【正点原子】嵌入式Qt5 C++开发视频

qt项目的实现和介绍 1.第一个qt项目  &#xff08;1).创建qt工程    [1].创建一个存放qt的目录    [2].新建一个qt工程    [3].编译第一个工程    发生错误时的解决方式 二.QT文件介绍  (1).工程中文件简单介绍  (2).项目文件代码流程介绍    [1].添…

计算机网络:网络层 —— 网络地址转换 NAT

文章目录 网络地址转换 NAT 概述最基本的 NAT 方法NAT 转换表的作用 网络地址与端口号转换 NAPTNAT 和 NAPT 的缺陷 网络地址转换 NAT 概述 尽管因特网采用了无分类编址方法来减缓 IPv4 地址空间耗尽的速度&#xff0c;但由于因特网用户数量的急剧增长&#xff0c;特别是大量小…

【算法】【优选算法】双指针(下)

目录 一、611.有效三⻆形的个数1.1 左右指针解法1.2 暴力解法 二、LCR 179.查找总价格为目标值的两个商品2.1 左右指针解法2.2 暴力解法 三、15.三数之和3.1 左右指针解法3.2 暴力解法 四、18.四数之和4.1 左右指针解法4.2 暴力解法 一、611.有效三⻆形的个数 题目链接&#x…