最容易学会的springboot gralde spring cloud 多模块微服务项目

简介: 最容易学会的springboot gralde spring cloud 多模块微服务项目
Sping Cloud
服务发现组件 Eureka

Eureka Server 服务中心

Eureka Client 启动 就会注册到Server

  1. 用到的库
    spring-cloud-starter-netflix-eureka-server
    spring-cloud-starter-netflix-eureka-client
  2. 注解
    @EnableEurekaServer
    @EnableEurekaClient
  3. application.yml 配置信息
//服务端
server:
  port: 6868
eureka:
  client:
    service-url:
      defaultZone: http://127.0.0.1:${server.port}/eureka/
    register-with-eureka: false
    fetch-registry: false
spring:
  application:
    name: study-eureka
    //客户端

server:
  port: 8087
eureka:
  client:
    service-url:
      defaultZone: http://127.0.0.1:6868/eureka/
  instance:
    prefer-ip-address: true
spring:
  application:
    name: study-admin

  1. 打开网页可以看到http://localhost:6868/
Feign实现服务间的调用(默认带有负载均衡)

Feign是简化Java HTTP客户端开发的工具(java-to-httpclient-binder),它的灵感

来自于Retrofit、JAXRS-2.0和WebSocket。Feign的初衷是降低统一绑定Denominator到

HTTP API的复杂度,不区分是否为restful


  1. spring-cloud-starter-openfeign
  2. 注解

@EnableFeignClients
@EnableDiscoveryClient
创建FeignClient接口

@FeignClient(value = "study-api", fallback = ApiClientImpl.class)
@Component
public interface ApiClient {
    //, @RequestHeader(value = "token", required = false) String token
    @PostMapping(value = "/api/test")
    R<String> test(@RequestParam(value = "data") String data);
}
熔断器Hystrix
  1. 配置
 feign:
  hystrix:
    enabled: true
  1. 代码
   @Component
public class ApiClientImpl implements ApiClient {

    @Override
    public R<String> test(String data) {
        return RUtil.success("熔断器起作用了" + data);
    }
}
微服务网关Zuul

微服务网关是介于客户端和服务器端之间的中间层,所有的外部请求都会先经过微服务网关,然后通过spring

-application-name 转发对应的服务

spring-cloud-starter-netflix-zuul

  1. 注解
    @EnableZuulProxy
  2. 路由转发
