基于SpringCloud全家桶搭建微服务框架实践

前言
  • 目前很多的企业都开始使用SpringCloud全家桶的组件来搭建自己公司微服务架构,因为SpringCloud来源Spring,可以利用SpringBoot进行快捷开发,很多的组件都是对已有的开源框架的集成,社区也越来越强大,对于考虑使用成本和落地成本的中小企业非常合适。

  • 搭建微服务框架使用的组件

组件 作用
Eureka 服务发现
Hystrix 熔断器
Zuul 动态路由
Spring Cloud config 远程配置服务
Ribbon 负载均衡
Feign HTTP客户端
  • 微服务架构下各个组件之间的交互流程图


    各个组件之间的交互流程图
一:搭建Eureka服务 ms-test-eureka
  • 1:创建一个ms-eureka-server的SpringBoot项目,加入依赖,springboot版本要和springcloud版本能兼容,不然会启动报错
<dependency>
    <groupId>org.springframework.cloud</groupId>
    <artifactId>spring-cloud-starter-netflix-eureka-server</artifactId>
</dependency>
  • 2:修改配置文件application.yml (将properties文件转为yml文件,这样看起来更有层次感)
server:
  port: 8761 # 8761是eureka server的默认端口
eureka:
  server:
    enable-self-preservation: true
  client:
    service-url:
      defaultZone: http://localhost:8761/eureka/ #这便是此eureka server的应用注册地址
    register-with-eureka: false #默认设置下,eureka服务注册中心也会将自己做为客户端尝试注册自己,所以要禁止服务端的注册行为
    fetchRegistry: false #注册中心的职责是维护实例,不需要去检索服务
spring:
  application:
    name: ms-eureka-server
  • 3:Application主类加入 @EnableDiscoveryClient 注解
  • 4:启动主类main方法,运行看到的效果如下就代表我们注册中心搭建成功


    eureka注册中心界面
二:搭建配置中心服务 ms-config-server

1:创建一个ms-config-server的SpringBoot项目
2:pom文件加入EurekaClient和spring-config-server的依赖

        <dependency>
            <groupId>org.springframework.cloud</groupId>
            <artifactId>spring-cloud-config-server</artifactId>
        </dependency>
        <dependency>
            <groupId>org.springframework.cloud</groupId>
            <artifactId>spring-cloud-starter-netflix-eureka-server</artifactId>
        </dependency>
        <dependency>
            <groupId>org.springframework.cloud</groupId>
            <artifactId>spring-cloud-commons</artifactId>
        </dependency>

3:修改配置文件,加入注入eureka的服务配置和要拉去的配置文件服务的地址,配置文件用户名和密码要用自己的数据

server:
  port: 9002

spring:
  application:
    name: ms-config-server
  cloud:
    config:
      server:
        git:
          uri: https://github.com/aixinjian/ms-test-config-file.git
          username: ********
          password: ********
          default-label: master
          search-paths: config
  security:
    user:
      name: admin
      password: admin

eureka:
  client:
    serviceUrl:
      defaultZone: http://localhost:8761/eureka/
  instance:
    prefer-ip-address: true
    instance-id: ${spring.application.name}:${spring.cloud.client.ip-address}:${spring.application.instance_id:${server.port}}
    appname: ms-eureka-server

  • 4:application主类加入@EnableEurekaClient和@EnableConfigServer注解
  • 5:启动,看注册中心注册列表里有实例的展示


    注册的服务实例展示
三:测试配置服务中心正常运作
  • 1:创建一个ms-config-client的springboot应用
  • 2:加入依赖
        <dependency>
            <groupId>org.springframework.cloud</groupId>
            <artifactId>spring-cloud-starter-netflix-eureka-server</artifactId>
        </dependency>
        <dependency>
            <groupId>org.springframework.cloud</groupId>
            <artifactId>spring-cloud-commons</artifactId>
        </dependency>
        <dependency>
            <groupId>org.springframework.cloud</groupId>
            <artifactId>spring-cloud-starter-config</artifactId>
        </dependency>
  • 3:修改bootstartp.yml的配置
server:
  port: 9003

spring:
  application:
    name: ms-config-client
  cloud:
    config:
      discovery:
        enabled: true
        serviceId: ms-config-server
      lable: master
      profile: prod

eureka:
  client:
    serverUrl:
      defaultZone: http://localhost:8761/eureka/
  instance:
    prefer-ip-address: true
    instance-id: ${spring.application.name}:${spring.cloud.client.ip-address}:${spring.application.instance_id:${server.port}}
    appname: ms-config-client
  • 4:创建controller测试类
@RefreshScope
@RestController
@RequestMapping("/test")
public class TestController {

    @Value("${data.name}")
    private String name;


    @GetMapping
    public String test() {
        System.out.println(name);
        return name;
    }
}
  • 5:测试结果,把配置库的文件ms-config-client-prod.yml文件中的data.name的属性值读取出来
