SpringCloud入门学习
我相信,如果小伙伴们能来到这里,肯定对微服务有一定的认识。
我们之前创建web项目的时候,常见的有两种方式:
1).创建一个war包,然后放在servlet容器中运行(比如Tomcat等);
2).使用SpringBoot创建一个jar包运行,这也是使用了内嵌式的servlet容器。
这么做的好处是:开发布署方便,直接放在tomcat的webapp目录下或者使用java -jar xxx.jar 方式进行运行。
但是,缺点呢?我们通常在一个tomcat下会运行多个应用程序,就算是使用只装一个应用。如果在同一时间有很大的并发访问量,会导致内存溢出,从而让整个tomcat停止运行,其中的应用也停止服务,这是很可怕的事。
那么,我们就需要使用分布式开发和布署。我们将一个巨大的项目进行“微服务化”,这样,就算其中的一个服务坏了,其他服务依然可以运行。就拿一个最常见的博客系统来说,如果我们将发布博文和评论系统分开部署,当评论系统坏了,并不影响我们发布和阅读博文。
什么是微服务?
就是我们对整个系统进行划分的各处微小的“系统”。比如:电商网站中一般会将订单、评论、购物车等各分为一个单独的“微服务”
什么是SpringCloud
“微服务化”只是一种思想,目前市面上有很多的解决方案,Dubbo和SpringCloud就是目前最常用的两种解决方案。但是两者有很大的区别:Dubbo采用的是RPC(远程过程调用),SpringCloud使用的是HTTP REST的通信方式。
RPC的底层是通过二进制传送的,用的socket的通信方式。
HTTP REST的通信方式就是使用http协议,比如我们常用的httpclient就一种进行http通信的工具类
SpringCloud并不是像SpringBoot一样是一种新型技术,它只是一系列的技术的结合体。
如何学习SpringCloud
学习SpringCloud至少要拥有以下基础知识:
- SpringBoot应用的创建以及运行
- Maven的依赖继承,抽象以及管理
创建第一个SpringCloud应用
我使用的Idea开发工具,当然使用MyEclipse也是可以的。
1. 创建一个Maven项目进行依赖管理
注意将这个项目的打包方式设置为pom(因为只做依赖管理,不进行代码编写,其他的项目都会继承这个项目)
- 在项目中引入相应的依赖
?xml version="1.0" encoding="UTF-8"?>
<project xmlns="http://maven.apache.org/POM/4.0.0"
xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance"
xsi:schemaLocation="http://maven.apache.org/POM/4.0.0 http://maven.apache.org/xsd/maven-4.0.0.xsd">
<modelVersion>4.0.0</modelVersion>
<groupId>cn.lyn4ever</groupId>
<artifactId>spingcloud-learn</artifactId>
<version>1.0-SNAPSHOT</version>
<!--打包方式为pom-->
<packaging>pom</packaging>
<properties>
<project.build.sourceEncoding>UTF-8</project.build.sourceEncoding>
<maven.compiler.source>1.8</maven.compiler.source>
<maven.compiler.target>1.8</maven.compiler.target>
</properties>
<dependencyManagement>
<dependencies>
<dependency>
<groupId>org.springframework.cloud</groupId>
<artifactId>spring-cloud-dependencies</artifactId>
<!--springcloud的版本号就是这么奇怪-->
<version>Dalston.SR1</version>
<type>pom</type>
<scope>import</scope>
</dependency>
<dependency>
<groupId>org.springframework.boot</groupId>
<artifactId>spring-boot-dependencies</artifactId>
<version>1.5.9.RELEASE</version>
<type>pom</type>
<scope>import</scope>
</dependency>
</dependencies>
</dependencyManagement>
</project>
2.创建一个provider项目(web项目)
- 这个项目是一个maven的module项目,并不是一个project,在这个项目上鼠标右键就可以创建Module。
- 这个子项目是一个SpringBoot项目,但是并不建议使用Idea的Spri ing Initializr进行创建,因为它并不会建立和上一个项目的父子关系,建议创建一个maven项目,然后进行编码

