在第一节已经大概说明了Eureka,这一节直接开始搭建
1.新建一个module
这个步骤直接略过,直接上截图
2.引入pom文件,配置yml及启动类
pom
<?xml version="1.0" encoding="UTF-8"?>
<project xmlns="http://maven.apache.org/POM/4.0.0"
xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance"
xsi:schemaLocation="http://maven.apache.org/POM/4.0.0 http://maven.apache.org/xsd/maven-4.0.0.xsd">
<parent>
<artifactId>spring-cloud-eureka</artifactId>
<groupId>com.cto</groupId>
<version>1.0-SNAPSHOT</version>
</parent>
<modelVersion>4.0.0</modelVersion>
<artifactId>cloud-eureka</artifactId>
<packaging>jar</packaging>
<dependencies>
<!--Eureka 服务-->
<dependency>
<groupId>org.springframework.cloud</groupId>
<artifactId>spring-cloud-starter-netflix-eureka-server</artifactId>
</dependency>
<!-- 引入 BootWeb 功能 -->
<dependency>
<groupId>org.springframework.boot</groupId>
<artifactId>spring-boot-starter-web</artifactId>
</dependency>
<dependency>
<groupId>org.springframework.boot</groupId>
<artifactId>spring-boot-starter-actuator</artifactId>
</dependency>
</dependencies>
<!--
SpringBoot的Maven插件, 能够以Maven的方式为应用提供SpringBoot的支持,可以将
SpringBoot应用打包为可执行的jar或war文件, 然后以通常的方式运行SpringBoot应用
-->
<build>
<plugins>
<plugin>
<groupId>org.springframework.boot</groupId>
<artifactId>spring-boot-maven-plugin</artifactId>
</plugin>
</plugins>
</build>
</project>
yml
server:
port: 7000
spring:
application:
name: cloud-eureka
eureka:
instance:
#eureka服务端的实例名称
hostname: localhost
client:
#false表示不往注册中心注册自己
register-with-eureka: false
#false表示自己就是注册中心,指示此客户端是否应从eureka服务器获取eureka注册表信息
fetch-registry: false
service-url:
#设置与Eureka服务交互的地址,查询服务\注册服务都需要依赖于这个地址,此处可逗号分隔配置多个来配置集群
defaultZone: http://${eureka.instance.hostname}:${server.port}/eureka/
#日志
logging:
level:
com:
cto:
cloud: debug
org:
springframework:
web: info
file: log/cto-eurake.log
启动类
package com.cto.cloud;
import org.springframework.boot.SpringApplication;
import org.springframework.boot.autoconfigure.SpringBootApplication;
import org.springframework.cloud.netflix.eureka.server.EnableEurekaServer;
/**
*
* @author Zhang Wei
* @date 2020/5/23 15:07
* @version v1.0.1
*/
@SpringBootApplication
@EnableEurekaServer
public class EurekaApplication {
public static void main(String[] args) {
SpringApplication.run(EurekaApplication.class, args);
}
}
3.修改前一节的生产者和消费者,将他们注册进服务
修改provider pom和yml
<!--EurekaClient-->
<dependency>
<groupId>org.springframework.cloud</groupId>
<artifactId>spring-cloud-starter-netflix-eureka-client</artifactId>
</dependency>
eureka:
client:
service-url:
defaultZone: http://localhost:7000/eureka/
启动类添加 @EnableEurekaClient 注解
修改完毕后pom和yml总览
<?xml version="1.0" encoding="UTF-8"?>
<project xmlns="http://maven.apache.org/POM/4.0.0"
xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance"
xsi:schemaLocation="http://maven.apache.org/POM/4.0.0 http://maven.apache.org/xsd/maven-4.0.0.xsd">
<parent>
<artifactId>spring-cloud-eureka</artifactId>
<groupId>com.cto</groupId>
<version>1.0-SNAPSHOT</version>
</parent>
<modelVersion>4.0.0</modelVersion>
<artifactId>cloud-provider</artifactId>
<packaging>jar</packaging>
<dependencies>
<!--EurekaClient-->
<dependency>
<groupId>org.springframework.cloud</groupId>
<artifactId>spring-cloud-starter-netflix-eureka-client</artifactId>
</dependency>
<!-- 引入 BootWeb 功能 -->
<dependency>
<groupId>org.springframework.boot</groupId>
<artifactId>spring-boot-starter-web</artifactId>
</dependency>
<dependency>
<groupId>org.springframework.boot</groupId>
<artifactId>spring-boot-starter-actuator</artifactId>
</dependency>
</dependencies>
<!--
SpringBoot的Maven插件, 能够以Maven的方式为应用提供SpringBoot的支持,可以将
SpringBoot应用打包为可执行的jar或war文件, 然后以通常的方式运行SpringBoot应用
-->
<build>
<plugins>
<plugin>
<groupId>org.springframework.boot</groupId>
<artifactId>spring-boot-maven-plugin</artifactId>
</plugin>
</plugins>
</build>
</project>
server:
port: 9001
spring:
application:
name: cloud-provider
eureka:
client:
service-url:
defaultZone: http://localhost:7000/eureka/
#日志
logging:
level:
com:
cto:
cloud: debug
org:
springframework:
web: info
file: log/cloud-provider.log
启动eureka、启动服务者和消费者
启动访问http://localhost:7000/ 发现生产者和消费者都注册到Eureka
4.修改consumerController,将IP的调用方式切换为ApplicationName的调用方式
修改前:private final String providerService = “http://localhost:9001/”;
修改后:private final String providerService = “http://CLOUD-PROVIDER/”;
修改后重启consumer,访问http://localhost:8001/consumer/getData 返回provider服务的数据,和之前ip访问结果一样
说明CLOUD-PROVIDER 它是在yml中配置的spring.application.name 在调用时必须使用大写
5.微服务集群拓展,将生产者配置为集群模式
本地环境有两种方式,第一种 用命令java -jar provider.jar -Dserver.port=9002
第二种 在idea拷贝一份,直接启动,如下图:
第二步在VM options 中填写-Dserver.port=9002,保存后启动
全部启动后,在Eureka中发现,生产者已经是集群模式
此时访问消费者接口,http://localhost:8001/consumer/getData 发现打印的端口一直是9001,为什么9002没生效呢?
找到Consumer服务的ApplicationContextConfig,在RestTemplate上加上注解*@LoadBalanced*,重启Consumer,再次去访问http://localhost:8001/consumer/getData
得到的结果:第一次9001 第二次 9002 第三次 9001…… 由此可见,通过*@LoadBalanced* 赋予RestTemplate负载均衡的能力,默认是轮循模式
6.Actuator拓展
<dependency>
<groupId>org.springframework.boot</groupId>
<artifactId>spring-boot-starter-actuator</artifactId>
</dependency>
这个包默认已经导入了,就是方便在此处使用,目前只是用它的修改名称及显示IP的功能
在yml文件添加
instance:
#自定义服务ID名称
instance-id: cloud-pay-9001
#显示IP地址
prefer-ip-address: true
完整yml如下
server:
port: 9001
spring:
application:
name: cloud-provider
eureka:
client:
service-url:
defaultZone: http://localhost:7000/eureka/
instance:
#自定义服务ID名称
instance-id: cloud-pay-9001
#显示IP地址
prefer-ip-address: true
#日志
logging:
level:
com:
cto:
cloud: debug
org:
springframework:
web: info
file: log/cloud-provider.log
重启后查看eureka面板
变成自己配置的名字,鼠标放上去再看左下角
显示出服务IP
这些配置不会影响注册与发现,只是方便服务多的时候能准确的定位到该服务在哪台机器上
本文是在学习过程中整理,如有错误欢迎各位大佬指正!O(∩_∩)O
陆续更新中……