SpringCloud day1

本文介绍了系统架构的演变历程,从单一应用到微服务架构,重点讲解了Spring Cloud的基础知识,包括其简介、版本管理和与Spring Boot的匹配关系。然后,通过模拟微服务场景,详细阐述了如何创建服务提供者和消费者,并整合了Eureka作为注册中心,实现了服务的注册与发现。文章最后讨论了负载均衡工具Ribbon和熔断器Hystrix,展示了如何通过Hystrix实现服务降级和熔断机制。
摘要由CSDN通过智能技术生成

github

一、系统架构演变之路(回顾)

在这里插入图片描述

1.1 单一应用架构

当网站流量很小时,只需要一个应用,所有功能部署在一起,减少部署节点成本的框架称之为集中式框架。此时,用于简化增删改查工作量的数据访问框架(ORM)是影响项目开发的关键。

1.2 垂直应用架构

当访问量逐渐增大,单一应用增加机器带来的加速度越来越小,将应用拆成互不相干的几个应用,以提升效率。此时,用于加速前端页面开发的Web框架(MVC)是关键。

1.3 分布式服务架构

当垂直应用越来越多,应用之间交互不可避免,将核心业务抽取出来,作为独立的服务,逐渐形成稳定的服务中心,使前端应用能更快速的响应多变的市场需求。此时,用于提高业务复用及整合的分布式服务框架(RPC)是关键。

1.4 面向服务架构

典型代表有两个:流动计算架构和微服务架构;

流动计算架构:

当服务越来越多,容量的评估,小服务资源的浪费等问题逐渐显现,此时需增加一个调度中心基于访问压力实时管理集群容量,提高集群利用率。此时,用于提高机器利用率的资源调度和治理中心(SOA)是关键。流动计算架构的最佳实践阿里的Dubbo。

微服务架构

与流动计算架构很相似,除了具备流动计算架构优势外,微服务架构中的微服务可以独立部署,独立发展。且微服务的开发不会限制于任何技术栈。微服务架构的最佳实践是SpringCloud。

二、初识Spring Cloud

2.1 Spring Cloud简介

Spring Cloud是一系列框架的有序集合。它利用Spring Boot的开发便利性巧妙地简化了分布式系统基础设施的开发,如服务发现注册、配置中心、消息总线、负载均衡、断路器、数据监控等,都可以用Spring Boot的开发风格做到一键启动和部署。Spring Cloud并没有重复制造轮子,它只是将目前各家公司开发的比较成熟、经得起实际考验的服务框架组合起来,通过Spring Boot风格进行再封装屏蔽掉了复杂的配置和实现原理,最终给开发者留出了一套简单易懂、易部署和易维护的分布式系统开发工具包。

Spring Cloud从技术架构上降低了对大型系统构建的要求和难度,使我们以非常低的成本(技术或者硬件)搭建一套高效、分布式、容错的平台,但Spring Cloud也不是没有缺点,小型独立的项目不适合使用。
在这里插入图片描述

2.2 Spring Cloud的版本

在这里插入图片描述

  • SpringCloud是一系列框架组合,为了避免与框架版本产生混淆,采用新的版本命名方式,形式为大版本名+子版本名称
  • 大版本名用伦敦地铁站名:
  • 子版本名称三种
    • SNAPSHOT:快照版本,尝鲜版,随时可能修改
    • M版本,MileStone,M1表示第一个里程碑版本,一般同时标注PRE,表示预览版
    • SR,Service Release,SR1表示第一个正式版本,同时标注GA(Generally Available),稳定版

2.3 SpringCloud与SpringBoot版本匹配关系

SpringBoot SpringCloud
1.2.x Angel版本
1.3.x Brixton版本
1.4.x Camden版本
1.5.x Dalston版本、Edgware
2.0.x Finchley版本
2.1.x Greenwich GA版本 (2019年2月发布)

鉴于SpringBoot与SpringCloud关系,SpringBoot建议采用2.1.x版本

三、模拟微服务业务场景

模拟开发过程中的服务间关系。抽象出来,开发中的微服务之间的关系是生产者和消费者关系。

目标:模拟一个最简单的服务调用场景,场景中包含微服务提供者(Producer)和微服务调用者(Consumer),方便后面学习微服务架构

注意:实际开发中,每个微服务为一个独立的SpringBoot工程。

3.1 创建父工程

新建一个父项目itheima_parent

在这里插入图片描述

3.2 创建服务提供者(provider)工程

**目标:**新建一个项目provider_service,对外提供查询用户的服务

实现步骤:

  1. 创建SpringBoot工程,勾选依赖坐标
  2. 创建User表、创建实体User
  3. 编写三层架构:Mapper、Service、controller
  4. 编写查询方法,基于注解编写查询语句
  5. 在application.properties中添加配置:端口,数据库连接信息
  6. 访问测试地址

实现过程:

  1. 创建SpringBoot工程
    在这里插入图片描述
    勾选依赖坐标
    在这里插入图片描述
    创建User表、创建实体User
-- 创建数据库
CREATE database springcloud CHARACTER SET utf8 COLLATE utf8_general_ci;
-- 使用springcloud数据库
USE springcloud;
-- ----------------------------
-- Table structure for tb_user
-- ----------------------------
CREATE TABLE `tb_user` (
  `id` int(11) NOT NULL AUTO_INCREMENT,
  `username` varchar(100) DEFAULT NULL COMMENT '用户名',
  `password` varchar(100) DEFAULT NULL COMMENT '密码',
  `name` varchar(100) DEFAULT NULL COMMENT '姓名',
  `age` int(11) DEFAULT NULL COMMENT '年龄',
  `sex` int(11) DEFAULT NULL COMMENT '性别,1男,2女',
  `birthday` date DEFAULT NULL COMMENT '出生日期',
  `created` date DEFAULT NULL COMMENT '创建时间',
  `updated` date DEFAULT NULL COMMENT '更新时间',
  `note` varchar(1000) DEFAULT NULL COMMENT '备注',
  PRIMARY KEY (`id`)
) ENGINE=InnoDB AUTO_INCREMENT=2 DEFAULT CHARSET=utf8 COMMENT='用户信息表';
-- ----------------------------
-- Records of tb_user
-- ----------------------------
INSERT INTO `tb_user` VALUES ('1', 'zhangsan', '123456', '张三', '13', '1', '2006-08-01', '2019-05-16', '2019-05-16', '张三');
INSERT INTO `tb_user` VALUES ('2', 'lisi', '123456', '李四', '13', '1', '2006-08-01', '2019-05-16', '2019-05-16', '李四');
  1. 实体bean:

    public class User {
         
        private Integer id;//主键id
        private String username;//用户名
        private String password;//密码
        private String name;//姓名
        private Integer age;//年龄
        private Integer sex;//性别 1男性,2女性
        private Date birthday; //出生日期
        private Date created; //创建时间
        private Date updated; //更新时间
        private String note;//备注
    	//getter setter
    }
    
  2. 编写三层架构:Mapper、Service、controller,编写查询所有的方法

    service类:

    @Service
    public class UserServiceImpl implements UserService {
         
    
        @Autowired
     private UserMapper userMapper;
        @Override
     
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值