springcloud技术套件 ——致敬狂神

以下论述,一点儿个人理解。 欢迎各路大佬支持!

一、springcloud诞生的意义

java项目开发历经了,从
jsp(servlet)+实体+数据库的蛮荒时代

MVC三层架构

spring诞生后的 ssm = spring + springMVC +mybatis

springboot 自动装配
这时候 单个服务的开发已经变得极为迅速高效,而java强大的生态,导致项目的访问者会逐渐膨胀。
而单机服务器,再强大,也无法承载极高的并发数据量访问。
这时候有一些策略就是 服务器集群,等价复制多个服务器。 这必然会有计算机资源的浪费!
一条业务线,可能某些环节的处理非常简单, 而某些环节的处理非常复杂。
基于这样的现状, martin fowler 提出了微服务的概念! 将服务拆分! 按需组装~

引入这些概念去解决 大访问量的 软件承载力问题的时候,不可避免的引入了几个基本问题

  1. 多个服务, 客户端如何访问?(zuul API网关)
  2. 多个服务,他们不在同一个机器上,他们如何通信? (http的restful风格feign(ribbon) 或者 rpc框架 dubbo)
  3. 多个服务,如何让每个服务都能均衡的承载业务压力?(服务注册与发现 eureka或zookeeper)
  4. 多个服务必然有网格式依赖,单个服务出现问题时,如何保障集群仍然稳定运作?(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 
  • 0
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值