学习SpringCloud技术前提就是学习Eureka注册服务中心,而Eureka注册服务中心,它是什么呢?今天小编就带你一起了解一下吧!!!
首先我们来解决第一问题,服务的管理。
基本架构:
了解了这么多,终于到了写代码的时候啦,现在就让我们来写一个入门案例吧!
3.1.编写EurekaServer
接下来我们创建一个项目,启动一个EurekaServer:
依然使用spring提供的快速搭建工具:
选择依赖:
完整的Pom文件:
<?xml version="1.0" encoding="UTF-8"?>
<project xmlns=".0.0" xmlns:xsi=""xsi:schemaLocation=".0.0 .0.0.xsd"><modelVersion>4.0.0</modelVersion><groupId&demo</groupId><artifactId>eureka-demo</artifactId><version>0.0.1-SNAPSHOT</version><packaging>jar</packaging><name>eureka-demo</name><description>Demo project for Spring Boot</description><parent><groupId>org.springframework.boot</groupId><artifactId>spring-boot-starter-parent</artifactId><version>2.0.1.RELEASE</version><relativePath/> <!-- lookup parent from repository --></parent><properties><project.build.sourceEncoding>UTF-8</project.build.sourceEncoding>&porting.outputEncoding>UTF-8</porting.outputEncoding><java.version>1.8</java.version><!-- SpringCloud版本,是最新的F系列 --><spring-cloud.version>Finchley.RC1</spring-cloud.version></properties><dependencies><!-- Eureka服务端 --><dependency><groupId>org.springframework.cloud</groupId><artifactId>spring-cloud-starter-netflix-eureka-server</artifactId></dependency></dependencies><dependencyManagement><dependencies><!-- SpringCloud依赖,一定要放到dependencyManagement中,起到管理版本的作用即可 --><dependency><groupId>org.springframework.cloud</groupId><artifactId>spring-cloud-dependencies</artifactId><version>${spring-cloud.version}</version><type>pom</type><scope>import</scope></dependency></dependencies></dependencyManagement><build><plugins><plugin><groupId>org.springframework.boot</groupId><artifactId>spring-boot-maven-plugin</artifactId></plugin></plugins></build><repositories><repository><id>spring-milestones</id><name>Spring Milestones</name><url>;/url><snapshots><enabled>false</enabled></snapshots></repository></repositories>
</project>
编写启动类:
@SpringBootApplication
@EnableEurekaServer // 声明这个应用是一个EurekaServer
public class EurekaDemoApplication {public static void main(String[] args) {SpringApplication.run(EurekaDemoApplication.class, args);}
}
编写配置l:
server:port: 10086 # 端口
spring:application:name: eureka-server # 应用名称,会在Eureka中显示
eureka:client:register-with-eureka: false # 是否注册自己的信息到EurekaServer,默认是truefetch-registry: false # 是否拉取其它服务的信息,默认是trueservice-url: # EurekaServer的地址,现在是自己的地址,如果是集群,需要加上其它Server的地址。defaultZone: 127.0.0.1:${server.port}/eureka
启动服务,并访问:127.0.0.1:10086/eureka
3.2user-service注册到Eureka
注册服务,就是在服务上添加Eureka的客户端依赖,客户端代码会自动把服务注册到EurekaServer中。
先添加SpringCloud依赖:
<!-- SpringCloud的依赖 -->
<dependencyManagement><dependencies><dependency><groupId>org.springframework.cloud</groupId><artifactId>spring-cloud-dependencies</artifactId><version>Finchley.RC1</version><type>pom</type><scope>import</scope></dependency></dependencies>
</dependencyManagement>
<!-- Spring的仓库地址 -->
<repositories><repository><id>spring-milestones</id><name>Spring Milestones</name><url>;/url><snapshots><enabled>false</enabled></snapshots></repository>
</repositories>
然后是Eureka客户端:
<!-- Eureka客户端 -->
<dependency><groupId>org.springframework.cloud</groupId><artifactId>spring-cloud-starter-netflix-eureka-client</artifactId>
</dependency>
通过添加@EnableDiscoveryClient来开启Eureka客户端功能
@SpringBootApplication
@EnableEurekaClient // 开启EurekaClient功能
public class UserServiceDemoApplication {public static void main(String[] args) {SpringApplication.run(UserServiceDemoApplication.class, args);}
}
编写配置
server:port: 8081
spring:datasource:url: jdbc:mysql://localhost:3306/mydb1?useUnicode=true&characterEncoding=utf8username: rootpassword: 123456driver-class-name: sql.jdbc.Driverapplication:name: user-service # 应用名称
eureka:client:service-url: # EurekaServer地址defaultZone: 127.0.0.1:10086/eurekainstance:prefer-ip-address: true # 当调用getHostname获取实例的hostname时,返回ip而不是host名称ip-address: 127.0.0.1 # 指定自己的ip信息,不指定的话会自己寻找
注意:
3.3消费者从Eureka获取服务
接下来我们修改consumer-demo,尝试从EurekaServer获取服务。
方法与消费者类似,只需要在项目中添加EurekaClient依赖,就可以通过服务名称来获取信息了!
1)添加依赖:
先添加SpringCloud依赖:
<!-- SpringCloud的依赖 -->
<dependencyManagement><dependencies><dependency><groupId>org.springframework.cloud</groupId><artifactId>spring-cloud-dependencies</artifactId><version>Finchley.RC1</version><type>pom</type><scope>import</scope></dependency></dependencies>
</dependencyManagement>
<!-- Spring的仓库地址 -->
<repositories><repository><id>spring-milestones</id><name>Spring Milestones</name><url>;/url><snapshots><enabled>false</enabled></snapshots></repository>
</repositories>
然后是Eureka客户端:
<!-- Eureka客户端 -->
<dependency><groupId>org.springframework.cloud</groupId><artifactId>spring-cloud-starter-netflix-eureka-client</artifactId>
</dependency>
2)在启动类开启Eureka客户端
@SpringBootApplication
@EnableDiscoveryClient // 开启Eureka客户端
public class UserConsumerDemoApplication {@Beanpublic RestTemplate restTemplate() {return new RestTemplate();}public static void main(String[] args) {SpringApplication.run(UserConsumerDemoApplication.class, args);}
}
3)修改配置:
server:port: 8080
spring:application:name: user-consumer # 应用名称
eureka:client:service-url: # EurekaServer地址defaultZone: 127.0.0.1:10086/eurekainstance:prefer-ip-address: true # 当其它服务获取地址时提供ip而不是hostnameip-address: 127.0.0.1 # 指定自己的ip信息,不指定的话会自己寻找
4)修改user-consumer-demo项目中的UserDao代码,用DiscoveryClient类的方法,根据服务名称,获取服务实例:
// 必须导入org.springframework.cloud.client.discovery.DiscoveryClient@Autowiredprivate DiscoveryClient discoveryClient;public User queryUserById(Long id){//1、 根据user-service获取user-serivce 的集群的信息List<ServiceInstance> instances = Instances("user-service");//2、由于我们没有集群,只有一个,所以直接取出第一个ServiceInstance instance = (0);//3、拼接URLString url = ""Host()+":"Port()+"/user/"+id;// 使用restTemplate发起请求ResponseEntity<User> entity = ForEntity(url, User.class);// 获取返回对象User user = Body();return user;}
5)Debug跟踪运行:
生成的URL:
访问结果:
好啦!以上就是小编的内容啦,如果不懂,请在下方留言! 如有错误,欢迎大家请在下方评论!!!!
本文发布于:2024-02-02 21:24:52,感谢您对本站的认可!
本文链接:https://www.4u4v.net/it/170688029246532.html
版权声明:本站内容均来自互联网,仅供演示用,请勿用于商业和其他非法用途。如果侵犯了您的权益请与我们联系,我们将在24小时内删除。
留言与评论(共有 0 条评论) |