- 在pom.xml中引入依赖
<?xml version="1.0" encoding="UTF-8"?>
<project xmlns="http://maven.apache.org/POM/4.0.0"
xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance"
xsi:schemaLocation="http://maven.apache.org/POM/4.0.0 http://maven.apache.org/xsd/maven-4.0.0.xsd">
<parent>
<artifactId>spingcloud-learn</artifactId>
<groupId>cn.lyn4ever</groupId>
<version>1.0-SNAPSHOT</version>
</parent>
<modelVersion>4.0.0</modelVersion>
<artifactId>demo1-provider-8001</artifactId>
<dependencies>
<dependency>
<groupId>org.springframework.boot</groupId>
<artifactId>spring-boot-starter-web</artifactId>
</dependency>
<dependency>
<groupId>org.springframework.boot</groupId>
<artifactId>spring-boot-starter-test</artifactId>
</dependency>
</dependencies>
</project>
- 在resources下创建application.yml
server:
port: 8001
- 编写一个SpringBoot应用的启动类
@RestController
public class HelloController {
@GetMapping("demo1/provider/hello/{id}")
public String hello(@PathVariable("id") Integer id) {
return "这是来自提供者的一条消息,你传过来的消息" + id;
}
}
- 编写一个Controller
@RestController
public class HelloController {
@GetMapping("demo1/provider/hello/{id}")
public String hello(@PathVariable("id") Integer id) {
return "这是来自提供者的一条消息,你传过来的消息" + id;
}
}
- 最后的项目结构如下:

- 然后,启动这个主类,我们可以使用浏览器
http://localhost:8001/demo1/provider/hello/99进行访问了
3.创建一个消费者应用(也是一个web项目)
- 同样也是一个Maven的Module项目,创建方式和相关代码略,和上边一样,这里主要写一个配置类和Controller
- 不过,这回的application.yml中的端口号和上个要不一样,我使用的是80
- 配置一个RestTemplate的bean,进行远程访问。这个bean,其实和我们之前使用过的HttpClient是一样的,只不这个是Spring高度抽象后的一个工具类,要好用的多(这是SpringBoot的基础了,这个类相当于Spring中的xml配置文件)。
@Configuration
public class BeanConfig {
@Bean
public RestTemplate restTemplate(){
return new RestTemplate();
}
}
- controller类
@RestController
public class HelloConsumerController {
@Autowired
private RestTemplate restTemplate;
@GetMapping("demo1/consumer/hello/{id}")
public String hello(@PathVariable("id") String id){
//远程调用provider中的接口
return restTemplate.getForObject("http://localhost:8001/demo1/provider/hello"+id,String.class);
}
}
- 完整项目结构如下:

然后使用
http://localhost:80/demo1/consumer/hello/3进行访问
SpringCloud学习参考
关注我的公众号,每日更新SpringCloud知识

