微服务入门-笔记

server/2025/2/22 15:33:13/

微服务入门-笔记

介绍

这个mvn工程里边包含了微服务里最基础的服务拆分、基于nacos的服务注册和发现、配置中心以及OpenFeign版的远程调用。

初始化这个工程是来源于阿里云的脚手架,https://start.aliyun.com/,从这上边创建一个包含各种依赖的工程,然后下载下来,再把里边初始的src给删了就ok了。其实从阿里云上边下载这个初始工程主要是帮我们做好了springboot、springcloud和springcloud-alibaba三个版本的统一,剩下还有好多操作要我们自己完成。

依赖

为了以后稍方便点,我就把自己的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><groupId>cn.ac.evo.review</groupId><artifactId>root</artifactId><version>0.0.1-SNAPSHOT</version><packaging>pom</packaging><name>root</name><description>Demo project for Spring Boot</description><modules></modules><properties><java.version>17</java.version><project.build.sourceEncoding>UTF-8</project.build.sourceEncoding><project.reporting.outputEncoding>UTF-8</project.reporting.outputEncoding><spring-boot.version>2.7.6</spring-boot.version><spring-cloud-alibaba.version>2021.0.5.0</spring-cloud-alibaba.version><spring-cloud.version>2021.0.5</spring-cloud.version></properties><dependencies><dependency><groupId>org.springframework.boot</groupId><artifactId>spring-boot-starter-web</artifactId></dependency><dependency><groupId>com.alibaba.cloud</groupId><artifactId>spring-cloud-starter-alibaba-nacos-config</artifactId></dependency><dependency><groupId>com.alibaba.cloud</groupId><artifactId>spring-cloud-starter-alibaba-nacos-discovery</artifactId></dependency><dependency><groupId>org.springframework.cloud</groupId><artifactId>spring-cloud-starter-loadbalancer</artifactId></dependency><dependency><groupId>org.springframework.cloud</groupId><artifactId>spring-cloud-starter-openfeign</artifactId></dependency><dependency><groupId>org.springframework.boot</groupId><artifactId>spring-boot-starter-test</artifactId><scope>test</scope></dependency></dependencies><dependencyManagement><dependencies><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>org.springframework.boot</groupId><artifactId>spring-boot-dependencies</artifactId><version>${spring-boot.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></dependencies></dependencyManagement><build><plugins><plugin><groupId>org.apache.maven.plugins</groupId><artifactId>maven-compiler-plugin</artifactId><version>3.8.1</version><configuration><source>17</source><target>17</target><encoding>UTF-8</encoding></configuration></plugin><plugin><groupId>org.springframework.boot</groupId><artifactId>spring-boot-maven-plugin</artifactId><version>${spring-boot.version}</version><configuration><mainClass>cn.ac.evo.review.root.RootApplication</mainClass><skip>true</skip></configuration><executions><execution><id>repackage</id><goals><goal>repackage</goal></goals></execution></executions></plugin></plugins></build>
</project>

模块介绍

在这里插入图片描述

common模块里放了一个公共的EmailDTO,用来规范数据传输。

email-service里模拟了一个发送邮件的接口。

user里模拟了一个发送注册时候用于身份验证的接口。

都是模拟的。

到时候调用的时候就是user调用email-service里的接口,如果能调用成功了,就说明服务注册、发现、远程调用都成功了。置于配置中心,其实只需要让其中一个服务在启动的时候,输出一下获取到的配置内容就ok了,能输出就表示成功,不能输出就是有问题。

nacos 相关的spring配置

# app名称,必须写。
spring.application.name=email-service
# 服务注册相关的
spring.cloud.nacos.discovery.server-addr=127.0.0.1:8848
spring.cloud.nacos.discovery.username=nacos
spring.cloud.nacos.discovery.password=nacos
spring.cloud.nacos.discovery.namespace=public# 配置中心相关的
spring.cloud.nacos.config.server-addr=127.0.0.1:8848
spring.cloud.nacos.config.username=nacos
spring.cloud.nacos.config.password=nacos
spring.cloud.nacos.config.contextPath=/nacos
spring.cloud.nacos.config.group=DEFAULT_GROUP
# ↓这个是在nacos: 这个冒号后边写你在nacos上写的配置文件的全名
spring.config.import=nacos:email.properties 

如果有的服务不需要读取配置文件,把刚才配置中心相关的配置给注释掉,加上这行。

spring.cloud.nacos.config.import-check.enabled=false

OpenFeign

这里挂一个FeignClient的代码,做做笔记,下次再写别的了,可以参考参考。

package user.feign;import cn.ac.evo.review.model.dto.EmailDTO;
import org.springframework.cloud.openfeign.FeignClient;
import org.springframework.http.ResponseEntity;
import org.springframework.web.bind.annotation.PostMapping;
import org.springframework.web.bind.annotation.RequestBody;@FeignClient(name = "email-service") // 通过服务名进行调用
public interface EmailFeignClient {@PostMapping("/api/email/send/default")ResponseEntity<String> sendEmail(@RequestBody EmailDTO emailDTO);
}

http://www.ppmy.cn/server/169871.html

相关文章

基于WebRTC与AI大模型接入EasyRTC:打造轻量级、高实时、强互动的嵌入式音视频解决方案

随着物联网和嵌入式技术的快速发展&#xff0c;嵌入式设备对实时音视频通信的需求日益增长。然而&#xff0c;传统的音视频解决方案往往存在体积庞大、实时性差、互动体验不佳等问题&#xff0c;难以满足嵌入式设备的资源限制和应用场景需求。 针对以上痛点&#xff0c;本文将介…

Screen Wonders for Mac v3.3.1 3D屏保应用 支持M、Intel芯片

应用介绍 Screen Wonders 是一款专为 macOS 设计的屏保应用&#xff0c;它提供了多种高质量的动态屏保选择&#xff0c;旨在为用户的屏幕增添美感和个性化元素。 如果你厌倦了桌面上静止的图片&#xff0c;如果你准备好迎接世界各地甚至平行宇宙的魔力&#xff0c;我们在这个…

【程序人生】怎样养生?关于中医的核心思想,经典著作,与西医理念的对比,优缺点

【程序人生】怎样养生?关于中医的核心思想,经典著作,与西医理念的对比,优缺点 中医学是中国传统的医学体系,其核心思想可以概括为 “整体观念”、“阴阳五行学说”和“辨证论治法”。 文章目录 【程序人生】怎样养生?关于中医的核心思想,经典著作,与西医理念的对比,优…

数字内容体验的技术支持包含哪些核心功能?

内容概要 在构建数字内容体验的技术架构时&#xff0c;技术支持的底层能力直接决定了内容运营的效能与用户互动深度。其核心功能以智能数据分析为起点&#xff0c;通过采集用户行为轨迹、设备特征及互动反馈&#xff0c;构建动态更新的用户行为图谱&#xff0c;为内容策略的持…

管道的学习

进程间通信&#xff1a;是指在操作系统中&#xff0c;两个或多个独立的进程之间进行数据交换和信息共享的一种机制 进程间通信的本质&#xff1a;先让不同的进程先看到同一份资源&#xff0c;才有通信的条件 进程间通信的目的&#xff1a; 1.将一个进程的数据发送给另一个进程…

MySQL MHA 部署全攻略:从零搭建高可用数据库架构

文章目录 1.MHA介绍2.MHA组件介绍3.集群规划4.服务器初始化5.MySQL集群部署5.1 安装MySQL集群5.2 配置一主两从5.3 测试MySQL主从5.4 赋予MHA用户连接权限 6.安装MHA环境6.1 安装MHA Node6.2 安装MHA Manager 7.配置MHA环境8.MySQL MHA高可用集群测试8.1 通过VIP连接MySQL8.2模…

创建一个简单的spring boot+vue前后端分离项目

一、环境准备 此次实验需要的环境&#xff1a; jdk、maven、nvm和node.js 开发工具&#xff1a;idea或者Spring Tool Suite 4&#xff0c;前端可使用HBuilder X&#xff0c;数据库Mysql 下面提供maven安装与配置步骤和nvm安装与配置步骤&#xff1a; 1、maven安装与配置 1…

GCC编译器(含预处理/编译/汇编/链接四阶段详解)

GCC编译器&#xff08;含预处理/编译/汇编/链接四阶段详解&#xff09; 1. 预处理阶段&#xff08;生成 .i 文件&#xff09;2. 编译阶段&#xff08;生成 .s 文件&#xff09;3. 汇编阶段&#xff08;生成 .o 文件&#xff09;4. 链接阶段&#xff08;生成可执行文件&#xff…