Spring Cloud 如何实现服务间的调用 4.2.3
搭建订单服务工程
(1)在pom.xml中,添加spring-cloud-starter-eureka依赖,其代码如下。
<dependency>
<groupId>org.springframework.cloud</groupId>
<artifactId>spring-cloud-starter-eureka</artifactId>
</dependency>
  (2)编写配置文件。在配置文件中添加Eureka服务实例的端口号、服务端地址等信息,如文件4-8所示。
  文件4-8 application.yml
server:
port: 7900 # 指定该Eureka实例的端口号 eureka:
instance:
prefer-ip-address: true # 是否显示主机的IP
#instance-id: ${spring.cloud.client.ipAddress}:${server.port} #将Status中的显示内容也以“IP:端口号”的形式显示
client:
service-url:
defaultZone: http://localhost:8761/eureka/ # 指定Eureka服务端地址 spring:
application:
name: xcservice-eureka-order # 指定应用名称
  (3)创建订单实体类。
  文件4-9 Order.java
package com.xc.xcserviceeurekaorder.po;
public class Order {
    private String id;
    private Double price;
    private String receiverName;
    private String receiverAddress;
    private String receiverPhone;
    ...
}
  (4)创建订单控制器类。
  文件4-10 OrderController.java
package com.xc.xcserviceeurekaorder.controller; import com.xc.xcserviceeurekaorder.po.Order;
import org.springframework.web.bind.annotation.GetMapping;
import org.springframework.web.bind.annotation.PathVariable;
import org.springframework.web.bind.annotation.RestController; @RestController
public class OrderController { /**
* 通过id查询订单
*/
@GetMapping("/order/{id}")
public String findOrderById(@PathVariable String id) {
Order order = new Order();
order.setId("123");
order.setPrice(23.5);
order.setReceiverAddress("beijing");
order.setReceiverName("xiaoqiang");
order.setReceiverPhone("13422343311");
return order.toString();
} }
(5)在引导类中添加@EnableEurekaClient注解。
编写用户服务功能
@Bean
public RestTemplate restTemplate() {
return new RestTemplate();
}
在上述代码中,RestTemplate是Spring提供的用于访问Rest服务的客户端实例,它提供了多种便捷访问远程Http服务的方法,能够大大提高客户端的编写效率。
  (2)创建用户控制器类
  文件4-11 UserController.java
package com.xc.xcserviceeurekauser.controller; import org.springframework.beans.factory.annotation.Autowired;
import org.springframework.web.bind.annotation.GetMapping;
import org.springframework.web.bind.annotation.PathVariable;
import org.springframework.web.bind.annotation.RestController;
import org.springframework.web.client.RestTemplate; @RestController
public class UserController { @Autowired
private RestTemplate restTemplate; /**
* http://localhost:8000/findOrdersByUser/1
* 查找与用户相关的订单
*/
@GetMapping("/findOrdersByUser/{id}")
public String findOrdersByUser(@PathVariable String id) {
// 假设用户只有一个订单,并且订单id为123
int oid = 123;
return restTemplate.getForObject("http://localhost:7900/order/" + oid, String.class);
} }
在上述代码中,当用户查询订单时,首先会通过用户id查询与用户相关的所有订单(由于这里主要是演示服务的调用,所以省略了查询方法,并且自定义了一个oid为123的订单,来模拟查询出的结果)。然后通过restTemplate对象的getForObject()方法调用了订单服务中的查询订单方法来查询订单id为123的订单信息。
  3. 启动服务应用,测试服务调用
  分别启动服务注册中心应用、订单服务应用和用户服务应用

  当通过浏览器访问地址http://localhost:8000/findOrdersByUser/1(1表示用户id)后,浏览器的显示效果。
Order{id='123', price=23.5, receiverName='xiaoqiang', receiverAddress='beijing', receiverPhone='13422343311'}
Spring Cloud 如何实现服务间的调用 4.2.3的更多相关文章
- Spring Cloud(三):服务提供与调用
		
上一篇文章我们介绍了eureka服务注册中心的搭建,这篇文章介绍一下如何使用eureka服务注册中心,搭建一个简单的服务端注册服务,客户端去调用服务使用的案例. 案例中有三个角色:服务注册中心.服务提 ...
 - Spring Boot + Spring Cloud 构建微服务系统(八):分布式链路追踪(Sleuth、Zipkin)
		
技术背景 在微服务架构中,随着业务发展,系统拆分导致系统调用链路愈发复杂,一个看似简单的前端请求可能最终需要调用很多次后端服务才能完成,那么当整个请求出现问题时,我们很难得知到底是哪个服务出了问题导致 ...
 - Spring Cloud API网关服务 5.2
		
