springboot + eureka集群,实现注册中心,实现负载均衡

2023-11-07

搭建eureka集群

- 新建一个boot项目

File-》new-》project
在这里插入图片描述如图选择-》next-》起名字如下
在这里插入图片描述->next -》finish

- 新建3个注册中心
以三个注册中心为例,想多的自己加
项目名字上-》new-》module
在这里插入图片描述-》next-》起名字-》next
选择依赖
Web —spring web这个就别选了,截图截多一个。选后两个就行
Security ----Spring Security
Spring Cloud Discovery----Eureka Server
在这里插入图片描述修改pom.xml,解决java8版本的问题,后面每个服务都要改这个,我的idea默认jdk6,导致启动失败,加了这个就默认为JDK1.8了

<build>
        <plugins>
            <plugin>
                <groupId>org.springframework.boot</groupId>
                <artifactId>spring-boot-maven-plugin</artifactId>
                <executions>
                    <execution>
                        <goals>
                            <goal>repackage</goal><!--可以把依赖的包都打包到生成的Jar包中-->
                        </goals>
                    </execution>
                </executions>
            </plugin>
            <plugin>
                <groupId>org.apache.maven.plugins</groupId>
                <artifactId>maven-compiler-plugin</artifactId>
                <version>2.3.2</version>
                <configuration>
                    <!--指定jdk版本-->
                    <source>1.8</source>
                    <target>1.8</target>
                </configuration>
            </plugin>
        </plugins>
    </build>

配置application.yml
注意defaultZone,本例是三个注册中心,中心1配置地址2、3,中心2配置地址3、1,中心3配置地址1、2。注意顺序,
对于注册中心eureka默认优先注册到最前面那个,也就是1注册到2,2注册到3,3注册到1.
当其中一个注册中心死掉后,才会注册到其他地方。如2死掉了,1会注册到第二个地址3上面,结果就成了1注册到3,3注册到1.

eureka:
  instance:
    hostname: localhost
  client:
    #  eureka.client.registerWithEureka:false   因为自己是为注册中心,不需要自己注册自己  集群模式下改为 ture,注册到其他注册中中心
    # 是否将该实例信息注册到其他eureka server上;如果设置为false,那么该server无法被其他server发现,但是仍然可以发现其他server
    #  fetchRegistry:false来表明自己是一个eureka server.
    registerWithEureka: true
    #表示是否向eureka注册服务,即在eureka中注册自己,默认为true,此处应该设置为true,只有一个注册中心时为false;
    #是否允许该客户端从eureka server上获取注册信息
    fetchRegistry: true
    serviceUrl:
      #    集群模式:
      defaultZone: http://admin:admin2@${eureka.instance.hostname}:8762/eureka/,http://admin:admin3@${eureka.instance.hostname}:8763/eureka/
      #    单例模式:
	#defaultZone: http://admin:admin1${eureka.instance.hostname}:8761/eureka/
      #没有密码时,去掉security依赖,配置:    defaultZone: http://${eureka.instance.hostname}:${server.port}/eureka/
  server:
    #设为false,关闭自我保护,即Eureka server在云心光器件会去统计心跳失败比例在15分钟之内是否低于85%,如果低于85%,EurekaServer
    #会将这些事例保护起来,让这些事例不会过期,但是在保护器内如果刚哈这个服务提供者非正常下线了,此时服务消费者会拿到一个无效的服务
    #实例,此时调用会失败,对于这个问题需要服务消费者端有一些容错机制,如重试、断路器等;
    enable-self-preservation: false
    #扫描失效服务的间隔时间(单位是毫秒,摩恩是60*1000),即60s
    eviction-interval-timer-in-ms: 10000


server:
  #服务端口号
  port: 8761

spring:
  application:
    name: a-server1
#  #安全登入用户设置   ####******** 用户名密码,三个项目建议不一样
  security:
    user:
      name: admin
      password: admin1

其他两个按这个配置,记得改defaultZone,和password
修改启动类
加两个注解就可以了。

@EnableEurekaServer
@SpringBootApplication
public class AiServer1Application {

    public static void main(String[] args) {
        SpringApplication.run(AiServer1Application.class, args);
    }

}

本来这样就可以启动了,但是我们配置了security安全验证,
而新版(Spring Cloud 2.0 以上)的security默认启用了csrf检验,要在eurekaServer端配置security的csrf检验为false
新建一个类WebSecurityConfig,关闭csrf检验

