成人国产在线小视频_日韩寡妇人妻调教在线播放_色成人www永久在线观看_2018国产精品久久_亚洲欧美高清在线30p_亚洲少妇综合一区_黄色在线播放国产_亚洲另类技巧小说校园_国产主播xx日韩_a级毛片在线免费

資訊專欄INFORMATION COLUMN

[Spring cloud 一步步實(shí)現(xiàn)廣告系統(tǒng)] 7. 中期總結(jié)回顧

cnsworder / 2171人閱讀

摘要:在前面的過程中,我們創(chuàng)建了個(gè)服務(wù)發(fā)現(xiàn)我們使用作為服務(wù)發(fā)現(xiàn)組件,學(xué)習(xí)了的使用。加依賴加注解改配置使用項(xiàng)目三部曲,我們可以快速添加一個(gè)新組件,并正常使用這個(gè)我沒有在項(xiàng)目中實(shí)現(xiàn),但是大家可以和一樣,三部曲搞定。

在前面的過程中,我們創(chuàng)建了4個(gè)project:

服務(wù)發(fā)現(xiàn)

我們使用Eureka 作為服務(wù)發(fā)現(xiàn)組件,學(xué)習(xí)了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 項(xiàng)目三部曲,我們可以快速添加一個(gè)新組件,并正常使用

Nacos Server

這個(gè)我沒有在項(xiàng)目中實(shí)現(xiàn),但是大家可以和Eureka一樣,三部曲搞定。