为什么需要API网关 通过前面内容的学习,我们已经可以构建一个简单的微服务架构系统.这个系统可以使用Spring Boot实现微服务的开发,使用Spring Cloud Eureka实现注册中心以及服 ...
 - spring boot / cloud (十四) 微服务间远程服务调用的认证和鉴权的思考和设计,以及restFul风格的url匹配拦截方法
		
spring boot / cloud (十四) 微服务间远程服务调用的认证和鉴权的思考和设计,以及restFul风格的url匹配拦截方法 前言 本篇接着<spring boot / cloud ...
 - Spring Cloud构建微服务架构(一)服务注册与发现
		
Spring Cloud简介 Spring Cloud是一个基于Spring Boot实现的云应用开发工具,它为基于JVM的云应用开发中的配置管理.服务发现.断路器.智能路由.微代理.控制总线.全局锁 ...
 - Spring Cloud构建微服务架构(五)服务网关
		
通过之前几篇Spring Cloud中几个核心组件的介绍,我们已经可以构建一个简略的(不够完善)微服务架构了.比如下图所示: 我们使用Spring Cloud Netflix中的Eureka实现了服务 ...
 - Spring Cloud构建微服务架构 - 服务网关
		
通过之前几篇Spring Cloud中几个核心组件的介绍,我们已经可以构建一个简略的(不够完善)微服务架构了.比如下图所示: alt 我们使用Spring Cloud Netflix中的Eureka实 ...
 - 【微服务】使用spring cloud搭建微服务框架,整理学习资料
		
写在前面 使用spring cloud搭建微服务框架,是我最近最主要的工作之一,一开始我使用bubbo加zookeeper制作了一个基于dubbo的微服务框架,然后被架构师否了,架构师曰:此物过时.随 ...
 - 基于Spring Cloud的微服务入门教程
		
(本教程的原地址发布在本人的简书上:http://www.jianshu.com/p/947d57d042e7,若各位看官有什么问题或不同看法请在这里或简书留言,谢谢!) 本人也是前段时间才开始接触S ...
 
随机推荐
- mage Ansible学习3 ansible role实例
			
一.ansible配置文件解析 1./etc/ansible/ansible.cfg配置文件详解 [root@node3 ~]# cat /etc/ansible/ansible.cfg |grep ...
 - RookeyFrame 附件 上传附件
			
上传附件可允许的格式: 位置:Rookey.Frame.Web\Config\upload.xml 节点:Attachment -> allowType
 - 复习题之Blah数集
			
题目描述: 大数学家高斯小时候偶然间发现一种有趣的自然数集合Blah,对于已a为基的集合Ba定义如下: (1)a是集合Ba的基,且a是Ba的第一个元素: (2)如果x在集合Ba中,则2x+1,3x+1 ...
 - 2017.10.7 国庆清北 D7T2 第k大区间
			
题目描述 定义一个长度为奇数的区间的值为其所包含的的元素的中位数. 现给出n个数,求将所有长度为奇数的区间的值排序后,第K大的值为多少. 输入输出格式 输入格式: 输入文件名为kth.in. 第一行两 ...
 - CF1209题解
			
E 每列都可以沿下滚动若干次,使得各行最大值之和最大 对每列的元素计算最大值,降序排,显然取前\(min(n,m)\)个列处理即可 比较巧妙的动规,设\(f(i,S)\)为前\(i\)列,已经确定最大 ...
 - cnetos7--zabbix(3.4)-server安装
			
1.安装前准备 (1)关闭防火墙 [root@localhost ~]#Systemctl stop firewalld.service (2)开机关闭防火墙 [root@localhost ~]#S ...
 - 第十七周助教工作总结——NWNU李泓毅
			
助教博客链接:https://www.cnblogs.com/NWNU-LHY/ 本次作业的要求:软件测试与ALPHA冲刺:https://www.cnblogs.com/nwnu-daizh/p/1 ...
 - python模块中__init__.py的作用
			
基本概念先上结论举例解释实验一:不包含__init__.py实验二:A中包含__init__.py实验三:A.A_A中也包含__init__.py进阶基本概念概念 解释import 即导入,方式就是在 ...
 - embeding 是什么
			
要搞清楚embeding先要弄明白他和one hot encoding的区别,以及他解决了什么one hot encoding不能解决的问题,带着这两个问题去思考,在看一个简单的计算例子 以下引用 Y ...
 - java判断A字符串中是否包含B字符
			
java.lang.String类提供的方法 public boolean contains(CharSequence s) 当且仅当此字符串包含指定的 char 值序列时,返回 true. 例如: ...