33 Spring Cloud 中整合Zipkin進(jìn)行服務(wù)跟蹤zipkin-server

https://blog.csdn.net/huangjinjin520/article/details/90114385

隋釗業(yè)務(wù)的發(fā)展惶洲,系統(tǒng)拆分導(dǎo)致系統(tǒng)調(diào)用的鏈路愈發(fā)復(fù)雜燃乍,一個前端請求可能最終需要調(diào)用很多次后端服務(wù)才能完成,當(dāng)整個請求變慢護(hù)著不可行時,是無法得知該請求時由某個請求或者某些后端服務(wù)引起的脉课,這時候就需要解決如何快速定位服務(wù)故障點挂滓,對癥下藥馒索,于是就有了。分布式系統(tǒng)調(diào)用跟蹤的誕生红碑,現(xiàn)今業(yè)界分布式服務(wù)跟蹤的理論基礎(chǔ)源于GOOgle 的一篇論文<<Dapper, a Large-Scale Distributed Systems Tracing Infrastructure>>, 使用最廣泛的開源實現(xiàn)時 Twitter 的 ZipKin舞吭。

ZipKin是一個開放源代碼分布式的跟蹤系統(tǒng),它提供了在分布式環(huán)境下發(fā)送接收析珊,存儲和可視化跟蹤的機(jī)制這使得我們能夠?qū)Ψ?wù)之間的活動進(jìn)行關(guān)聯(lián)羡鸥,并更清楚的了解我們服務(wù)中發(fā)生的情況。
ZIpKin由Twitter公司開源忠寻,致力于收集服務(wù)的定時數(shù)據(jù)惧浴,以解決微服務(wù)架構(gòu)中的延遲問題,奕剃,包括數(shù)據(jù)的收集衷旅,捐腿,存儲,查找和展現(xiàn)柿顶。每個服務(wù)向zipkin報告計時數(shù)據(jù)茄袖,Zipkin會根據(jù)調(diào)用關(guān)系通過Zipkin UI生成依賴關(guān)系圖,顯示多少跟蹤請求通過每個服務(wù)嘁锯。該系統(tǒng)讓開發(fā)者可以通過一個Web前端輕松的收集和分析數(shù)據(jù)绞佩,例如每次用戶請求服務(wù)處理的時間等,可以方便的監(jiān)控系統(tǒng)中存在的瓶頸猪钮。zipkin提供了可拆拔數(shù)據(jù)存儲方式:In-Memory,MySql,Cassandra以及Elasticsearch.接下來的測試未方便直接采用In-Memory方式進(jìn)行存儲品山,生產(chǎn)推薦使用Elasticsearch.


image

搭建Ziokin-server
1,新建項目
zipkin-server, 對應(yīng)的pom.xml 文件如下:


<project xmlns="http://maven.apache.org/POM/4.0.0" xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance"
    xsi:schemaLocation="http://maven.apache.org/POM/4.0.0 http://maven.apache.org/xsd/maven-4.0.0.xsd">
    <modelVersion>4.0.0</modelVersion>

    <groupId>spring-cloud</groupId>
    <artifactId>zipkin-server</artifactId>
    <version>0.0.1-SNAPSHOT</version>
    <packaging>jar</packaging>

    <name>sc-zipkin-server</name>
    <url>http://maven.apache.org</url>

    <parent>
        <groupId>org.springframework.boot</groupId>
        <artifactId>spring-boot-starter-parent</artifactId>
        <version>2.0.4.RELEASE</version>
    </parent>

    <dependencyManagement>
        <dependencies>
            <dependency>
                <groupId>org.springframework.cloud</groupId>
                <artifactId>spring-cloud-dependencies</artifactId>
                <version>Finchley.RELEASE</version>
                <type>pom</type>
                <scope>import</scope>
            </dependency>

        </dependencies>
    </dependencyManagement>

    <properties>
        <project.build.sourceEncoding>UTF-8</project.build.sourceEncoding>
        <maven.compiler.source>1.8</maven.compiler.source>
        <maven.compiler.target>1.8</maven.compiler.target>
    </properties>

    <dependencies>
        <dependency>
            <groupId>org.springframework.cloud</groupId>
            <artifactId>spring-cloud-starter-netflix-eureka-client</artifactId>
        </dependency>
        <dependency>
            <groupId>io.zipkin.java</groupId>
            <artifactId>zipkin-server</artifactId>
            <version>2.11.8</version>
        </dependency>

        <dependency>
            <groupId>io.zipkin.java</groupId>
            <artifactId>zipkin-autoconfigure-ui</artifactId>
            <version>2.11.8</version>
        </dependency>

    </dependencies>
</project>

2,新建啟動文件:

package com.taotao.zipkinserver;

import org.springframework.boot.SpringApplication;
import org.springframework.boot.autoconfigure.SpringBootApplication;
import org.springframework.cloud.netflix.eureka.EnableEurekaClient;
import zipkin2.server.internal.EnableZipkinServer;

@EnableEurekaClient
@EnableZipkinServer
@SpringBootApplication
public class ZipkinServerApplication {

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

}




備注:存在zipkin.server.EnableZipkinServer和zipkin2.server.internal.EnableZipkinServer兩個EnableZipkinServer注解烤低,其中zipkin.server.EnableZipkinServer已經(jīng)被標(biāo)志為過期肘交,我們這里使用zipkin2.server.internal.EnableZipkinServer
3 新建配置文件application.yml