@EnableWebSecurity
public class WebSecurityConfig extends WebSecurityConfigurerAdapter {

    @Override
    protected void configure(HttpSecurity http) throws Exception {
        http.csrf().disable();
        super.configure(http);
    }
}

其他两个按这个写,到此一个简单的eureka集群就搭建完成了。
启动会报错,不用管,这个是注册到其他注册中心时没扫描到,原因是启动注册中心1时2还没启动,总得有个先后,都启动了就好了。

com.sun.jersey.api.client.ClientHandlerException: java.net.ConnectException: Connection refused: connect

登录http://IP:8761/
登录http://IP:8762/
登录http://IP:8763/
本地启动要输入密码
注册1:注册2注册3可以看出,1注册在2,2注册在3,3注册在1.
注册中心完成。
可以尝试关闭其中某个看看注册情况。可能有时差大概30s。

搭建服务提供者client

笔者将上述注册中心布置到了服务器。所以服务提供者就按照服务器配置了,本地的话,把ip改为localhost就行。
新建提供者1
项目名字-》new-》mudule-》next-》起名字-》next
选择依赖(两个)
Web —spring web
Spring Cloud Discovery----Eureka Server
配置application.yml

spring:
  application:
    name: ai-client1
server:
  port: 8769
eureka:
  instance:
  	# 服务提供者地址
    hostname: localhost
    # 注册中心ip(根据实际,本地写localhost)
    hostname1: 47.102.111.111
  client:
    serviceUrl:
      # 集群时,其实只需要配置一个地址,当这个地址的注册中心挂掉后,会自动注册到其他注册中心
      # 配置多个注册中心地址的好处是:启动之前,某个注册中心挂掉了,会抛出异常,但是也会正常注册到其他某个注册中心
      defaultZone: http://admin:admin1@${eureka.instance.hostname1}:8761/eureka/,http://admin:admin2@${eureka.instance.hostname1}:8762/eureka/,http://admin:admin3@${eureka.instance.hostname1}:8763/eureka/

启动类

@RestController
@EnableEurekaClient
@SpringBootApplication
public class AiClient1Application {

    public static void main(String[] args) {
        SpringApplication.run(AiClient1Application.class, args);
    }
    /**
     * 假如这个客户端要提供一个getUser的方法
     * @return
     */
    @GetMapping(value = "/getUser")
    @ResponseBody
    public Map<String,Object> getUser(@RequestParam Integer id){
        Map<String,Object> data = new HashMap<String,Object>();
        data.put("id",id);
        data.put("userName","admin");
        data.put("from","provider-A");
        return data;
    }
}

新建提供者2
内容跟提供者1一样。
为了测试负载均衡,不要改服务名字,必须保持一致。
spring.application.name=ai-client1
修改一下端口号和输出结果就行,不同输出结果验证是哪个服务处理的请求。
如data.put(“from”,“provider-B1111111111”);
能看出不同就行。

启动提供者,发现3号注册中心会有这两个服务

搭建服务消费者customer

搭建一个消费者customer
新建流程通服务提供者。
application.yml配置如下

eureka:
  instance:
    # 服务提供者地址
    hostname: localhost
    # 注册中心ip(根据实际,本地写localhost)
    hostname1: 47.102.111.111
  client:
    serviceUrl: #注册中心的注册地址
#      defaultZone: http://localhost:8761/eureka/,http://localhost:8762/eureka/,http://localhost:8763/eureka/
      defaultZone: http://skyworth:skyworth1@${eureka.instance.hostname1}:8761/eureka/,http://skyworth:skyworth2@${eureka.instance.hostname1}:8762/eureka/,http://skyworth:skyworth3@${eureka.instance.hostname1}:8763/eureka/
server:
  port: 8759  #服务端口号
spring:
  application:
    name: service-consumer #服务名称--调用的时候根据名称来调用该服务的方法

修改启动类

/**
 * Eureka客户端-消费者
 */
@RestController
@EnableEurekaClient
@SpringBootApplication
public class AiConsumer1Application {

    @Autowired
    RestTemplate restTemplate;

    public static void main(String[] args) {
        SpringApplication.run(AiConsumer1Application.class, args);
    }

    /**
     * 实例化RestTemplate
     * @return
     */
    @LoadBalanced
    @Bean
    public RestTemplate rest() {
        return new RestTemplate();
    }

