欢迎您访问程序员文章站本站旨在为大家提供分享程序员计算机编程知识!
您现在的位置是: 首页  >  IT编程

[Spring cloud 一步步实现广告系统] 7. 中期总结回顾

程序员文章站 2022-05-27 10:02:32
在前面的过程中,我们创建了4个project: "服务发现" 我们使用Eureka 作为服务发现组件,学习了 ,`Eureka Client`的使用。 Eureka Server 1. 加依赖 2. 加注解 3. 改配置 使用Sprint Boot 项目三部曲,我们可以快速添加一个新组件,并正常使用 ......

在前面的过程中,我们创建了4个project:

我们使用eureka 作为服务发现组件,学习了eureka server,eureka client的使用。

  • eureka server
    1. 加依赖
        <dependency>
            <groupid>org.springframework.cloud</groupid>
            <!--<artifactid>spring-cloud-netflix-eureka-server</artifactid>-->
            <artifactid>spring-cloud-starter-eureka-server</artifactid>
            <version>1.2.7.release</version>
        </dependency>
    1. 加注解
    @springbootapplication
    @enableeurekaserver
    public class discoveryapplication {
        public static void main(string[] args) {
            springapplication.run(discoveryapplication.class, args);
        }
    }
    1. 改配置
    eureka:
      instance:
        hostname: server1
        prefer-ip-address: false
      client:
        service-url:
          defaultzone: http://server2:8888/eureka/,http://server3:9999/eureka/

使用sprint boot 项目三部曲,我们可以快速添加一个新组件,并正常使用

  • nacos server
    这个我没有在项目中实现,但是大家可以和eureka一样,三部曲搞定。
  1. 加依赖(因sc alibaba即将毕业影响,会从spring-cloud家族依赖中移动到alibaba repository下,因此,大家在学习依赖的时候,一定要注意版本信息,)
      <dependency>
          <groupid>org.springframework.cloud</groupid>
          <artifactid>spring-cloud-starter-alibaba-nacos-discovery</artifactid>
          <version>0.9.0.release</version>
      </dependency>
  1. 加注解
    在早期版本中,我们需要添加@enablediscoveryclient,但是在nacos 0.9之后,不需要我们显示的添加注解了~,因此这步可以忽略。
  2. 改配置
spring: 
  cloud:
      nacos:
        discovery:
          server-addr: localhost:8848 #前提是要启动nacos server
          metadata:
            version: v1
          # 指定namespace(profile)
          #namespace: 404060ce-2e6c-4f72-8083-2beb4ca921ad
          # 指定集群名称
          cluster-name: bj

nacos server ,请大家自行搜索,可参考 nacos github

  1. 加依赖(因为网关也需要注册到服务发现上,因此它也是一个client,那么需要引入spring-cloud-starter-netflix-eureka-client)
    <dependencies>
        <dependency>
            <groupid>org.springframework.cloud</groupid>
            <artifactid>spring-cloud-starter-netflix-zuul</artifactid>
        </dependency>
        <dependency>
            <groupid>org.springframework.cloud</groupid>
            <artifactid>spring-cloud-starter-netflix-eureka-client</artifactid>
        </dependency>
    </dependencies>
  1. 加注解
/**
* @springcloudapplication 是以下三个注解的组合注解

* @see springbootapplication // 标柱是spring boot 项目启动
* @see enablediscoveryclient // 标柱为服务发现 client,引入eureka依赖之后 等同于 @enableeurekaclient
* @see enablecircuitbreaker // 断路器,后续我们会讲解
*/
@springcloudapplication
@enablezuulproxy //启动网关代理服务
public class gatewayapplication {
    public static void main(string[] args) {
        springapplication.run(gatewayapplication.class, args);
    }
}
  1. 改配置
zuul:
#  ignored-services: '*' # 过滤所有请求,除了下面routes中声明过的服务
  routes:
    sponsor: #在路由中自定义服务路由名称
      path: /ad-sponsor/**
      serviceid: mscx-ad-sponsor #微服务name
      strip-prefix: false
    search: #在路由中自定义服务路由名称
      path: /ad-search/**
      serviceid: mscx-ad-search #微服务name
      strip-prefix: false
  prefix: /gateway/api
  strip-prefix: true #不对 prefix: /gateway/api 设置的路径进行截取,默认转发会截取掉配置的前缀

具体的代码,参考源代码实现。

这个其实大家就可以当作是本项目内的工具类就行了,没什么特殊的需求。

该项目中,我们使用到的技术有:

  1. mysql 8
  2. eureka client
  3. 代码与数据库的交互orm jpa
  4. flyway(数据库版本管理工具)

后续我们要添加的技术

  1. feign(微服务相互调用)
  2. ribbon(调用的客户端负载均衡)
  3. hystrix(服务容错以及流控管理)

每一种技术都有一套完整的实现以及框架,想要深入学习的同学请自行索引,后期广告系统结束之后,我会另起一个系列来和大家一起讨论框架底层实现。