zuul:
  routes:
    study-api:
      path: /api/**
      serviceId: study-api
    study-admin:
      path: /admin/**
      serviceId: study-admin
  1. 过滤器
package com.ityu.studyadminzuul.filter;

import com.netflix.zuul.ZuulFilter;
import com.netflix.zuul.context.RequestContext;
import com.netflix.zuul.exception.ZuulException;
import org.apache.commons.lang3.StringUtils;
import org.springframework.stereotype.Component;

import javax.servlet.http.HttpServletRequest;
import java.io.UnsupportedEncodingException;
import java.net.URLEncoder;

@Component
public class WebFilter extends ZuulFilter {
    @Override
    public String filterType() {
        return "pre";
    }

    @Override
    public int filterOrder() {
        return 0;
    }

    @Override
    public boolean shouldFilter() {
        return true;
    }

    @Override
    public Object run() throws ZuulException {
        System.out.println("拦截器启动了");
        RequestContext currentContext = RequestContext.getCurrentContext();
        HttpServletRequest request = currentContext.getRequest();
        if (request.getMethod().equals("OPTIONS")) {
            return null;
        }
        String url = request.getRequestURL().toString();
        if (url.indexOf("/admin/login") > 0) {
            return null;
        }

        String header = request.getHeader("token");
        if (StringUtils.isNotEmpty(header)) {
            currentContext.addZuulRequestHeader("token", header);
        } else {
            try {
                //URLDecoder.decode("xxxxx","UTF-8"); 解码 微服务获取时解码
                //在网关添加内容是编码
                currentContext.addZuulRequestHeader("token", URLEncoder.encode("没有头的信息", "UTF-8"));
            } catch (UnsupportedEncodingException e) {
                e.printStackTrace();
            }
        }
        return null;
    }
}


集中配置组件SpringCloudConfig

config server

config client

 spring-cloud-config-server
spring-cloud-starter-config

  1. 注解
    @EnableConfigServer
    3.配置信息
 cloud:
    config:
      server:
        git:
          uri: https://gitee.com/lanlingkeji_yu.jl/srpingcloudstudyconfig.git

4.客户端配置信息 bootstrap.yml

spring:
  cloud:
    config:
      name: api
      profile: dev
      lable: master
      uri: http://127.0.0.1:12000
消息总线组件SpringCloudBus

SpringCloudBus来实现配置的自动更新


  1. spring-cloud-stream-binder-rabbit
    spring-cloud-bus
    spring-boot-starter-actuator
  2. 注解
    @RefreshScope 刷新自定义配置信息
  3. 配置
management:
  endpoints:
    web:
      exposure:
        include: bus-refresh
  1. 客戶端也要配置 rabbitmq 信息
相关文章
|
2月前
|
Dubbo Java 应用服务中间件
Spring Cloud Dubbo:微服务通信的高效解决方案
【10月更文挑战第15天】随着信息技术的发展,微服务架构成为企业应用开发的主流。Spring Cloud Dubbo结合了Dubbo的高性能RPC和Spring Cloud的生态系统,提供高效、稳定的微服务通信解决方案。它支持多种通信协议,具备服务注册与发现、负载均衡及容错机制,简化了服务调用的复杂性,使开发者能更专注于业务逻辑的实现。
68 2
|
2月前
|
Dubbo Java 应用服务中间件
Dubbo学习圣经:从入门到精通 Dubbo3.0 + SpringCloud Alibaba 微服务基础框架
尼恩团队的15大技术圣经,旨在帮助开发者系统化、体系化地掌握核心技术,提升技术实力,从而在面试和工作中脱颖而出。本文介绍了如何使用Dubbo3.0与Spring Cloud Gateway进行整合,解决传统Dubbo架构缺乏HTTP入口的问题,实现高性能的微服务网关。
|
2月前
|
JSON Java 数据格式
【微服务】SpringCloud之Feign远程调用
本文介绍了使用Feign作为HTTP客户端替代RestTemplate进行远程调用的优势及具体使用方法。Feign通过声明式接口简化了HTTP请求的发送,提高了代码的可读性和维护性。文章详细描述了Feign的搭建步骤,包括引入依赖、添加注解、编写FeignClient接口和调用代码,并提供了自定义配置的示例,如修改日志级别等。
109 1
|
2月前
|
人工智能 文字识别 Java
SpringCloud+Python 混合微服务,如何打造AI分布式业务应用的技术底层?
尼恩,一位拥有20年架构经验的老架构师,通过其深厚的架构功力,成功指导了一位9年经验的网易工程师转型为大模型架构师,薪资逆涨50%,年薪近80W。尼恩的指导不仅帮助这位工程师在一年内成为大模型架构师,还让他管理起了10人团队,产品成功应用于多家大中型企业。尼恩因此决定编写《LLM大模型学习圣经》系列,帮助更多人掌握大模型架构,实现职业跃迁。该系列包括《从0到1吃透Transformer技术底座》、《从0到1精通RAG架构》等,旨在系统化、体系化地讲解大模型技术,助力读者实现“offer直提”。此外,尼恩还分享了多个技术圣经,如《NIO圣经》、《Docker圣经》等,帮助读者深入理解核心技术。
SpringCloud+Python 混合微服务,如何打造AI分布式业务应用的技术底层?
|
2月前
|
负载均衡 网络协议 Java
浅谈Springboot与Springcloud的区别
浅谈Springboot与Springcloud的区别
40 1
|
2月前
|
监控 Java 对象存储
监控与追踪:如何利用Spring Cloud Sleuth和Netflix OSS工具进行微服务调试
监控与追踪:如何利用Spring Cloud Sleuth和Netflix OSS工具进行微服务调试
46 1
|
3月前
|
负载均衡 Java 网络架构
实现微服务网关:Zuul与Spring Cloud Gateway的比较分析
实现微服务网关:Zuul与Spring Cloud Gateway的比较分析
138 5
|
3月前
|
前端开发 API 微服务
SpringCloud微服务之间使用Feign调用不通情况举例
SpringCloud微服务之间使用Feign调用不通情况举例
621 2
|
2月前
|
负载均衡 算法 Nacos
SpringCloud 微服务nacos和eureka
SpringCloud 微服务nacos和eureka
67 0
|
3月前
|
SQL 监控 druid
springboot-druid数据源的配置方式及配置后台监控-自定义和导入stater(推荐-简单方便使用)两种方式配置druid数据源
这篇文章介绍了如何在Spring Boot项目中配置和监控Druid数据源,包括自定义配置和使用Spring Boot Starter两种方法。