加依賴(因SC Alibaba即將畢業(yè)影響,會(huì)從Spring-Cloud家族依賴中移動(dòng)到alibaba repository下,因此,大家在學(xué)習(xí)依賴的時(shí)候,一定要注意版本信息,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 #前提是要啟動(dòng)Nacos Server
          metadata:
            version: v1
          # 指定namespace(profile)
          #namespace: 404060ce-2e6c-4f72-8083-2beb4ca921ad
          # 指定集群名稱
          cluster-name: BJ

Nacos Server ,請(qǐng)大家自行搜索,可參考 Nacos Github

網(wǎng)關(guān)路由

加依賴(因?yàn)榫W(wǎng)關(guān)也需要注冊(cè)到服務(wù)發(fā)現(xiàn)上,因此它也是一個(gè)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 是以下三個(gè)注解的組合注解

* @see SpringBootApplication // 標(biāo)柱是Spring Boot 項(xiàng)目啟動(dòng)
* @see EnableDiscoveryClient // 標(biāo)柱為服務(wù)發(fā)現(xiàn) client,引入Eureka依賴之后 等同于 @EnableEurekaClient
* @see EnableCircuitBreaker // 斷路器,后續(xù)我們會(huì)講解
*/
@SpringCloudApplication
@EnableZuulProxy //啟動(dòng)網(wǎng)關(guān)代理服務(wù)
public class GatewayApplication {
    public static void main(String[] args) {
        SpringApplication.run(GatewayApplication.class, args);
    }
}

改配置

zuul:
#  ignored-services: "*" # 過濾所有請(qǐng)求,除了下面routes中聲明過的服務(wù)
  routes:
    sponsor: #在路由中自定義服務(wù)路由名稱
      path: /ad-sponsor/**
      serviceId: mscx-ad-sponsor #微服務(wù)name
      strip-prefix: false
    search: #在路由中自定義服務(wù)路由名稱
      path: /ad-search/**
      serviceId: mscx-ad-search #微服務(wù)name
      strip-prefix: false
  prefix: /gateway/api
  strip-prefix: true #不對(duì) prefix: /gateway/api 設(shè)置的路徑進(jìn)行截取,默認(rèn)轉(zhuǎn)發(fā)會(huì)截取掉配置的前綴

具體的代碼,參考源代碼實(shí)現(xiàn)。

通用代碼庫

這個(gè)其實(shí)大家就可以當(dāng)作是本項(xiàng)目內(nèi)的工具類就行了,沒什么特殊的需求。

廣告投放系統(tǒng)

該項(xiàng)目中,我們使用到的技術(shù)有:

mysql 8

Eureka client

代碼與數(shù)據(jù)庫的交互ORM jpa

flyway(數(shù)據(jù)庫版本管理工具)

后續(xù)我們要添加的技術(shù)

Feign(微服務(wù)相互調(diào)用)

Ribbon(調(diào)用的客戶端負(fù)載均衡)

hystrix(服務(wù)容錯(cuò)以及流控管理)

每一種技術(shù)都有一套完整的實(shí)現(xiàn)以及框架,想要深入學(xué)習(xí)的同學(xué)請(qǐng)自行索引,后期廣告系統(tǒng)結(jié)束之后,我會(huì)另起一個(gè)系列來和大家一起討論框架底層實(shí)現(xiàn)。

文章版權(quán)歸作者所有,未經(jīng)允許請(qǐng)勿轉(zhuǎn)載,若此文章存在違規(guī)行為,您可以聯(lián)系管理員刪除。

轉(zhuǎn)載請(qǐng)注明本文地址:http://systransis.cn/yun/75641.html

相關(guān)文章

  • [Spring cloud 步步實(shí)現(xiàn)廣告系統(tǒng)] 8. 檢索系統(tǒng)配置&依賴

    摘要:工作流程項(xiàng)目依賴監(jiān)控面板引入服務(wù)調(diào)用的組件依賴引入服務(wù)消費(fèi)者的依賴數(shù)據(jù)庫鏈接依賴工具類集合類操作日志監(jiān)聽解析開源工具類庫中的配置相關(guān)依賴圖片壓縮 工作流程 showImg(https://i.loli.net/2019/07/29/5d3ee1829df4d57461.png); 項(xiàng)目依賴 org.springframewo...

    dailybird 評(píng)論0 收藏0
  • [Spring cloud 步步實(shí)現(xiàn)廣告系統(tǒng)] 11. 使用Feign實(shí)現(xiàn)微服務(wù)調(diào)用

    摘要:上一節(jié)我們使用了基于進(jìn)行微服務(wù)的調(diào)用,的調(diào)用比較簡單,通過組件對(duì)請(qǐng)求的服務(wù)進(jìn)行攔截,通過獲取到服務(wù)實(shí)例的然后再去調(diào)用。為了代碼的重用性,我們來創(chuàng)建一個(gè)新的作為的服務(wù)調(diào)用工具。 上一節(jié)我們使用了Ribbon(基于Http/Tcp)進(jìn)行微服務(wù)的調(diào)用,Ribbon的調(diào)用比較簡單,通過Ribbon組件對(duì)請(qǐng)求的服務(wù)進(jìn)行攔截,通過Eureka Server 獲取到服務(wù)實(shí)例的IP:Port,然后再去...

    Forest10 評(píng)論0 收藏0
  • [Spring cloud 步步實(shí)現(xiàn)廣告系統(tǒng)] 12. 廣告索引介紹

    摘要:索引設(shè)計(jì)介紹在我們廣告系統(tǒng)中,為了我們能更快的拿到我們想要的廣告數(shù)據(jù),我們需要對(duì)廣告數(shù)據(jù)添加類似于數(shù)據(jù)庫一樣的索引結(jié)構(gòu),分兩大類正向索引和倒排索引。如何在廣告系統(tǒng)中使用倒排索引核心用途是對(duì)各個(gè)維度限制的整理。 索引設(shè)計(jì)介紹 在我們廣告系統(tǒng)中,為了我們能更快的拿到我們想要的廣告數(shù)據(jù),我們需要對(duì)廣告數(shù)據(jù)添加類似于數(shù)據(jù)庫index一樣的索引結(jié)構(gòu),分兩大類:正向索引和倒排索引。 正向索引 通過...

    endless_road 評(píng)論0 收藏0
  • [Spring cloud 步步實(shí)現(xiàn)廣告系統(tǒng)] 3. 網(wǎng)關(guān)路由

    摘要:獲取當(dāng)前請(qǐng)求的請(qǐng)求上下文記錄請(qǐng)求進(jìn)入時(shí)間需要最后一個(gè)執(zhí)行的后續(xù)更新做一個(gè)好人。 Zuul(Router and Filter) WIKI: 傳送門 showImg(https://i.loli.net/2019/07/24/5d38183f1dff763558.png); 作用 認(rèn)證,鑒權(quán)(Authentication/Security) 預(yù)判(Insights) 壓力測試(Stre...

    miguel.jiang 評(píng)論0 收藏0
  • [Spring cloud 步步實(shí)現(xiàn)廣告系統(tǒng)] 10. 使用Ribbon 實(shí)現(xiàn)微服務(wù)調(diào)用

    摘要:在使用調(diào)用廣告投放系統(tǒng)之前,我們需要先創(chuàng)建個(gè)對(duì)象,數(shù)據(jù)請(qǐng)求對(duì)象請(qǐng)求響應(yīng)結(jié)果反序列化對(duì)象在啟動(dòng)類中,添加客戶端。注冊(cè)讓在調(diào)用服務(wù)的時(shí)候,可以實(shí)現(xiàn)負(fù)載均衡創(chuàng)建一個(gè),來測試調(diào)用廣告提供系統(tǒng)的若初注入 在使用Ribbon調(diào)用廣告投放系統(tǒng)API之前,我們需要先創(chuàng)建2個(gè)VO對(duì)象,AdPlanVO,AdPlanGetRequestVO. //數(shù)據(jù)請(qǐng)求對(duì)象 @Data @NoArgsConstruct...

    junbaor 評(píng)論0 收藏0

發(fā)表評(píng)論

0條評(píng)論

最新活動(dòng)
閱讀需要支付1元查看
<