我相信,如果小伙伴们能来到这里,肯定对微服务有一定的认识。

我们之前创建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学习参考

Spring官网

SpringCloud中文网

关注我的公众号,每日更新SpringCloud知识

SpringCloud入门学习的更多相关文章

  1. 【原创】SpringBoot & SpringCloud 快速入门学习笔记(完整示例)

    [原创]SpringBoot & SpringCloud 快速入门学习笔记(完整示例) 1月前在系统的学习SpringBoot和SpringCloud,同时整理了快速入门示例,方便能针对每个知 ...

  2. 从实例一步一步入门学习SpringCloud的Eureka、Ribbon、Feign、熔断器、Zuul的简单使用(附代码下载)

    场景 SpringCloud -创建统一的依赖管理: https://blog.csdn.net/BADAO_LIUMANG_QIZHI/article/details/102530574 Sprin ...

  3. SpringCloud入门之常用的配置文件 application.yml和 bootstrap.yml区别

    作者其他技术文章 1) Spring Boot 简介 2)SpringCloud入门之YAML格式文件规范学习 3)SpringCloud入门之Spring Boot多环境配置切换指南 4) Elas ...

  4. springcloud 入门 8 (config配置中心)

    Spring Cloud Config: 配置中心为了方便服务配置文件统一管理,实时更新,所以需要分布式配置中心组件,它就是Spring Cloud Config. 在分布式系统中,由于服务数量巨多, ...

  5. SpringCloud开发学习总结(七)—— 声明式服务调用Feign(一)

    在实践的过程中,我们会发现在微服务架构中实现客户端负载均衡的服务调用技术Spring Cloud Ribbon<SpringCloud开发学习总结(四)—— 客户端负载均衡Ribbon> ...

  6. springCloud相关学习资料

    SpringCloud相关学习资料 SpringCloud资料参考: 1. 史上最简单的 SpringCloud 教程 | 终章 2. Spring Cloud基础教程 SpringCloud相关: ...

  7. SpringCloud 入门知识篇

    SpringCloud 入门 springcloud 学习 7天学会springcloud 教程 https://www.cnblogs.com/skyblog/category/738524.htm ...

  8. Nacos入门学习&实践

    文中涉及到了一些模块代码没有给出,我一并上传到github了,可以整个项目clone下来进行调试. 地址:https://github.com/stronglxp/springcloud-test 1 ...

  9. vue入门学习(基础篇)

    vue入门学习总结: vue的一个组件包括三部分:template.style.script. vue的数据在data中定义使用. 数据渲染指令:v-text.v-html.{{}}. 隐藏未编译的标 ...

随机推荐

  1. Apache Commons 相关工具类使用

    Apache Commons Apache Commons包含了很多开源的工具,用于解决平时编程经常会遇到的问题,减少重复劳动.下面是我这几年做开发过程中自己用过的工具类做简单介绍. 组件 功能介绍 ...

  2. 01-前言&WEB标准

    人生苦短,要学就只学有用的 [前端教学-前言] 初识web开发 我们先来认识一下web前端 其实前端的工作,大体的概括就是:根据美工给的设计稿,变成web网页,使用后天的接口实现数据的渲染,要是高端一 ...

  3. java进阶视频分享

    更多资源和教程请关注公众号:非科班的科班. 如果觉得我写的还可以请给个赞,谢谢大家,你的鼓励是我创作的动力 课程目录介绍 01.开班仪式02.并发编程专题之多线程基础03.并发编程专题之Java内存模 ...

  4. 《高性能MySQL》之MySQL查询性能优化

    为什么查询会慢? 响应时间过长.如果把查询看做是一个任务,那么它由一系列子任务组成,每个子任务都会消耗一定的时间.如果要优化查询,实际上优化其子任务,要么消除其中一些子任务,要么减少子任务的执行次数, ...

  5. [ZJOI2007]报表统计(splay,堆)

    [ZJOI2007]报表统计(luogu) Description 题目描述 Q的妈妈是一个出纳,经常需要做一些统计报表的工作.今天是妈妈的生日,小Q希望可以帮妈妈分担一些工作,作为她的生日礼物之一. ...

  6. spring cloud oauth2+JWT整合使用token返回JWT Cannot convert access token to JSON解决办法

    我碰到的问题是Token正常,但是资源访问不了,原因是,资源服务配置的时候需要传一个对象: 设置了这个就可以了

  7. Python 入门基本知识

    编码:是把机器语言翻译成人能看懂的语言 美国信息互换标准代码<<ASSIC>>这张表就是相当于语法表随着发展后面又出现了:gb2312  ——到——  gbk18030  AS ...

  8. linux 内存使用分析

      查看当前内存使用情况,最常用的指令就是 [root@t ~]# free -m total used free shared buffers cached Mem: -/+ buffers/cac ...

  9. iNeuOS工业互联平台,iNeuKernel(物联网核心组件)远程控制标准化设计与实现。发布v2.3版本。

    目       录 1.      概述... 2 2.      平台演示... 2 3.      控制端与iNeuKernel的交互协议... 3 4.      设备驱动实现控制业务... 4 ...

  10. mplayer的参数

    播放文件 使用 MPlayer 播放媒体文件最简单的方式是: mplayer <somefile>  MPlayer 会自动检测文件的类型并加以播放,如果是音频文件,则会在命令行中显示该播 ...