摘要:第篇电影微服务,也注册到中,通过协议访问已注册到生态圈中的用户微服务一大致介绍在服务治理框架中,微服务与微服务之间通过协议进行通信用户微服务作为消费方电影微服务作为提供方都注册到中在电影微服务层通过的硬编码配置方式实现服务之间的通信二实现
SpringCloud(第 005 篇)电影微服务,也注册到 EurekaServer 中,通过 Http 协议访问已注册到生态圈中的用户微服务
-
一、大致介绍</>复制代码
1、在 eureka 服务治理框架中,微服务与微服务之间通过 Http 协议进行通信;
2、用户微服务作为消费方、电影微服务作为提供方都注册到 EurekaServer 中;
3、在电影微服务Web层通过 application.yml 的硬编码配置方式实现服务之间的通信;
二、实现步骤
2.1 添加 maven 引用包
</>复制代码
4.0.0
springms-consumer-movie
1.0-SNAPSHOT
jar
com.springms.cloud
springms-spring-cloud
1.0-SNAPSHOT
org.springframework.boot
spring-boot-starter-web
org.springframework.boot
spring-boot-starter-actuator
org.springframework.cloud
spring-cloud-starter-eureka
2.2 添加应用配置文件(springms-consumer-moviesrcmainresourcesapplication.yml)
</>复制代码
spring:
application:
name: springms-consumer-movie
server:
port: 7901
user:
userServicePath: http://localhost:7900/simple/
eureka:
client:
# healthcheck:
# enabled: true
serviceUrl:
defaultZone: http://admin:admin@localhost:8761/eureka
instance:
prefer-ip-address: true
instance-id: ${spring.application.name}:${spring.cloud.client.ipAddress}:${spring.application.instance_id:${server.port}}
2.3 添加实体用户类User(springms-consumer-moviesrcmainjavacomspringmscloudentityUser.java)
</>复制代码
package com.springms.cloud.entity;
import java.math.BigDecimal;
public class User {
private Long id;
private String username;
private String name;
private Short age;
private BigDecimal balance;
public Long getId() {
return this.id;
}
public void setId(Long id) {
this.id = id;
}
public String getUsername() {
return this.username;
}
public void setUsername(String username) {
this.username = username;
}
public String getName() {
return this.name;
}
public void setName(String name) {
this.name = name;
}
public Short getAge() {
return this.age;
}
public void setAge(Short age) {
this.age = age;
}
public BigDecimal getBalance() {
return this.balance;
}
public void setBalance(BigDecimal balance) {
this.balance = balance;
}
}
2.4 添加电影Web访问层Controller(springms-consumer-moviesrcmainjavacomspringmscloudcontrollerMovieController.java)
</>复制代码
package com.springms.cloud.controller;
import com.springms.cloud.entity.User;
import org.springframework.beans.factory.annotation.Autowired;
import org.springframework.beans.factory.annotation.Value;
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 MovieController {
@Autowired
private RestTemplate restTemplate;
@Value("${user.userServicePath}")
private String userServicePath;
@GetMapping("/movie/{id}")
public User findById(@PathVariable Long id) {
return this.restTemplate.getForObject(this.userServicePath + id, User.class);
}
}
2.5 添加电影微服务启动类(springms-consumer-moviesrcmainjavacomspringmscloudMsConsumerMovieApplication.java)
</>复制代码
package com.springms.cloud;
import org.springframework.boot.SpringApplication;
import org.springframework.boot.autoconfigure.SpringBootApplication;
import org.springframework.cloud.netflix.eureka.EnableEurekaClient;
import org.springframework.context.annotation.Bean;
import org.springframework.web.client.RestTemplate;
/**
* 电影微服务,也注册到 EurekaServer 中,通过 Http 协议访问已注册到生态圈中的用户微服务。
*
* @author hmilyylimh
*
* @version 0.0.1
*
* @date 2017/9/17
*
*/
@SpringBootApplication
@EnableEurekaClient
public class MsConsumerMovieApplication {
@Bean
public RestTemplate restTemplate(){
return new RestTemplate();
}
public static void main(String[] args) {
SpringApplication.run(MsConsumerMovieApplication.class, args);
System.out.println("【【【【【【 电影微服务 】】】】】】已启动.");
}
}
三、测试
</>复制代码
/****************************************************************************************
一、电影微服务,也注册到 EurekaServer 中,通过 Http 协议访问已注册到生态圈中的用户微服务:
1、启动 springms-discovery-eureka 模块服务,启动1个端口;
2、启动 springms-provider-user 模块服务,启动1个端口;
3、启动 springms-consumer-movie 模块服务,启动1个端口;
4、在浏览器输入地址 http://localhost:7900/simple/1 可以看到信息成功的被打印出来,说明用户微服务正常;
5、在浏览器输入地址 http://localhost:8761 并输入用户名密码 admin/admin 进入Eureka微服务显示在网页中,验证用户微服务、电影微服务确实注册到了 eureka 服务中;
6、在浏览器输入地址http://localhost:7901/movie/1 可以看到用户信息成功的被打印出来;
****************************************************************************************/
四、下载地址
https://gitee.com/ylimhhmily/SpringCloudTutorial.git
SpringCloudTutorial交流QQ群: 235322432
SpringCloudTutorial交流微信群: 微信沟通群二维码图片链接
欢迎关注,您的肯定是对我最大的支持!!!
文章版权归作者所有,未经允许请勿转载,若此文章存在违规行为,您可以联系管理员删除。
转载请注明本文地址:https://www.ucloud.cn/yun/70444.html
摘要:第篇服务发现服务端微服务一大致介绍众所周知,在现在互联网开发中,访问地址的和端口号是动态的,一个服务停掉再重新启用后和端口就可能发生了改变,所以用硬编码是肯定不行了。再对外提供服务的时候便不再使用挂掉的服务提供者的和端口。 SpringCloud(第 003 篇)服务发现服务端EurekaServer微服务 - 一、大致介绍 1、众所周知,在现在互联网开发中,访问地址的IP和端口号是...
SpringCloud(第 051 篇)EurekaServer集群高可用注册中心以及简单的安全认证 - 一、大致介绍 1、前面章节分析了一下 Eureka 的源码,我们是不是在里面注意到了 Peer 节点的复制,为什么要复制节点同步信息呢,其实就是为了同一个集群之间的EurekaServer一致性方案的一个实现; 2、于是我们在本章节就真正的来通过代码来实现一下EurekaServer之间的高...
摘要:接收参数对象添加用户微服务启动类用户服务类添加服务注册,将用户微服务注册到中。 SpringCloud(第 004 篇)用户服务类(添加服务注册,将用户微服务注册到 EurekaServer 中) - 一、大致介绍 通过添加注解 EnableEurekaClient,将用户微服务注册到 EurekaServer 中。 二、实现步骤 2.1 添加 maven 引用包 4.0....
摘要:在应用启动后,将会向发送心跳默认周期为秒,如果在多个心跳周期没有收到某个节点的心跳,将会从服务注册表中把这个服务节点移除默认秒。进入类看看,看这个类的名字,见名知意,应该就是的启动类了。。。分析一由于是我们刚刚打断点 SpringCloud(第 049 篇)Netflix Eureka 源码深入剖析(上) - 一、大致介绍 1、鉴于一些朋友的提问并提议讲解下eureka的源码分析,由此...
阅读 3683·2021-11-24 09:38
阅读 3350·2021-11-22 09:34
阅读 2244·2021-09-22 16:03
阅读 2492·2019-08-29 18:37
阅读 462·2019-08-29 16:15
阅读 1855·2019-08-26 13:56
阅读 956·2019-08-26 12:21
阅读 2321·2019-08-26 12:15