springcloud学习之路: (一) 最简单的搭建springcloud的方法
参考资料: [javaee] 五分钟搭建springcloud环境, 进入微服务时代
感谢上篇博文大佬带领走进springcloud世界, 本博文主要目的为记录自己学习springcloud的点点滴滴, 给自己的知识进行整理, 如果能帮助更多的小伙帮那就更好了.
ps: 本文主要作为备忘及快速搭建springcloud之用, 只记录主要步骤. 原文讲述更加细致, 想深入学习的同学推荐点击上方连接学习.
操作系统: windows 10
ide: intellij idea 2018.3.6
java: jdk 1.8.x
meave: 3.6.0
springboot: 2.1.7
1. 创建一个工程
创建springboot工程
2. 创建eureka注册中心
依然选择springboot工程
选择eureka服务器
导包, 开启服务管理器
为eureka注册中心添加注解开启服务
配置eureka注册中心配置文件
server: # 配置服务端口 port: 8081 eureka: client: service-url: # 配置eureka服务器地址 defaultzone: http://127.0.0.1:8081/eureka #是否需要将自己注册到注册中心(注册中心集群需要设置为true) register-with-eureka: false #是否需要搜索服务信息 因为自己是注册中心所以为false fetch-registry: false
注意缩进, 因为yml
使用缩进来区分不同字段的.
运行serviceeurekaapplication文件启动项目, 访问注册中心
3. 创建两个微服务service-a,service-b
创建一个springboot模块
起个名字
选择web
选择客户模块
路由设置
配置微服务的入口文件 @enableeurekaclient
配置application.yml
service-a
server: # 服务端口号 port: 8082 spring: application: # 服务名称 - 服务之间使用名称进行通讯 name: service-objcat-a eureka: client: service-url: # 填写注册中心服务器地址 defaultzone: http://localhost:8081/eureka # 是否需要将自己注册到注册中心 register-with-eureka: true # 是否需要搜索服务信息 fetch-registry: true instance: # 使用ip地址注册到注册中心 prefer-ip-address: true # 注册中心列表中显示的状态参数 instance-id: ${spring.cloud.client.ip-address}:${server.port}
service-b
server: # 服务端口号 port: 8083 spring: application: # 服务名称 - 服务之间使用名称进行通讯 name: service-objcat-b eureka: client: service-url: # 填写注册中心服务器地址 defaultzone: http://localhost:8081/eureka # 是否需要将自己注册到注册中心 register-with-eureka: true # 是否需要搜索服务信息 fetch-registry: true instance: # 使用ip地址注册到注册中心 prefer-ip-address: true # 注册中心列表中显示的状态参数 instance-id: ${spring.cloud.client.ip-address}:${server.port}
运行微服务
分别运行注册中心及微服务模块
出现端口号表示启动成功
编写测试接口
import org.springframework.web.bind.annotation.requestmapping; import org.springframework.web.bind.annotation.restcontroller; @restcontroller public class testacontroller { @requestmapping("testa") public string testacontroller(){ return "hello,springcloud for testa"; } }
重启服务
访问下面地址
访问成功
使用服务b调用服务a的接口
这时我们就需要用到eurka(注册中心)
和feign
客户端了
首先我们在service-b中创建interface
在微服务b中, 创建一个serviceafeignclient接口
import org.springframework.cloud.openfeign.feignclient; import org.springframework.web.bind.annotation.requestmapping; // 填入注册中心中的应用名, 也就是要调用的微服务的应用名 // 在eureka页面中可以找到 @feignclient("service-objcat-a") public interface serviceafeignclient { @requestmapping("testa") public string testacontroller(); }
应用名可以在eureka中找到
在服务b中添加个控制器
import org.springframework.beans.factory.annotation.autowired; import org.springframework.cloud.netflix.eureka.enableeurekaclient; import org.springframework.cloud.openfeign.enablefeignclients; import org.springframework.web.bind.annotation.requestmapping; import org.springframework.web.bind.annotation.restcontroller; @restcontroller // 添加注解声明是注册中心客户端 @enableeurekaclient // 实现不同子服务调用 @enablefeignclients public class testbcontroller { @autowired private serviceafeignclient serviceafeignclient; @requestmapping("call") public string call(){ string result = serviceafeignclient.testacontroller(); return "b to a 访问结果 ---" + result; } }
解决@autowired实例报错
重新运行服务b 在网站*问试试吧
ps: 在springcloud中一个子服务调用另一个子服务默认超时时间是1s, 也就是说要是被调用的子服务返回超过一秒就会出现错误, 针对此问题需要修改调用服务的yml文件.
举例: 在本案例中, service-a是被调用者, service-b是调用者, 则在service-b的yml文件中加入
ribbon: #建立连接超时时间 readtimeout: 5000 #读取资源超时间 connecttimeout: 5000
注意首行缩进, service-b完整配置如下
server: # 服务端口号 port: 8083 spring: application: # 服务名称 - 服务之间使用名称进行通讯 name: service-objcat-b eureka: client: service-url: # 填写注册中心服务器地址 defaultzone: http://localhost:8081/eureka # 是否需要将自己注册到注册中心 register-with-eureka: true # 是否需要搜索服务信息 fetch-registry: true instance: # 使用ip地址注册到注册中心 prefer-ip-address: true # 注册中心列表中显示的状态参数 instance-id: ${spring.cloud.client.ip-address}:${server.port} ribbon: #建立连接超时时间 readtimeout: 5000 #读取资源超时间 connecttimeout: 5000
上一篇: JQuery高级笔记
下一篇: python--生成器和迭代器
推荐阅读
-
springcloud学习之路: (一) 最简单的搭建springcloud的方法
-
从实例一步一步入门学习SpringCloud的Eureka、Ribbon、Feign、熔断器、Zuul的简单使用(附代码下载)
-
荐 小名的开源项目【EamonVenti】0.0篇 —— 学习如何搭建一个简单的SpringCloud架构,体验微服务的强大!
-
feign和zuul组件的使用方法以及使用SpringCloud的feign和zuul组件搭建一个简单的微服务
-
SpringBoot 学习之路(一):使用IDEA搭建一个简单的框架
-
SpringCloud学习系列之一 ----- 搭建一个高可用的注册中心(Eureka)
-
从实例一步一步入门学习SpringCloud的Eureka、Ribbon、Feign、熔断器、Zuul的简单使用(附代码下载)
-
springcloud学习之路: (一) 最简单的搭建springcloud的方法
-
荐 小名的开源项目【EamonVenti】0.0篇 —— 学习如何搭建一个简单的SpringCloud架构,体验微服务的强大!