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.{{}}. 隐藏未编译的标 ...
随机推荐
- Apache Commons 相关工具类使用
Apache Commons Apache Commons包含了很多开源的工具,用于解决平时编程经常会遇到的问题,减少重复劳动.下面是我这几年做开发过程中自己用过的工具类做简单介绍. 组件 功能介绍 ...
- 01-前言&WEB标准
人生苦短,要学就只学有用的 [前端教学-前言] 初识web开发 我们先来认识一下web前端 其实前端的工作,大体的概括就是:根据美工给的设计稿,变成web网页,使用后天的接口实现数据的渲染,要是高端一 ...
- java进阶视频分享
更多资源和教程请关注公众号:非科班的科班. 如果觉得我写的还可以请给个赞,谢谢大家,你的鼓励是我创作的动力 课程目录介绍 01.开班仪式02.并发编程专题之多线程基础03.并发编程专题之Java内存模 ...
- 《高性能MySQL》之MySQL查询性能优化
为什么查询会慢? 响应时间过长.如果把查询看做是一个任务,那么它由一系列子任务组成,每个子任务都会消耗一定的时间.如果要优化查询,实际上优化其子任务,要么消除其中一些子任务,要么减少子任务的执行次数, ...
- [ZJOI2007]报表统计(splay,堆)
[ZJOI2007]报表统计(luogu) Description 题目描述 Q的妈妈是一个出纳,经常需要做一些统计报表的工作.今天是妈妈的生日,小Q希望可以帮妈妈分担一些工作,作为她的生日礼物之一. ...
- spring cloud oauth2+JWT整合使用token返回JWT Cannot convert access token to JSON解决办法
我碰到的问题是Token正常,但是资源访问不了,原因是,资源服务配置的时候需要传一个对象: 设置了这个就可以了
- Python 入门基本知识
编码:是把机器语言翻译成人能看懂的语言 美国信息互换标准代码<<ASSIC>>这张表就是相当于语法表随着发展后面又出现了:gb2312 ——到—— gbk18030 AS ...
- linux 内存使用分析
查看当前内存使用情况,最常用的指令就是 [root@t ~]# free -m total used free shared buffers cached Mem: -/+ buffers/cac ...
- iNeuOS工业互联平台,iNeuKernel(物联网核心组件)远程控制标准化设计与实现。发布v2.3版本。
目 录 1. 概述... 2 2. 平台演示... 2 3. 控制端与iNeuKernel的交互协议... 3 4. 设备驱动实现控制业务... 4 ...
- mplayer的参数
播放文件 使用 MPlayer 播放媒体文件最简单的方式是: mplayer <somefile> MPlayer 会自动检测文件的类型并加以播放,如果是音频文件,则会在命令行中显示该播 ...