版权声明:本文为博主原创文章,未经博主允许不得转载。 https://blog.csdn.net/csolo/article/details/79982388
在学习SpringCloud之前,先梳理一下基础知识,本章节的目标就是了解如下基础知识:
- 微服务
- SpringCloud
- Springboot
- 最后通过搭建一个简单的Springboot 的 helloworld 结束本章。
一、什么是微服务
传统企业架构里面,一般分为数据库、服务端处理、前端展现。服务端一般是单体模块或者单体的进程,随着web端的业务越来越复杂,对于服务端的要求也越来越高,服务接口越来越多。一开始人们采用服务总线来解决服务发现和服务治理的问题,随着互联网兴起,接口的调用性能和稳定性问题越来越突出,因此去中心化成为服务治理之后一个被大家高度重视的问题,在这个背景下,越来越多的公司采用了微服务来进行服务端的设计,从之前的淘宝dubbo,到后来的SpringCloud, 微服务现在已经成为后端服务设计中最为流行的一种技术选型。
二、SpringCloud简介
微服务概念兴起后,有许多相关的框架在技术人员中流传出来,如果前面提过的dubbo,其他还有批量任务的 Elastic-job 一系列的技术框架,但是都是基于微服务中的某一个点的问题进行解决,SpringCloud的出现,给技术人员提供了一个解决微服务架构实施的综合性解决框架。
SpringCloud包含了多个子项目:
Spring Cloud Config: 配置管理工具
Spring Cloud Netflix: 核心组件,含有Eureka: 服务治理组件(服务注册中心,服务注册和发现机制)
Hystrix:容错管理组件,实现断路器模式
Ribbon:客户端负载均衡的服务调用组件
Spring Cloud Bus: 事件、消息总线
Spring Cloud Cluster:集群
等等,还有很多不一一列举。
三、Spring Boot简介
SpringCloud的工程构建是基于Spring Boot实现,因此有必要先了解一下Spring Boot, 通过创建一个简单的web工程来了解一下SpringBoot:建议使用IDEA作为开发工具
首先通过建立一个Model来建立一个SpringBoot工程:
点击下一步:
填入Model 的元数据相关信息后,继续next
这里选择Web,next后,填入模块的名称:
点击finish后,就出现如下的工程结构:
上面这张图显示了工程结构,其中pom.xml是maven工程的配置文件,里面会有工程的依赖,我们使用了spring initialzr向导,因此会在pom.xml 中自动填入初始的依赖;其次默认src main 目录下有一个java ,一个resources,在java 中放置代码,在resources中放工程的资源如配置文件,图中的application.yml 也是配置文件,是后来加入的,这是springboot的特色配置文件,在代码区的 HelloControler也是后来代码,后面会说明,系统默认会有一个应用入口类,SpringbootApplication。最后test区是放置单元测试代码的区域。
建立起工程后,我们准备开发一个小demo,helloword。
首先看一下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">
-
<modelVersion>4.0.0</modelVersion>
-
<groupId>com.study</groupId>
-
<artifactId>springboot</artifactId>
-
<version>0.0.1-SNAPSHOT</version>
-
<packaging>jar</packaging>
-
<name>springboot</name>
-
<description>Demo project for Spring Boot</description>
-
<parent>
-
<groupId>org.springframework.boot</groupId>
-
<artifactId>spring-boot-starter-parent</artifactId>
-
<version>2.0.1.RELEASE</version>
-
<relativePath/> <!-- lookup parent from repository -->
-
</parent>
-
<properties>
-
<project.build.sourceEncoding>UTF-8</project.build.sourceEncoding>
-
<project.reporting.outputEncoding>UTF-8</project.reporting.outputEncoding>
-
<java.version>1.8</java.version>
-
</properties>
-
<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>
-
<scope>test</scope>
-
</dependency>
-
</dependencies>
-
<build>
-
<plugins>
-
<plugin>
-
<groupId>org.springframework.boot</groupId>
-
<artifactId>spring-boot-maven-plugin</artifactId>
-
</plugin>
-
</plugins>
-
</build>
-
</project>
如果以后自己的工程中有其他依赖,可以自己添加,上面是创建工程时就自己创建的,还记得前面我们选的web 选项吗,在这里就有sping-boot-starter-web。
其次,我们写一个controler,默认调用都被这个controler处理
-
package com.study.springboot.controler;
-
import org.springframework.web.bind.annotation.RequestMapping;
-
import org.springframework.web.bind.annotation.RestController;
-
@RestController
-
public class HelloController {
-
@RequestMapping("/sayhello")
-
public String Hello() {
-
return "Hello World!";
-
}
-
}
在springboot中采用了注解方式来开发,提升开发效率,上面这段就是当http://localhost:port/sayhello调用时,返回hello world。接着,创建一下运用的配置文件,在resource 目录下,我们创建一个文件application.yml
-
server:
-
#配置服务器启动端口
-
port: 8028
-
#配置访问的上下文路径,就是localhost:8028后面需要的上下文路径
-
context-path: /sayhello
Springboot采用了递进式样的配置文件格式yml,有点类似python,当然也可以用默认的application.properties
上面等于server.port=8028
最后,我们看一下demo的入口:
-
package com.study.springboot;
-
import org.springframework.boot.SpringApplication;
-
import org.springframework.boot.autoconfigure.SpringBootApplication;
-
@SpringBootApplication
-
public class SpringbootApplication {
-
public static void main(String[] args) {
-
SpringApplication.run(SpringbootApplication.class, args);
-
}
-
}
这个类没有做任何处理,创建时就是这样,,我们直接把它运行起来:
运行后,我们在浏览器输入url http://localhost:8028/sayhello,浏览器就会返回如下信息:
一个简单的 Springboot demo 就完成了。