    /**
     * Rest服务端使用RestTemplate发起http请求,然后得到数据返回给前端----gotoUser是为了区分getUser怕小伙伴晕头
     * @param id
     * @return
     */
    @GetMapping(value = "/gotoUser")
    @ResponseBody
    public Map<String,Object> getUser(@RequestParam Integer id){
        Map<String,Object> data = new HashMap<String,Object>();
        /**
         * 小伙伴发现没有,地址居然是http://service-provider
         * 居然不是http://127.0.0.1:8082/
         * 因为他向注册中心注册了服务,服务名称service-provider,我们访问service-provider即可
         *
         * 注意要容错,当发生错误时重新掉这个接口,防止发生某个服务挂掉,请求失败的情况。
         */
        data = restTemplate.getForObject("http://ai-client1/getUser?id="+id, Map.class);
        return data;
    }
}

启动消费者,发现3号注册中心会有这个服务。

访问地址:http:localhost:8759/gotoUser?id=1
多次访问,发现会分别从服务1,服务2 返回结果。(服务1,2 返回结果要设置的不一样,才能看出来的。)

总结几个坑

1.解决java8版本的问题,后面每个服务都要改这个,我的idea默认jdk6,导致启动失败,加了这个就默认为JDK1.8了
2.新版(Spring Cloud 2.0 以上)的security默认启用了csrf检验,要在eurekaServer端配置security的csrf检验为false
3.使用了安全验证,注册地址要加上username:password@,
http://username:password@${eureka.instance.hostname}:8762/eureka/
4.将注册中心部署到服务器之后,如果服务要连接服务时,
要设置eureka.instance.hostname=localhost,如果写成服务器ip,连接会成功,但是消费者会调用失败,因为跳转的时候会跳转到,服务器上的这个服务,而实际的服务在本地。

本文内容由网友自发贡献,版权归原作者所有,本站不承担相应法律责任。如您发现有涉嫌抄袭侵权的内容,请联系:hwhale#tublm.com(使用前将#替换为@)

springboot + eureka集群,实现注册中心,实现负载均衡 的相关文章

