最容易学会的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 信息
相关文章
|
6月前
|
负载均衡 Java API
《深入理解Spring》Spring Cloud 构建分布式系统的微服务全家桶
Spring Cloud为微服务架构提供一站式解决方案,涵盖服务注册、配置管理、负载均衡、熔断限流等核心功能,助力开发者构建高可用、易扩展的分布式系统,并持续向云原生演进。
|
6月前
|
前端开发 Java 应用服务中间件
《深入理解Spring》 Spring Boot——约定优于配置的革命者
Spring Boot基于“约定优于配置”理念,通过自动配置、起步依赖、嵌入式容器和Actuator四大特性,简化Spring应用的开发与部署,提升效率,降低门槛,成为现代Java开发的事实标准。
|
6月前
|
前端开发 Java 微服务
《深入理解Spring》:Spring、Spring MVC与Spring Boot的深度解析
Spring Framework是Java生态的基石,提供IoC、AOP等核心功能;Spring MVC基于其构建,实现Web层MVC架构;Spring Boot则通过自动配置和内嵌服务器,极大简化了开发与部署。三者层层演进,Spring Boot并非替代,而是对前者的高效封装与增强,适用于微服务与快速开发,而深入理解Spring Framework有助于更好驾驭整体技术栈。
|
6月前
|
XML Java 应用服务中间件
【SpringBoot(一)】Spring的认知、容器功能讲解与自动装配原理的入门,带你熟悉Springboot中基本的注解使用
SpringBoot专栏开篇第一章,讲述认识SpringBoot、Bean容器功能的讲解、自动装配原理的入门,还有其他常用的Springboot注解!如果想要了解SpringBoot,那么就进来看看吧!
673 2
|
7月前
|
监控 Java 数据库
从零学 Dropwizard:手把手搭轻量 Java 微服务,告别 Spring 臃肿
Dropwizard 整合 Jetty、Jersey 等成熟组件,开箱即用,无需复杂配置。轻量高效,启动快,资源占用少,内置监控、健康检查与安全防护,搭配 Docker 部署便捷,是构建生产级 Java 微服务的极简利器。
775 117
|
7月前
|
人工智能 Java 机器人
基于Spring AI Alibaba + Spring Boot + Ollama搭建本地AI对话机器人API
Spring AI Alibaba集成Ollama,基于Java构建本地大模型应用,支持流式对话、knife4j接口可视化,实现高隐私、免API密钥的离线AI服务。
6042 2
基于Spring AI Alibaba + Spring Boot + Ollama搭建本地AI对话机器人API
存储 JSON Java
808 0
|
7月前
|
人工智能 Java 开发者
【Spring】原理解析:Spring Boot 自动配置
Spring Boot通过“约定优于配置”的设计理念,自动检测项目依赖并根据这些依赖自动装配相应的Bean,从而解放开发者从繁琐的配置工作中解脱出来,专注于业务逻辑实现。
2454 0
|
人工智能 安全 Java
微服务引擎 MSE:打造通用的企业级微服务架构
微服务引擎MSE致力于打造通用的企业级微服务架构,涵盖四大核心内容:微服务技术趋势与挑战、MSE应对方案、拥抱开源及最佳实践。MSE通过流量入口、内部流量管理、服务治理等模块,提供高可用、跨语言支持和性能优化。此外,MSE坚持开放,推动云原生与AI融合,助力企业实现无缝迁移和高效运维。
670 1