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

  • 时间:
  • 浏览:0
  • 来源:大发时时彩_时时彩最新网址_大发时时彩最新网址

在前面的过程中,亲戚亲戚我门我门我门我门我门我门 创建了有一个 多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下,因此 ,亲戚亲戚我门我门我门我门我门我门 在学习依赖的之前 ,一定要注意版本信息,github传送门)
      <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: 404060
ce-2e6c-4f72-60

83-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(服务容错以及流控管理)

每三种技术有的是一套删剪的实现以及框架,之前 深入学习的同学请自行索引,后期广告系统之前 结束了了之前 ,我会另起有一个 多系列来和亲戚亲戚我门我门我门我门我门我门 一起去讨论框架底层实现。