随机推荐

  • 循序渐进,学会用pyecharts绘制玫瑰图

    循序渐进 学会用pyecharts绘制玫瑰图 玫瑰图简介 玫瑰图全称南丁格尔玫瑰图 是英国护士和统计学家弗罗伦斯 南丁格尔发明的 又名为极区图 南丁格尔自己常昵称这类图为鸡冠花图 coxcomb 用以表达军医院季节性的死亡率 提供给那些不太
  • adb install 多个设备时指定设备

    在emulator 5554模拟器上安装ebook apk adb s emulator 5554 install ebook apk 在真机上安装ebook apk adb s HT9BYL904399 install ebook apk
  • 可孚医疗:「最懂互联网」的医疗器械企业是如何炼成的?

    如果说钉钉在过去的标签是软件 是低代码 那么在医疗这个赛道里 这些标签已经不足以成为钉钉价值的侧写 除了固有标签之外 在可孚医疗的场景里 钉钉可以连接 可以成为智能BI 也更可以做到内外部协同等 作者 皮爷 出品 产业家 1000分 打开可
  • GetX项目级实战

    在使用了 Provider 一年后 遇到了很多阻力 期间尝试过 BLoC MobX 均不如意 一个样本代码太多 使用复杂 一个生产代码要等很久 难道 Flutter 就没有诸如原生 Android 的 jetpack 套装一样方便的套件吗
  • Cyclic Components CodeForces - 977E(找简单环)

    先求连通块 再看是不是所有连通块的点的度数为2 如果是那就是简单环 只不过我觉得我这个代码时间复杂度还是挺高的 虽然这题没啥问题 不过我看有他人是一遍用dfs找环 一遍判断找到环时的那个点的度数是不是2 AC代码 include
  • ES:一次分片设计问题导致的故障

    现象 1 单节点CPU持续高 2 写入骤降 3 线程池队列积压 但没有reject 4 使用方没有记录日志 排查 1 ES监控 只能看到相应的结果指标 无法反应出原因 2 ES日志 大量日志打印相关异常 routate等调用栈 core a
  • Java是解释型还是编译型语言?

    Java是解释型还是编译型语言 首先JVM是什么 JVM虚拟机也是java的运行环境 因为所有系统平台都支持JVM 所以实现了Java的跨平台 我们可以把JVM虚拟机比作人 有食物供我们食用 当我们需要吃哪种食物的时候就吃哪个实物 在JVM
  • 深度学习笔记(五) 代价函数的梯度求解过程和方法

    作为自己的笔记系列 方便自己查阅和理解 1 什么是梯度 梯度 本意是一个向量 矢量 当某一函数在某点处沿着该方向的方向导数取得该点处的最大值 即函数在该点处沿方向变化最快 变化率最大 为该梯度的模 在二元函数的情形 设函数z f x y 在
  • Linux C中对json格式数组数据的生成与解析

    在网络通信中 数据经常被做成json格式的来进行传输 那么我们怎么在linux系统中去做json格式的数据呢 怎么将接收到的json格式的数据解析出来呢 1 linux json库的安装 1 下载json c源码包 2 解压json c的源
  • Android Studio NDK开发注意

    1 如果JNILibs armeabi中有相应的库文件 编绎重新生成的 so文件不会打包到新的apk中
  • 干掉 “重复代码” 的技巧有哪些?

    软件工程师和码农最大的区别就是平时写代码时习惯问题 码农很喜欢写重复代码而软件工程师会利用各种技巧去干掉重复的冗余代码 业务同学抱怨业务开发没有技术含量 用不到设计模式 Java 高级特性 OOP 平时写代码都在堆 CRUD 个人成长无从谈
  • UDP包传送字符串实现方法以及方格乱码的出现原因和解决办法

    在使用socket发送udp包传输文本时 由于包中的char型数组是定长的 且其长度大于消息长度 所以其中必有很多空元素 当接收端接收到udp包时进行转码 空元素就会被转码成方块形状的乱码 解决办法 每条消息发送完毕后添加 作为记号 接收后
  • 浏览器渲染机制 (二)浏览器主进程-浏览器内核-浏览器渲染流程

    文章目录 浏览器主进程和浏览器渲染进程的通信过程 浏览器内核 渲染进程 中线程之间的管理 GUI渲染线程与JS引擎线程互斥 JS阻塞页面加载 WebWorker JS的多线程 WebWorker与SharedWorker 总结浏览器渲染流程
  • adb通过网络连接

    1 使用USB数据线连接设备 2 在命令行输入adb tcpip 5555 5555为端口号 可以自由指定 3 断开 USB数据 此时可以连接你需要连接的 USB设备 4 再计算机命令行输入 adb connect lt 设备的IP地址 g
  • 自动计算30天内的股价最高价源代码

    我可以回答这个问题 您可以使用以下代码来计算30天内股价的最高价 复制 import pandas as pd import yfinance as yf 设置股票代码和日期范围 symbol AAPL start date 2021 01
  • Python绝技:运用Python成为顶级黑客

    Python 是一门常用的编程语言 它不仅上手容易 而且还拥有丰富的支持库 对经常需要针对自己所 处的特定场景 以极少的代码量实现所需的功能 Python绝技 运用Python成为顶级黑客结合具体的场景和真 实的案例 详述了 Python
  • 《软件测试的艺术》第三章 代码检查、走查和评审

    软件测试的艺术 第三章 代码检查 走查和评审 3 1 代码检查与走查 3 2 代码检查 3 2 1 代码检查小组 3 2 2 检查议程与注意事项 3 2 3 对事不对人 和人有关的注意事项 3 2 4 代码检查的衍生功效 3 3 用于代码检
  • 100个python算法超详细讲解:农夫过河

    100个python算法超详细讲解 谷哥技术 1 问题描述 一个农夫在河边带了一匹狼 一只羊和一棵白菜 他需要把这三样东西用 船带到河的对岸 然而 这艘船只能容下农夫本人和另外一样东西 如果农夫 不在场的话 狼会吃掉羊 羊也会吃掉白菜 请编
  • 鸿蒙内核阅读笔记-定时器

    鸿蒙内核阅读笔记 定时器 简介 核心模块 定时器 los swtmr c 介绍 阅读代码 函数部分 简介 近期在阅读鸿蒙liteOS a 由于是初次探索内核的奥秘 将一些阅读的心得进行分享 希望能在作为笔记的同时 也能帮助更多人学习 感谢图
  • springboot + eureka集群,实现注册中心,实现负载均衡

    搭建eureka集群 新建一个boot项目 File new project 如图选择 next 起名字如下 gt next finish 新建3个注册中心 以三个注册中心为例 想多的自己加 项目名字上 new module next 起名