资讯专栏INFORMATION COLUMN

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

cnsworder / 2113人阅读

摘要:在前面的过程中,我们创建了个服务发现我们使用作为服务发现组件,学习了的使用。加依赖加注解改配置使用项目三部曲,我们可以快速添加一个新组件,并正常使用这个我没有在项目中实现,但是大家可以和一样,三部曲搞定。

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

服务发现

我们使用Eureka 作为服务发现组件,学习了Eureka Server,Eureka Client的使用。

Eureka Server

加依赖

    
        org.springframework.cloud
        
        spring-cloud-starter-eureka-server
        1.2.7.RELEASE
    

加注解

@SpringBootApplication
@EnableEurekaServer
public class DiscoveryApplication {
    public static void main(String[] args) {
        SpringApplication.run(DiscoveryApplication.class, args);
    }
}

改配置

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一样,三部曲搞定。

加依赖(因SC Alibaba即将毕业影响,会从Spring-Cloud家族依赖中移动到alibaba repository下,因此,大家在学习依赖的时候,一定要注意版本信息,github传送门)

    
        org.springframework.cloud
        spring-cloud-starter-alibaba-nacos-discovery
        0.9.0.RELEASE
    

加注解

在早期版本中,我们需要添加@EnableDiscoveryClient,但是在nacos 0.9之后,不需要我们显示的添加注解了~,因此这步可以忽略。

改配置

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

网关路由

加依赖(因为网关也需要注册到服务发现上,因此它也是一个client,那么需要引入spring-cloud-starter-netflix-eureka-client)

    
        
            org.springframework.cloud
            spring-cloud-starter-netflix-zuul
        
        
            org.springframework.cloud
            spring-cloud-starter-netflix-eureka-client
        
    

加注解

/**
* @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);
    }
}

改配置

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 设置的路径进行截取,默认转发会截取掉配置的前缀

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

通用代码库

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

广告投放系统

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

mysql 8

Eureka client

代码与数据库的交互ORM jpa

flyway(数据库版本管理工具)

后续我们要添加的技术

Feign(微服务相互调用)

Ribbon(调用的客户端负载均衡)

hystrix(服务容错以及流控管理)

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

文章版权归作者所有,未经允许请勿转载,若此文章存在违规行为,您可以联系管理员删除。

转载请注明本文地址:https://www.ucloud.cn/yun/75641.html

相关文章

  • [Spring cloud 步步实现广告系统] 8. 检索系统配置&依赖

    摘要:工作流程项目依赖监控面板引入服务调用的组件依赖引入服务消费者的依赖数据库链接依赖工具类集合类操作日志监听解析开源工具类库中的配置相关依赖图片压缩 工作流程 showImg(https://i.loli.net/2019/07/29/5d3ee1829df4d57461.png); 项目依赖 org.springframewo...

    dailybird 评论0 收藏0
  • [Spring cloud 步步实现广告系统] 11. 使用Feign实现微服务调用

    摘要:上一节我们使用了基于进行微服务的调用,的调用比较简单,通过组件对请求的服务进行拦截,通过获取到服务实例的然后再去调用。为了代码的重用性,我们来创建一个新的作为的服务调用工具。 上一节我们使用了Ribbon(基于Http/Tcp)进行微服务的调用,Ribbon的调用比较简单,通过Ribbon组件对请求的服务进行拦截,通过Eureka Server 获取到服务实例的IP:Port,然后再去...

    Forest10 评论0 收藏0
  • [Spring cloud 步步实现广告系统] 12. 广告索引介绍

    摘要:索引设计介绍在我们广告系统中,为了我们能更快的拿到我们想要的广告数据,我们需要对广告数据添加类似于数据库一样的索引结构,分两大类正向索引和倒排索引。如何在广告系统中使用倒排索引核心用途是对各个维度限制的整理。 索引设计介绍 在我们广告系统中,为了我们能更快的拿到我们想要的广告数据,我们需要对广告数据添加类似于数据库index一样的索引结构,分两大类:正向索引和倒排索引。 正向索引 通过...

    endless_road 评论0 收藏0
  • [Spring cloud 步步实现广告系统] 3. 网关路由

    摘要:获取当前请求的请求上下文记录请求进入时间需要最后一个执行的后续更新做一个好人。 Zuul(Router and Filter) WIKI: 传送门 showImg(https://i.loli.net/2019/07/24/5d38183f1dff763558.png); 作用 认证,鉴权(Authentication/Security) 预判(Insights) 压力测试(Stre...

    miguel.jiang 评论0 收藏0
  • [Spring cloud 步步实现广告系统] 10. 使用Ribbon 实现微服务调用

    摘要:在使用调用广告投放系统之前,我们需要先创建个对象,数据请求对象请求响应结果反序列化对象在启动类中,添加客户端。注册让在调用服务的时候,可以实现负载均衡创建一个,来测试调用广告提供系统的若初注入 在使用Ribbon调用广告投放系统API之前,我们需要先创建2个VO对象,AdPlanVO,AdPlanGetRequestVO. //数据请求对象 @Data @NoArgsConstruct...

    junbaor 评论0 收藏0

发表评论

0条评论

cnsworder

|高级讲师

TA的文章

阅读更多
最新活动
阅读需要支付1元查看
<