获取配置文件数据测试结果
四:搭建消费者服务,使用Feign组件进行内部服务之间调用
  • 1:为了省事,我们将已经搭好的ms-config-client当做一个服务提供者,提供所有的人员信息,人员信息必须通过ms-config-client服务获取,我们用Feign组件进行内部服务系统的调用
  • 引入Feign组件依赖
<dependency>
    <groupId>org.springframework.cloud</groupId>
    <artifactId>spring-cloud-starter-openfeign</artifactId>
</dependency>
  • 2:ms-config-client代码如下,为了方便直接定义几个用户实例返回:
 @GetMapping
    public List<UserVo> test() {
        List<UserVo> userVos = Lists.newArrayList();
        userVos.add(new UserVo("aixinjian",30));
        userVos.add(new UserVo("lisi",22));
        userVos.add(new UserVo("zhangshan",23));
        return userVos;
        
    }
  • 3:创建一个ms-consumer-client的springboot应用,按照前面的创建项目工程的步骤加入到eureka注册中心
  • 4:加入测试代码UserController类获取用户列表方法
@RestController
@Slf4j
@RequestMapping("/users")
public class UserController {

    @Autowired
    UserClient userClient;

    @GetMapping
    public List<UserVo> users() {
        List<UserVo> users = userClient.getUserList();
        return users;
    }

}
  • 5:用postman测试查看返回结果,能看到我们消费方从服务提供方获取的数据


    消费方从服务提供方获取的数据
五:使用zuul做API做网关服务
  • 1:和上面类似创建一个ms-api-gateway的springboot项目,加入spring-cloud-starter-netflix-zuul依赖,该依赖包含了负载均衡组件依赖spring-cloud-starter-netflix-ribbon和熔断组件依赖spring-cloud-starter-netflix-hystrix
        <dependency>
            <groupId>org.springframework.cloud</groupId>
            <artifactId>spring-cloud-starter-netflix-zuul</artifactId>
        </dependency>
  • 2:主类加入@EnableZuulProxy注解开启zuul的api网关功能
@EnableZuulProxy
@EnableDiscoveryClient
@SpringBootApplication
public class MsApiGatewayApplication {

    public static void main(String[] args) {
        SpringApplication.run(MsApiGatewayApplication.class, args);
    }

}
  • 3:在application.yml加入路由转发配置规则
