最容易学会的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 信息
相关文章
|
1月前
|
Java 开发者 微服务
从单体到微服务:如何借助 Spring Cloud 实现架构转型
**Spring Cloud** 是一套基于 Spring 框架的**微服务架构解决方案**,它提供了一系列的工具和组件,帮助开发者快速构建分布式系统,尤其是微服务架构。
192 69
从单体到微服务:如何借助 Spring Cloud 实现架构转型
|
4天前
|
搜索推荐 NoSQL Java
微服务架构设计与实践:用Spring Cloud实现抖音的推荐系统
本文基于Spring Cloud实现了一个简化的抖音推荐系统,涵盖用户行为管理、视频资源管理、个性化推荐和实时数据处理四大核心功能。通过Eureka进行服务注册与发现,使用Feign实现服务间调用,并借助Redis缓存用户画像,Kafka传递用户行为数据。文章详细介绍了项目搭建、服务创建及配置过程,包括用户服务、视频服务、推荐服务和数据处理服务的开发步骤。最后,通过业务测试验证了系统的功能,并引入Resilience4j实现服务降级,确保系统在部分服务故障时仍能正常运行。此示例旨在帮助读者理解微服务架构的设计思路与实践方法。
43 16
|
1天前
|
缓存 安全 Java
Spring Boot 3 集成 Spring Security + JWT
本文详细介绍了如何使用Spring Boot 3和Spring Security集成JWT,实现前后端分离的安全认证概述了从入门到引入数据库,再到使用JWT的完整流程。列举了项目中用到的关键依赖,如MyBatis-Plus、Hutool等。简要提及了系统配置表、部门表、字典表等表结构。使用Hutool-jwt工具类进行JWT校验。配置忽略路径、禁用CSRF、添加JWT校验过滤器等。实现登录接口,返回token等信息。
65 12
|
7天前
|
监控 JavaScript 数据可视化
建筑施工一体化信息管理平台源码,支持微服务架构,采用Java、Spring Cloud、Vue等技术开发。
智慧工地云平台是专为建筑施工领域打造的一体化信息管理平台,利用大数据、云计算、物联网等技术,实现施工区域各系统数据汇总与可视化管理。平台涵盖人员、设备、物料、环境等关键因素的实时监控与数据分析,提供远程指挥、决策支持等功能,提升工作效率,促进产业信息化发展。系统由PC端、APP移动端及项目、监管、数据屏三大平台组成,支持微服务架构,采用Java、Spring Cloud、Vue等技术开发。
|
7天前
|
存储 安全 Java
Spring Boot 3 集成Spring AOP实现系统日志记录
本文介绍了如何在Spring Boot 3中集成Spring AOP实现系统日志记录功能。通过定义`SysLog`注解和配置相应的AOP切面,可以在方法执行前后自动记录日志信息,包括操作的开始时间、结束时间、请求参数、返回结果、异常信息等,并将这些信息保存到数据库中。此外,还使用了`ThreadLocal`变量来存储每个线程独立的日志数据,确保线程安全。文中还展示了项目实战中的部分代码片段,以及基于Spring Boot 3 + Vue 3构建的快速开发框架的简介与内置功能列表。此框架结合了当前主流技术栈,提供了用户管理、权限控制、接口文档自动生成等多项实用特性。
37 8
|
22天前
|
运维 监控 Java
为何内存不够用?微服务改造启动多个Spring Boot的陷阱与解决方案
本文记录并复盘了生产环境中Spring Boot应用内存占用过高的问题及解决过程。系统上线初期运行正常,但随着业务量上升,多个Spring Boot应用共占用了64G内存中的大部分,导致应用假死。通过jps和jmap工具排查发现,原因是运维人员未设置JVM参数,导致默认配置下每个应用占用近12G内存。最终通过调整JVM参数、优化堆内存大小等措施解决了问题。建议在生产环境中合理设置JVM参数,避免资源浪费和性能问题。
65 3
|
1月前
|
负载均衡 Java 开发者
深入探索Spring Cloud与Spring Boot:构建微服务架构的实践经验
深入探索Spring Cloud与Spring Boot:构建微服务架构的实践经验
155 5
|
2月前
|
Java 应用服务中间件
SpringBoot获取项目文件的绝对路径和相对路径
SpringBoot获取项目文件的绝对路径和相对路径
139 1
SpringBoot获取项目文件的绝对路径和相对路径
|
2月前
|
分布式计算 关系型数据库 MySQL
SpringBoot项目中mysql字段映射使用JSONObject和JSONArray类型
SpringBoot项目中mysql字段映射使用JSONObject和JSONArray类型 图像处理 光通信 分布式计算 算法语言 信息技术 计算机应用
66 8
|
2月前
|
存储 运维 安全
Spring运维之boot项目多环境(yaml 多文件 proerties)及分组管理与开发控制
通过以上措施,可以保证Spring Boot项目的配置管理在专业水准上,并且易于维护和管理,符合搜索引擎收录标准。
56 2