0020SpringBoot使用SpringCloud中的eureka实现远程调用
要实现远程调用,主要需要三个module:一个注册中心、一个服务提供者、一个服务消费者,然后进行各自的配置和编码,详细内容如下:
1、建一个空的project,创建3各module
a、注册中心模块 eureka-server,依赖Eureka Server
b、服务提供者 provider-ticket,依赖Eureka Discovery Client
c、服务消费者 consumer-user,依赖Eureka Discovery Client

2、注册中心相关
a、编写application.yml
b、在主类上加上注解@EnableEurekaServer
3、编写服务提供者
a、编写TicketService类
b、编写TicketController类
c、配置application.yml
d、启动应用,访问controller的方法看是否成功
e、8001端口用maven打包一次,8002端口用maven打包一次,然后在cmd窗口分别用java -jar启动两个jar包,可在注册中心中查看到注册了两个服务,
此步骤是为了服务消费者调用的时候能看到负载均衡的效果
4、编写服务消费者
a、配置application.yml
b、在主类中使用@EnableDiscoveryClient注解来发现注册中心的服务,并且在主类中将RestTemplate类以@Bean的形式注册到容器中,使用
@LoadBalanced注解来达到远程调用服务提供者的时候使用负载均衡机制
c、编写UserController类,该类中使用RestTemplate来调用远程服务
2、3、4步骤具体如下:
2、注册中心相关
a、编写application.yml
#访问端口8761
server:
port: 8761
eureka:
instance:
hostname: eureka-server #注册中心实例名
client:
register-with-eureka: false #不注册自己
fetch-registry: false #不发现自己
service-url:
defaultZone: http://localhost:8761/eureka/ #服务提供者和消费者需要绑定的注册中心地址
b、在主类上加上注解@EnableEurekaServer
package com.example; import org.springframework.boot.SpringApplication;
import org.springframework.boot.autoconfigure.SpringBootApplication;
import org.springframework.cloud.netflix.eureka.server.EnableEurekaServer; @EnableEurekaServer
@SpringBootApplication
public class EurekaServerApplication { public static void main(String[] args) {
SpringApplication.run(EurekaServerApplication.class, args);
} }
3、编写服务提供者
a、编写TicketService类
package com.example.providerticket.service; import org.springframework.stereotype.Service; @Service
public class TicketService {
public String getTicket(){
System.out.println("端口是:8002");
return "《厉害了,我的国》";
}
}
b、编写TicketController类
package com.example.providerticket.controller; import com.example.providerticket.service.TicketService;
import org.springframework.beans.factory.annotation.Autowired;
import org.springframework.web.bind.annotation.GetMapping;
import org.springframework.web.bind.annotation.RestController; @RestController
public class TicketController {
@Autowired
TicketService ticketService;
//消费方调用该方法时也使用该路径
@GetMapping("/ticket")
public String getTicket(){
return ticketService.getTicket();
}
}
启动服务,并访问如下:

c、配置application.yml
server:
port: 8002 #访问端口8002,打不同端口包时可改为8001
spring:
application:
name: provider-ticket #名字可以任意取
eureka:
instance:
prefer-ip-address: true #使用ip地址
client:
service-url:
defaultZone: http://localhost:8761/eureka/ #与注册中心填写的内容相同
d、启动应用,访问controller的方法看是否成功

e、8001端口用maven打包一次,8002端口用maven打包一次,然后在cmd窗口分别用java -jar启动两个jar包,可在注册中心中查看到注册了两个服务,
此步骤是为了服务消费者调用的时候能看到负载均衡的效果

4、编写服务消费者
a、配置application.yml
server:
port: 8200
spring:
application:
name: consumer-user
eureka:
instance:
prefer-ip-address: true
client:
service-url:
defaultZone: http://localhost:8761/eureka/
b、在主类中使用@EnableDiscoveryClient注解来发现注册中心的服务,并且在主类中将RestTemplate类以@Bean的形式注册到容器中,使用
@LoadBalanced注解来达到远程调用服务提供者的时候使用负载均衡机制
package com.example.consumeruser; import org.springframework.boot.SpringApplication;
import org.springframework.boot.autoconfigure.SpringBootApplication;
import org.springframework.boot.autoconfigure.web.client.RestTemplateAutoConfiguration;
import org.springframework.boot.web.client.RestTemplateBuilder;
import org.springframework.cloud.client.discovery.EnableDiscoveryClient;
import org.springframework.cloud.client.loadbalancer.LoadBalanced;
import org.springframework.context.annotation.Bean;
import org.springframework.web.client.RestTemplate; //加上@EnableDiscoveryClient注解,消费者才能发现注册中心的服务
@EnableDiscoveryClient
@SpringBootApplication
public class ConsumerUserApplication { public static void main(String[] args) {
SpringApplication.run(ConsumerUserApplication.class, args);
} //RestTemplate是消费者访问远程服务的工具,所以需要先注册到容器中,用的时候使用@Autowired取出来就可以用
//@LoadBalanced注解用于说明调用远程服务时使用负载均衡机制
@Bean
@LoadBalanced
public RestTemplate restTemplate(){
return new RestTemplate();
} }
c、编写UserController类,该类中使用RestTemplate来调用远程服务
package com.example.consumeruser.controller; import org.springframework.beans.factory.annotation.Autowired;
import org.springframework.web.bind.annotation.GetMapping;
import org.springframework.web.bind.annotation.RestController;
import org.springframework.web.client.RestTemplate; @RestController
public class UserController {
@Autowired
RestTemplate restTemplate;
@GetMapping("buy")
public String buyTicket(String name){
//http://后不需要写ip地址和端口号,这样才能根据服务提供方的应用名字去负载均衡到不同的ip和端口
//provider-ticket(不区分大小写) 为服务提供方在注册中心注册的application名字
//ticket为服务提供方访问对应方法时使用的路径
String str = restTemplate.getForObject("http://provider-ticket/ticket",String.class);
return name + "购买了" + str;
}
} 启动消费者服务,并访问测试:

说明消费者能够调用到服务提供者的方法,且观察控制台,轮流打印8001端口和8002端口,说明负载均衡也生效了。
如有理解不到之处,望指正。
0020SpringBoot使用SpringCloud中的eureka实现远程调用的更多相关文章
- 在maven项目中 配置代理对象远程调用crm
1 在maven项目中配置代理对象远程调用crm 1.1 在项目的pom.xml中引入CXF的依赖 <dependency> <groupId>org.apache.cxf&l ...
- 阶段5 3.微服务项目【学成在线】_day09 课程预览 Eureka Feign_07-Feign远程调用-Feign测试
2.2.1 Feign介绍 Feign是Netflix公司开源的轻量级rest客户端,使用Feign可以非常方便的实现Http 客户端.Spring Cloud引入 Feign并且集成了Ribbon实 ...
- 阶段5 3.微服务项目【学成在线】_day09 课程预览 Eureka Feign_06-Feign远程调用-Ribbon测试
2.1.2 Ribbon测试 Spring Cloud引入Ribbon配合 restTemplate 实现客户端负载均衡.Java中远程调用的技术有很多,如: webservice.socket.rm ...
- 阶段5 3.微服务项目【学成在线】_day09 课程预览 Eureka Feign_05-Feign远程调用-客户端负载均衡介绍
2 Feign远程调用 在前后端分离架构中,服务层被拆分成了很多的微服务,服务与服务之间难免发生交互,比如:课程发布需要调用 CMS服务生成课程静态化页面,本节研究微服务远程调用所使用的技术. 下图是 ...
- SpringCloud(二) - Eureka注册中心,feign远程调用,hystrix降级和熔断
1.项目模块介绍 2. 父项目 主要依赖 spring-cloud 的 版本控制 <properties> <!-- springCloud 版本 --> <scd.ve ...
- SpringCloud学习(3)——Eureka服务注册中心及服务发现
Eureka概述: Eureka是Netflix的一个子模块, 也是核心模块之一.Eureka是一个基于REST的服务, 用于定位服务, 以实现云端中间层服务发现和故障转移.服务注册与发现对于微服务框 ...
- JAVAEE——BOS物流项目08:配置代理对象远程调用crm服务、查看定区中包含的分区、查看定区关联的客户
1 学习计划 1.定区关联客户 n 完善CRM服务中的客户查询方法 n 在BOS项目中配置代理对象远程调用crm服务 n 调整定区关联客户页面 n 实现定区关联客户 2.查看定区中包含的分区 n 页面 ...
- ABAP RFC远程调用
声明:原创作品,转载时请注明文章来自SAP师太技术博客( 博/客/园www.cnblogs.com):www.cnblogs.com/jiangzhengjun,并以超链接形式标明文章原始出处,否则将 ...
- 《Spring技术内幕》学习笔记17——Spring HTTP调用器实现远程调用
1.Spring中,HTTPInvoker(HTTP调用器)是通过基于HTTP协议的分布式远程调用解决方案,和java RMI一样,HTTP调用器也需要使用java的对象序列化机制完成客户端和服务器端 ...
随机推荐
- HTTP权威指南-URL与资源
URL与资源 URL是URI的子集 方案(http),主机(www.baidu.com),路径(/home/logo.png) 方案,其实有很多,HTTP.HTTPS.FTP,SMTP等等. http ...
- WCF-方法重载
一.服务端重载 一般写法直接重载,但是会报错,如下. [ServiceContract] public interface IService1 { [OperationContract] string ...
- 数据结构:队列queue 函数push() pop size empty front back
队列queue: push() pop() size() empty() front() back() push() 队列中由于是先进先出,push即在队尾插入一个元素,如:可以输出:Hello W ...
- go 数据渲染到终端 01
package main import ( "fmt" "text/template" "os" ) type Person struct ...
- 软件包 javax.naming了解
Context 此接口表示一个命名上下文,它由一组名称到对象的绑定组成. Name Name 接口表示一个一般名称,即一个有序的组件序列. NameParser 此接口用于解析取自分层的名称空间 ...
- Scratch编程:游泳的火柴人(四)
“ 上节课的内容全部掌握了吗?反复练习了没有,编程最好的学习方法就是练习.练习.再练习.一定要记得多动手.多动脑筋哦~~” 01 — 游戏介绍 这是一款简单的小游戏,实现了一个手绘的火柴人在水里游泳. ...
- PB笔记之数据窗口大小自适应的方式
1.在OPEN 事件中设置数据窗口大小属性 tab_1.tabpage_6.dw_6.x=0tab_1.tabpage_6.dw_6.y=0tab_1.tabpage_6.dw_6.width=thi ...
- PB笔记之第一行数据不能删除的解决方法
如果第一行数据不能删除,则单独写SQL进行删除 window lw_sheet //dw_1.event pfc_deleterow()long i String ls_manidInteger ls ...
- 编译内核提示mkimage command not found – U-Boot images will not be built
转載與:http://www.mr-wu.cn/u-boot-tools-binary-package-in-ubuntu/ ubuntu 编译linux kernel时提示: “mkimage” ...
- nfs挂载文件
1. 安装必备插件 以防centos7默认没有启动nfs服务 yum -y install nfs-utils rpcbind # 启动 rpcbind 和配置开机自启动 systemctl sta ...