当前位置:首页 > 技术 > 正文内容

Spring Cloud微服务核心组件实践

访客 技术 2026年6月23日 1

项目结构

microservice-example/
├── gateway-app/         # API网关服务 (8080)
├── member-service/      # 会员服务 (8081)
├── purchase-service/    # 采购服务 (8082)
└── pom.xml              # 父级POM文件

依赖管理

<properties>
    <java.version>17</java.version>
    <spring-boot.version>3.2.0</spring-boot.version>
    <spring-cloud.version>2023.0.0</spring-cloud.version>
    <spring-cloud-alibaba.version>2023.0.0.0</spring-cloud-alibaba.version>
</properties>

<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>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>

服务注册中心配置

Nacos安装

wget https://repo.alibaba.com/nacos-server/2.3.0/nacos-server-2.3.0.zip
unzip nacos-server-2.3.0.zip
cd nacos/bin
./startup.sh -m standalone

服务注册

# member-service配置
spring:
  application:
    name: member-service
  cloud:
    nacos:
      discovery:
        server-addr: 127.0.0.1:8848
        namespace: development

server:
  port: 8081

启动类

@SpringBootApplication
@EnableDiscoveryClient
public class MemberApplication {
    public static void main(String[] args) {
        SpringApplication.run(MemberApplication.class, args);
    }
}

API网关实现

网关依赖

<dependency>
    <groupId>org.springframework.cloud</groupId>
    <artifactId>spring-cloud-starter-gateway</artifactId>
</dependency>
<dependency>
    <groupId>com.alibaba.cloud</groupId>
    <artifactId>spring-cloud-starter-alibaba-nacos-discovery</artifactId>
</dependency>

路由配置

spring:
  cloud:
    gateway:
      routes:
        - id: member-route
          uri: lb://member-service
          predicates:
            - Path=/v1/member/**
          filters:
            - StripPrefix=1
        - id: purchase-route
          uri: lb://purchase-service
          predicates:
            - Path=/v1/purchase/**
      globalcors:
        cors-configurations:
          '[/**]':
            allowedMethods: [GET, POST]

服务调用与负载均衡

@RestController
@RequestMapping("/member")
public class MemberController {

    private final PurchaseClient purchaseClient;

    @GetMapping("/{id}/orders")
    public List<PurchaseOrder> getOrders(@PathVariable Long id) {
        return purchaseClient.fetchOrders(id);
    }
}

// Feign客户端
@FeignClient("purchase-service")
public interface PurchaseClient {
    @GetMapping("/orders/{memberId}")
    List<PurchaseOrder> fetchOrders(@PathVariable Long memberId);
}

负载均衡策略

@Configuration
public class BalancerConfig {
    @Bean
    public ReactorLoadBalancer<ServiceInstance> weightedBalancer(
            Environment env, LoadBalancerClientFactory factory) {
        String serviceName = env.getProperty(LoadBalancerClientFactory.PROPERTY_NAME);
        return new RoundRobinLoadBalancer(
            factory.getLazyProvider(serviceName, ServiceInstanceListSupplier.class),
            serviceName
        );
    }
}

系统启动流程

  1. 启动Nacos服务(8848端口)
  2. 启动member-service(8081端口)
  3. 启动purchase-service(8082端口)
  4. 启动gateway-app(8080端口)
  5. 访问 http://localhost:8080/v1/member/1001/orders

常见问题处理

  • 服务未注册:检查Nacos配置地址和命名空间
  • 网关路由失败:验证下游服务注册状态
  • 负载异常:确认lb://协议前缀配置正确
标签: Spring-Cloud

相关文章

Linux crontab 详解

1) crontab 是什么cron 是 Linux 的定时任务守护进程;crontab 是用来编辑/查看“按时间周期执行命令”的表(cron table)。常见两类:用户 crontab:每个用户一份(crontab -e 编辑)系统级 crontab / cron.d:可指定执行用户(/etc/crontab、/etc/cron.d/*)2) crontab 时间...

富文本里可以允许的 HTML 属性

一、所有标签默认允许的安全属性(极少)class        (可选)id           (通常建议禁用)title️ 注意:id 容易被滥用做锚点注入,很多系统直接禁用class 允许的话最好只允许固定前缀(如 editor-*)二、a 标签允许属性<a href="" t...

Mac 安装 Node.js 指南

方法一:通过官网安装包(最简单,适合初学者)如果你只是想快速安装并开始使用,这是最直接的方法。访问 Node.js 官网。页面会显示两个版本:LTS (Recommended For Most Users):长期支持版,最稳定。建议选这个。Current:最新特性版,包含最新功能但可能不够稳定。下载 .pkg 安装包并运行。按照安装向导点击“下一步”即可完成。方法二:使用 Homebrew 安装(...

Dom\HTML_NO_DEFAULT_NS 的副作用:自动加闭合标签

在使用Dom\HTMLDocument时,Dom\HTML_NO_DEFAULT_NS 将禁止在解析过程中设置元素的命名空间, 此设置是为了与DOMDocument向后兼容而存在的。当使用它时,已知的一个副作用就是:自动加闭合标签例如 </img> 为什么会这样?当你使用:Dom\HTML_NO_DEFAULT_NS文档会变成 无命名空间模式,此时内部更接近 XML...

Laravel 事件和监听器创建

在 Laravel 中,使用 Artisan 命令创建 Events(事件) 和 Listeners(监听器) 是非常高效的。你可以通过以下几种方式来实现:1. 手动创建单个 Event如果你只想创建一个事件类,可以使用 make:event 命令:Bashphp artisan make:event UserRegistered执行后,文件将生成在 app/Even...

自定义域名解析神器 dnsmasq

什么是 dnsmasq?dnsmasq 是一个轻量级、功能强大的网络服务工具,专为小型和中等规模网络设计。它是一个综合的网络基础设施解决方案[1]。dnsmasq 能做什么?功能说明应用场景DNS 转发与缓存将 DNS 查询转发到上游服务器(ISP、Google DNS 等),并在本地缓存结果加快 DNS 查询速度,减少外部 DNS 流量本地 DNS解析本地网络设备的主机名,无需编辑&n...

发表评论

访客

◎欢迎参与讨论,请在这里发表您的看法和观点。