这期内容当中小编将会给大家带来有关怎么在SpringCloud中使用Eureka实现服务之间的传递数据,文章内容丰富且以专业的角度为大家分析和叙述,阅读完这篇文章希望大家可以有所收获。
一、使用RestTemplate+Ip方式:
在用户微服务(服务提供者)中写好被调用的查询方法
@RestController @RequestMapping("/user") public class UserController { @Resource private UserRepository userRepository; @GetMapping("/getallUser") public List<User> getUserPage(){ return userRepository.findAll(); } @GetMapping("/getUser") public User getUser(Long userId){ return userRepository.getOne(userId); } }
@Repository public interface UserRepository extends JpaRepository<User,Long> { }
@Entity @Table(name="TM_USER") @JsonIgnoreProperties(value={"hibernateLazyInitializer","handler","fieldHandler"}) public class User implements Serializable, Cloneable { @Id @GeneratedValue(strategy= GenerationType.AUTO) private Long userId; /** * 登录名 */ @Column(name = "USER_NAME") private String userName; /** * 用户名 */ @Column private String name; /** * 薪水 */ @Column private BigDecimal balance; /** * 年龄 get set方法已省略 自行添加 */ @Column private int age;}
Ok,服务提供者已经写好,下面开始编写服务消费者
@SpringBootApplication @EnableEurekaClient //启用eureka客户端 public class MicroserviceSimplecConsumerOrderServerApplication { @Bean public RestTemplate restTemplate(){ return new RestTemplate(); } public static void main(String[] args) { SpringApplication.run(MicroserviceSimplecConsumerOrderServerApplication.class, args); } }
在订单微服务(服务消费者)配置文件yml中添加,其中localhost:9021改为用户微服务(服务提供者的Ip和端口)
user: urlPath: http://localhost:9021
订单服务控制层编写,此处的User为用户微服务的复制然后去掉@Column、@Table等注释只是一个临时存储对象和数据库没有任何关联
@RestController @RequestMapping("/order") public class OrderServerController { @Autowired private RestTemplate restTemplate; @Value("${user.urlPath}") private String urlPath; //获取集合方式 @GetMapping("/allUser") private List<User> getAllUser(){ ResponseEntity<List<User>> responseEntity = restTemplate.exchange("urlPath"+/user/getallUser?", HttpMethod.GET, null, new ParameterizedTypeReference<List<User>>() {}); return responseEntity.getBody(); } //获取单个对象方式 @GetMapping("/getUser") private User getUser(Long userId){ User user = restTemplate.getForObject("urlPath"+/user/getUser?userId="+userId,User.class); return user; } }
很简单就是直接把订单微服务(服务消费者)OrderServerController中的userPath替换为注册Eureka上面的服务名即可就是这么简单。假设用户微服务的服务名为:microservice-privider-user
spring: application: name: microservice-privider-user
然后就可以直接进行替换处理,即:
@GetMapping("/allUser") //返回集合 private List<User> getAllUser(){ ResponseEntity<List<User>> responseEntity = restTemplate.exchange("microservice-privider-user"+"/user/getallUser", HttpMethod.GET, null, new ParameterizedTypeReference<List<User>>() {}); return responseEntity.getBody(); } //返回对象 @GetMapping("/getUser") private User getUser(Long userId){ User user = restTemplate.getForObject("microservice-privider-user"+/user/getUser?userId="+userId,User.class); return user; }
Ok,使用第二种方式已经编写完成
使用服务名替换了固定的ip,解决了Ip硬编码不容易维护的问题
至于第三种Feign的方式会在以后讲解“Feign:声明性Rest客户端”的时候进行详细讲解
gitHub地址:https://github.com/mackjie/microservice-spring-cloud因为配置了RabbitMQ,所以请先阅读ReadMe然后进行启动项目,否则会启动报错
一、引入pom依赖
<!-- Eureka Client --> <dependency> <groupId>org.springframework.cloud</groupId> <artifactId>spring-cloud-starter-netflix-eureka-client</artifactId> </dependency>
二、启动类推荐添加@EnableEurekaClient注解
就是如果选用的注册中心是eureka,那么就推荐@EnableEurekaClient,
如果是其他的注册中心(zookeeper,consul等),那么推荐使用@EnableDiscoveryClient。
三、配置文件添加:
#eureka spring.application.name=producer #注册中心地址 eureka.client.service-url.defaultZone=http://localhost:8761/eureka #是否把自己注册 eureka.client.register-with-eureka=true #是否搜索服务信息 eureka.client.fetch-registry=true #使用ip地址注册 eureka.instance.prefer-ip-address=true #注册中心列表显示的状态 eureka.instance.instance-id=${spring.cloud.client.ip-address}:${server.port}
有两种方式:
一、ribbon(负载均衡)+restTemplate
启动类添加:
@Bean @LoadBalanced//负载均衡 public RestTemplate initRestTemplate() { return new RestTemplate();// } @Bean//负载均衡的规则,下面的是其中之一:随机,还有权重,轮询等 public IRule initIRule() { return new RandomRule(); }
RandomRule表示随机策略
RoundRobinRule表示轮询策略(默认)
WeightedResponseTimeRule表示加权策略
BestAvailableRule表示请求数最少策略
然后在controller中自动装配RestTemplate后使用 restTemplate.getForObject()调用。
二、feign(推荐)
1、引入pom依赖
<dependency> <groupId>org.springframework.cloud</groupId> <artifactId>spring-cloud-starter-openfeign</artifactId> <version>2.1.1.RELEASE</version> </dependency>
2、启动类添加@EnableFeignClients注解
3、创建一个接口,
package com.sumengnan.test.web; import org.springframework.cloud.openfeign.FeignClient; import org.springframework.web.bind.annotation.GetMapping; @FeignClient(name = "eureka",fallback = HtystrixEurekaFallback.class)//调用失败后回滚执行方法 public interface EurekaServiceApi { @GetMapping("test") String test(); }
回滚的方法:
package com.sumengnan.test.web; /** * eureka熔断回调类 */ public class HtystrixEurekaFallback implements EurekaServiceApi { @Override public String test() { return "连接失败,请稍后再试!"; } }
4、然后在controller中自动装配EurekaServiceApi后使用eurekaServiceApi.test()调用。
上述就是小编为大家分享的怎么在SpringCloud中使用Eureka实现服务之间的传递数据了,如果刚好有类似的疑惑,不妨参照上述分析进行理解。如果想知道更多相关知识,欢迎关注亿速云行业资讯频道。
免责声明:本站发布的内容(图片、视频和文字)以原创、转载和分享为主,文章观点不代表本网站立场,如果涉及侵权请联系站长邮箱:is@yisu.com进行举报,并提供相关证据,一经查实,将立刻删除涉嫌侵权内容。