以下论述,一点儿个人理解。 欢迎各路大佬支持!
一、springcloud诞生的意义
java项目开发历经了,从
jsp(servlet)+实体+数据库的蛮荒时代
到
MVC三层架构
到
spring诞生后的 ssm = spring + springMVC +mybatis
到
springboot 自动装配
这时候 单个服务的开发已经变得极为迅速高效,而java强大的生态,导致项目的访问者会逐渐膨胀。
而单机服务器,再强大,也无法承载极高的并发数据量访问。
这时候有一些策略就是 服务器集群,等价复制多个服务器。 这必然会有计算机资源的浪费!
一条业务线,可能某些环节的处理非常简单, 而某些环节的处理非常复杂。
基于这样的现状, martin fowler 提出了微服务的概念! 将服务拆分! 按需组装~
引入这些概念去解决 大访问量的 软件承载力问题的时候,不可避免的引入了几个基本问题
- 多个服务, 客户端如何访问?(zuul API网关)
- 多个服务,他们不在同一个机器上,他们如何通信? (http的restful风格feign(ribbon) 或者 rpc框架 dubbo)
- 多个服务,如何让每个服务都能均衡的承载业务压力?(服务注册与发现 eureka或zookeeper)
- 多个服务必然有网格式依赖,单个服务出现问题时,如何保障集群仍然稳定运作?(hystrix 熔断机制,服务降级)
springcloud就是微服务分布式架构下的一站式解决方案!
可以认为是领头羊的一家公司 spring-cloud-netflix 他们针对上述问题给出了一套解决方案
1.Api网关, 相关插件 zuul
2.http的通讯方式,同步并阻塞 相关插件 Feign -> HttpClient
3.服务注册与发现 , 相关插件 Eureka
4.熔断机制 相关插件 Hystrix
二、技术套件使用示例
服务提供者示例
文件结构如下图:
<!--所需要的依赖-->
<dependencies>
<dependency>
<groupId>org.springframework.cloud</groupId>
<artifactId>spring-cloud-starter-eureka</artifactId>
<version>1.4.6.RELEASE</version>
</dependency>
<!--需要实体,所以需要我们自己创建的api 这个当中只有一个实体类-->
<dependency>
<groupId>com.zz</groupId>
<artifactId>springcloud-api</artifactId>
<version>1.0-SNAPSHOT</version>
</dependency>
<dependency>
<groupId>org.mybatis.spring.boot</groupId>
<artifactId>mybatis-spring-boot-starter</artifactId>
</dependency>
<dependency>
<groupId>junit</groupId>
<artifactId>junit</artifactId>
</dependency>
<dependency>
<groupId>mysql</groupId>
<artifactId>mysql-connector-java</artifactId>
</dependency>
<dependency>
<groupId>com.alibaba</groupId>
<artifactId>druid</artifactId>
</dependency>
<dependency>
<groupId>org.springframework.boot</groupId>
<artifactId>spring-boot-starter-web</artifactId>
</dependency>
<dependency>
<groupId>org.springframework.boot</groupId>
<artifactId>spring-boot-starter-jetty</artifactId>
</dependency>
<dependency>
<groupId>org.springframework.boot</groupId>
<artifactId>spring-boot-devtools</artifactId>
</dependency>
</dependencies>
#application.yml配置文件
server:
port: 8001
spring:
application:
name: springcloud-provider-dept
datasource:
username: root
password: 123456
url: jdbc:mysql://localhost:3306/db01?useUnicode=true&characterEncoding=utf-8
driver-class-name: org.gjt.mm.mysql.Driver
mybatis:
type-aliases-package: com.zz.springcloud.pojo
mapper-locations: classpath:mybatis/mapper/*.xml
# 当前这个服务注册到哪里
eureka:
client:
service-url:
defaultZone: http://eureka7001.com:7001/eureka/,http://eureka7002.com:7002/eureka/,http://eureka7003.com:7003/eureka/
instance:
instance-id: springcloud-provider-dept8001
<!--mybatis的mapper配置文件-->
<?xml version="1.0" encoding="UTF-8"?>
<!DOCTYPE mapper
PUBLIC "-//mybatis.org//DTD Mapper 3.0//EN"
"http://mybatis.org/dtd/mybatis-3-mapper.dtd">
<mapper namespace="com.zz.springcloud.mapper.DeptMapper"><!--这个命名空间是固定的!! 要和类路径一致!!-->
<insert id="addDept" parameterType="dept">
insert into dept (dname, db_source) values (#{dname}, database());
</insert>
<select id="queryById" resultType="dept" parameterType="long">
select * from dept where deptno = #{id}
</select>
<select id="queryAll" resultType="dept">
select * from dept
</select>
</mapper>
//对消费者提供服务的controller层
import com.zz.springcloud.pojo.Dept;
import com.zz.springcloud.service.DeptService;
import org.springframework.beans.factory.annotation.Autowired;
import org.springframework.web.bind.annotation.GetMapping;
import org.springframework.web.bind.annotation.PathVariable;
import org.springframework.web.bind.annotation.PostMapping;
import org.springframework.web.bind.annotation.RestController;
import java.util.List;
@RestController
public class DeptController {
@Autowired
private DeptService service;
@PostMapping("/add")
public int add(Dept dept) {
return service.addDept(dept);
}
@GetMapping("/get/{id}")
public Dept queryById(@PathVariable("id") int id) {
return service.queryById(id);
}
@GetMapping("/all")
public List<Dept> queryAll() {
return service.queryAll();
}
}
//*****************************下面是mapper接口****************************************
import com.zz.springcloud.pojo.Dept;
import org.apache.ibatis.annotations.Mapper;
import org.springframework.stereotype.Component;
import java.util.List;
@Mapper
@Component
public interface DeptMapper {
int addDept(Dept dept);
Dept