SpringCloud入门学习的更多相关文章
- 【原创】SpringBoot & SpringCloud 快速入门学习笔记(完整示例)
[原创]SpringBoot & SpringCloud 快速入门学习笔记(完整示例) 1月前在系统的学习SpringBoot和SpringCloud,同时整理了快速入门示例,方便能针对每个知 ...
- 从实例一步一步入门学习SpringCloud的Eureka、Ribbon、Feign、熔断器、Zuul的简单使用(附代码下载)
场景 SpringCloud -创建统一的依赖管理: https://blog.csdn.net/BADAO_LIUMANG_QIZHI/article/details/102530574 Sprin ...
- SpringCloud入门之常用的配置文件 application.yml和 bootstrap.yml区别
作者其他技术文章 1) Spring Boot 简介 2)SpringCloud入门之YAML格式文件规范学习 3)SpringCloud入门之Spring Boot多环境配置切换指南 4) Elas ...
- springcloud 入门 8 (config配置中心)
Spring Cloud Config: 配置中心为了方便服务配置文件统一管理,实时更新,所以需要分布式配置中心组件,它就是Spring Cloud Config. 在分布式系统中,由于服务数量巨多, ...
- SpringCloud开发学习总结(七)—— 声明式服务调用Feign(一)
在实践的过程中,我们会发现在微服务架构中实现客户端负载均衡的服务调用技术Spring Cloud Ribbon<SpringCloud开发学习总结(四)—— 客户端负载均衡Ribbon> ...
- springCloud相关学习资料
SpringCloud相关学习资料 SpringCloud资料参考: 1. 史上最简单的 SpringCloud 教程 | 终章 2. Spring Cloud基础教程 SpringCloud相关: ...
- SpringCloud 入门知识篇
SpringCloud 入门 springcloud 学习 7天学会springcloud 教程 https://www.cnblogs.com/skyblog/category/738524.htm ...
- Nacos入门学习&实践
文中涉及到了一些模块代码没有给出,我一并上传到github了,可以整个项目clone下来进行调试. 地址:https://github.com/stronglxp/springcloud-test 1 ...
- vue入门学习(基础篇)
vue入门学习总结: vue的一个组件包括三部分:template.style.script. vue的数据在data中定义使用. 数据渲染指令:v-text.v-html.{{}}. 隐藏未编译的标 ...
随机推荐
- 虚拟机ubuntu系统怎么添加 VMware tools
首先弹出光盘 然后安装 点击安装VMware tools 然后进入光盘 打开VMware tools 文件夹 将解压文件拉到桌面上 打开桌面上的文件夹 不选中文件 然后键入下面的内容 输入密码 输入y ...
- CSS学习笔记--Div+Css布局实战(入门)
基本页面布局 本教程带着大家做一个简单的页面布局 最重效果如下: 1.第一部,先创建上下左右4个DIV <!DOCTYPE html> <html> <head lang ...
- abp vnext2.0核心组件之.Net Core默认DI组件切换到AutoFac源码解析
老版Abp对Castle的严重依赖在vnext中已经得到了解决,vnext中DI容器可以任意更换,为了实现这个功能,底层架构相较于老版abp,可以说是进行了高度重构.当然这得益于.Net Core的D ...
- 毕业论文系列之基于WiFi的智能农业大棚管控系统设计代码
#include <dht11.h>//dht11库 #include <MsTimer2.h> //定时器库的 头文件 #include < ...
- .NET异步编程之APM模式
目录 1.AMP模式简介 2.使用BeginInvoke实现异步委托 3.原始线程怎么知道新线程已经运行完毕 4.使用AsyncCallback委托实现回调模式 5.源代码下载 shanzm-2020 ...
- 低功耗设计技术--Multi VDD--Level shifter
本文转自:自己的微信公众号<集成电路设计及EDA教程> 前面的推文中我们分别介绍了低功耗设计中的Multi-VDD技术以及门控电源技术.在实际的低功耗设计中,门控电源技术中也常常结合Mul ...
- DotNetty发送请求的最佳实践
长链接发送request/response时, 绝大部分包都是小包, 而每个小包都要消耗一个IP包, 成本大约是20-30us, 普通千兆网卡的pps大约是60Wpps, 所以想要提高长链接密集IO的 ...
- 红帽(RedHat8) RHEL8.0系统安装教程(小白都会)
可以去了解一下Red Hat8产品详情:https://www.RedHat.com/zh/enterprise-linux-8 先准备VMware Workstation 15 Pro版本,Red ...
- 百度MP3音乐API接口及应用
当你在百度去搜索一首歌时,你会发现有种更简单的方法. http://box.zhangmen.baidu.com/x?op=12&count=1&title=歌名$$作者$$$$ 例如 ...
- js笔记(2)--第一天记录
---恢复内容开始--- 模仿了网站的一个常见小功能,开关灯小功能. 代码: <!DOCTYPE html> <html lang="en"> <he ...