zuul:
  routes:
    tms:
      path: /consumer/**
      serviceId: ms-consumer-client
  • 4:通过psotman测试,可以通过网关服务(设置的端口9005)请求ms-consumer-client的接口,看到的返回结果


    网关测试接口返回效果
六:使用spring cloud Sleuth+zipkin实现服务链路跟踪
  • 在企业应用中,随着公司的业务的发展,各种业务和服务越来越多,带来的服务之间的关系也越来越复杂,每一个前端的接口请求都会形成一条复杂的分布式服务调用链路,如果出现了问题,快速能定位问题就显得尤为重要,这就对整条的链路跟踪有个解决性的方案,我们可以使用spring cloud Sleuth+zipkin实现服务链路跟踪的需求
  • 1:创建一个ms-zipkin-server的springboot服务
  • 2:加入maven依赖(这里要注意springboot版本要和springcloud版本对应,不然会报很多的jar报冲突,我这里springboot用的版本2.1.11.RELEASE,springcloud用的Greenwich.SR4版本)
<dependencies>
        <dependency>
            <groupId>org.springframework.boot</groupId>
            <artifactId>spring-boot-starter</artifactId>
        </dependency>
        <dependency>
            <groupId>org.springframework.boot</groupId>
            <artifactId>spring-boot-actuator</artifactId>
        </dependency>
        <dependency>
            <groupId>org.springframework.boot</groupId>
            <artifactId>spring-boot-starter-web</artifactId>
        </dependency>
        <dependency>
            <groupId>io.zipkin.java</groupId>
            <artifactId>zipkin-server</artifactId>
            <version>2.12.3</version>
        </dependency>
        <dependency>
            <groupId>io.zipkin.java</groupId>
            <artifactId>zipkin-autoconfigure-ui</artifactId>
            <version>2.12.3</version>
        </dependency>
        <dependency>
            <groupId>org.springframework.cloud</groupId>
            <artifactId>spring-cloud-starter-netflix-eureka-server</artifactId>
        </dependency>
        <dependency>
            <groupId>org.springframework.cloud</groupId>
            <artifactId>spring-cloud-config-server</artifactId>
        </dependency>
        <dependency>
            <groupId>org.springframework.cloud</groupId>
            <artifactId>spring-cloud-starter-sleuth</artifactId>
        </dependency>
        <dependency>
            <groupId>org.springframework.cloud</groupId>
            <artifactId>spring-cloud-sleuth-zipkin</artifactId>
        </dependency>
        <dependency>
            <groupId>org.springframework.cloud</groupId>
            <artifactId>spring-cloud-context</artifactId>
        </dependency>

    </dependencies>
  • 3:bootstrap.yml加入配置文件
management:
  metrics:
    web:
      server:
        auto-time-requests: false
  • 4:主类加入注解@EnableZipkinServer
  • 5:启动,我们可以看到页面展示效果
  • Zipkin链路跟踪服务页面效果
  • 6:在我们的其他服务上加入zipkin的发现依赖包
<dependency>
    <groupId>org.springframework.cloud</groupId>
    <artifactId>spring-cloud-starter-zipkin</artifactId>
</dependency>
  • 7:其他的服务加入zipkin服务的配置
spring:
    zipkin:
        base-url: http://localhost:9007
        sleuth:
          sampler:
            percentage: 1.0
  • 8:请求接口服务,我们就会发现zipkin的控制台的服务就加入了刚才产生请求消费请求的服务名称


    服务注册到zipkin服务的效果
  • 9:可以查看具体接口请求的链路信息(具体里面的内容我们后面会开专题讲解)


    接口请求链路跟踪信息
七:结尾

这是一个简单的基于springcloud搭建的微服务框架,里面还有很多可以改造的地方,我们如果入手可以借鉴,代码地址在我github上:https://github.com/aixinjian,欢迎指教

参考资料
最后编辑于
©著作权归作者所有,转载或内容合作请联系作者
  • 序言:七十年代末,一起剥皮案震惊了整个滨河市,随后出现的几起案子,更是在滨河造成了极大的恐慌,老刑警刘岩,带你破解...
    沈念sama阅读 213,186评论 6 492
  • 序言:滨河连续发生了三起死亡事件,死亡现场离奇诡异,居然都是意外死亡,警方通过查阅死者的电脑和手机,发现死者居然都...
    沈念sama阅读 90,858评论 3 387
  • 文/潘晓璐 我一进店门,熙熙楼的掌柜王于贵愁眉苦脸地迎上来,“玉大人,你说我怎么就摊上这事。” “怎么了?”我有些...
    开封第一讲书人阅读 158,620评论 0 348
  • 文/不坏的土叔 我叫张陵,是天一观的道长。 经常有香客问我,道长,这世上最难降的妖魔是什么? 我笑而不...
    开封第一讲书人阅读 56,888评论 1 285
  • 正文 为了忘掉前任,我火速办了婚礼,结果婚礼上,老公的妹妹穿的比我还像新娘。我一直安慰自己,他们只是感情好,可当我...
    茶点故事阅读 66,009评论 6 385
  • 文/花漫 我一把揭开白布。 她就那样静静地躺着,像睡着了一般。 火红的嫁衣衬着肌肤如雪。 梳的纹丝不乱的头发上,一...
    开封第一讲书人阅读 50,149评论 1 291
  • 那天,我揣着相机与录音,去河边找鬼。 笑死,一个胖子当着我的面吹牛,可吹牛的内容都是我干的。 我是一名探鬼主播,决...
    沈念sama阅读 39,204评论 3 412
  • 文/苍兰香墨 我猛地睁开眼,长吁一口气:“原来是场噩梦啊……” “哼!你这毒妇竟也来了?” 一声冷哼从身侧响起,我...
    开封第一讲书人阅读 37,956评论 0 268
  • 序言:老挝万荣一对情侣失踪,失踪者是张志新(化名)和其女友刘颖,没想到半个月后,有当地人在树林里发现了一具尸体,经...
    沈念sama阅读 44,385评论 1 303
  • 正文 独居荒郊野岭守林人离奇死亡,尸身上长有42处带血的脓包…… 初始之章·张勋 以下内容为张勋视角 年9月15日...
    茶点故事阅读 36,698评论 2 327
  • 正文 我和宋清朗相恋三年,在试婚纱的时候发现自己被绿了。 大学时的朋友给我发了我未婚夫和他白月光在一起吃饭的照片。...
    茶点故事阅读 38,863评论 1 341
  • 序言:一个原本活蹦乱跳的男人离奇死亡,死状恐怖,灵堂内的尸体忽然破棺而出,到底是诈尸还是另有隐情,我是刑警宁泽,带...
    沈念sama阅读 34,544评论 4 335
  • 正文 年R本政府宣布,位于F岛的核电站,受9级特大地震影响,放射性物质发生泄漏。R本人自食恶果不足惜,却给世界环境...
    茶点故事阅读 40,185评论 3 317
  • 文/蒙蒙 一、第九天 我趴在偏房一处隐蔽的房顶上张望。 院中可真热闹,春花似锦、人声如沸。这庄子的主人今日做“春日...
    开封第一讲书人阅读 30,899评论 0 21
  • 文/苍兰香墨 我抬头看了看天上的太阳。三九已至,却和暖如春,着一层夹袄步出监牢的瞬间,已是汗流浃背。 一阵脚步声响...
    开封第一讲书人阅读 32,141评论 1 267
  • 我被黑心中介骗来泰国打工, 没想到刚下飞机就差点儿被人妖公主榨干…… 1. 我叫王不留,地道东北人。 一个月前我还...
    沈念sama阅读 46,684评论 2 362
  • 正文 我出身青楼,却偏偏与公主长得像,于是被迫代替她去往敌国和亲。 传闻我的和亲对象是个残疾皇子,可洞房花烛夜当晚...
    茶点故事阅读 43,750评论 2 351

推荐阅读更多精彩内容