eureka:
  client:
    service-url:
       defaultZone: http://localhost:8761/eureka/
server:
  port:  9411
spring:
   application:
        name: zipkin-server



4,分別先啟動注冊中心扑馁,再啟動Zipkin-server
5涯呻,驗證Zipkin 是否啟動成功
訪問: http://127.0.0.1:9411/zipkin/dependency/

最后編輯于
?著作權(quán)歸作者所有,轉(zhuǎn)載或內(nèi)容合作請聯(lián)系作者
  • 序言:七十年代末,一起剝皮案震驚了整個濱河市腻要,隨后出現(xiàn)的幾起案子复罐,更是在濱河造成了極大的恐慌,老刑警劉巖雄家,帶你破解...
    沈念sama閱讀 223,207評論 6 521
  • 序言:濱河連續(xù)發(fā)生了三起死亡事件效诅,死亡現(xiàn)場離奇詭異,居然都是意外死亡趟济,警方通過查閱死者的電腦和手機(jī)乱投,發(fā)現(xiàn)死者居然都...
    沈念sama閱讀 95,455評論 3 400
  • 文/潘曉璐 我一進(jìn)店門,熙熙樓的掌柜王于貴愁眉苦臉地迎上來顷编,“玉大人戚炫,你說我怎么就攤上這事∠蔽常” “怎么了双肤?”我有些...
    開封第一講書人閱讀 170,031評論 0 366
  • 文/不壞的土叔 我叫張陵,是天一觀的道長钮惠。 經(jīng)常有香客問我茅糜,道長,這世上最難降的妖魔是什么萌腿? 我笑而不...
    開封第一講書人閱讀 60,334評論 1 300
  • 正文 為了忘掉前任限匣,我火速辦了婚禮,結(jié)果婚禮上,老公的妹妹穿的比我還像新娘米死。我一直安慰自己锌历,他們只是感情好,可當(dāng)我...
    茶點故事閱讀 69,322評論 6 398
  • 文/花漫 我一把揭開白布峦筒。 她就那樣靜靜地躺著究西,像睡著了一般。 火紅的嫁衣襯著肌膚如雪物喷。 梳的紋絲不亂的頭發(fā)上卤材,一...
    開封第一講書人閱讀 52,895評論 1 314
  • 那天,我揣著相機(jī)與錄音峦失,去河邊找鬼扇丛。 笑死,一個胖子當(dāng)著我的面吹牛尉辑,可吹牛的內(nèi)容都是我干的帆精。 我是一名探鬼主播,決...
    沈念sama閱讀 41,300評論 3 424
  • 文/蒼蘭香墨 我猛地睜開眼隧魄,長吁一口氣:“原來是場噩夢啊……” “哼卓练!你這毒婦竟也來了?” 一聲冷哼從身側(cè)響起购啄,我...
    開封第一講書人閱讀 40,264評論 0 277
  • 序言:老撾萬榮一對情侶失蹤襟企,失蹤者是張志新(化名)和其女友劉穎,沒想到半個月后狮含,有當(dāng)?shù)厝嗽跇淞掷锇l(fā)現(xiàn)了一具尸體顽悼,經(jīng)...
    沈念sama閱讀 46,784評論 1 321
  • 正文 獨居荒郊野嶺守林人離奇死亡,尸身上長有42處帶血的膿包…… 初始之章·張勛 以下內(nèi)容為張勛視角 年9月15日...
    茶點故事閱讀 38,870評論 3 343
  • 正文 我和宋清朗相戀三年辉川,在試婚紗的時候發(fā)現(xiàn)自己被綠了表蝙。 大學(xué)時的朋友給我發(fā)了我未婚夫和他白月光在一起吃飯的照片拴测。...
    茶點故事閱讀 40,989評論 1 354
  • 序言:一個原本活蹦亂跳的男人離奇死亡乓旗,死狀恐怖,靈堂內(nèi)的尸體忽然破棺而出集索,到底是詐尸還是另有隱情屿愚,我是刑警寧澤,帶...
    沈念sama閱讀 36,649評論 5 351
  • 正文 年R本政府宣布务荆,位于F島的核電站妆距,受9級特大地震影響,放射性物質(zhì)發(fā)生泄漏函匕。R本人自食惡果不足惜娱据,卻給世界環(huán)境...
    茶點故事閱讀 42,331評論 3 336
  • 文/蒙蒙 一、第九天 我趴在偏房一處隱蔽的房頂上張望盅惜。 院中可真熱鬧中剩,春花似錦忌穿、人聲如沸。這莊子的主人今日做“春日...
    開封第一講書人閱讀 32,814評論 0 25
  • 文/蒼蘭香墨 我抬頭看了看天上的太陽。三九已至郊愧,卻和暖如春朴译,著一層夾襖步出監(jiān)牢的瞬間,已是汗流浹背属铁。 一陣腳步聲響...
    開封第一講書人閱讀 33,940評論 1 275
  • 我被黑心中介騙來泰國打工眠寿, 沒想到剛下飛機(jī)就差點兒被人妖公主榨干…… 1. 我叫王不留,地道東北人焦蘑。 一個月前我還...
    沈念sama閱讀 49,452評論 3 379
  • 正文 我出身青樓澜公,卻偏偏與公主長得像,于是被迫代替她去往敵國和親喇肋。 傳聞我的和親對象是個殘疾皇子坟乾,可洞房花燭夜當(dāng)晚...
    茶點故事閱讀 45,995評論 2 361