【第二十七章】 springboot + zipkin(brave-okhttp實現)

本文截取自:http://blog.csdn.net/liaokailin/article/details/52077620

一、前提

1、zipkin基本知識:附8 zipkin

2、啟動zipkin server:

2.1、在官網下載服務jar,http://zipkin.io/pages/quickstart.html,之后使用命令啟動服務jar即可。

  • nohup java -jar zipkin-server-1.5.1-exec.jar &

之后,查看與該jar同目錄下的nohup.out日志文件,發現其實該jar也是由springboot打成的,且內置的tomcat的啟動端口是9411,如下:

2.2、打開瀏覽器,http://ip:9411/(host為服務啟動的host)。

?

二、代碼實現

1、service1

1.1、pom.xml

<dependency><groupId>io.zipkin.brave</groupId><artifactId>brave-core</artifactId><version>3.9.0</version></dependency><dependency><groupId>io.zipkin.brave</groupId><artifactId>brave-spancollector-http</artifactId><version>3.9.0</version></dependency><dependency><groupId>io.zipkin.brave</groupId><artifactId>brave-web-servlet-filter</artifactId><version>3.9.0</version></dependency><dependency><groupId>io.zipkin.brave</groupId><artifactId>brave-okhttp</artifactId><version>3.9.0</version></dependency>

1.2、ZipkinConfig

package com.xxx.service1.zipkin;import org.springframework.context.annotation.Bean;
import org.springframework.context.annotation.Configuration;import com.github.kristofa.brave.Brave;
import com.github.kristofa.brave.EmptySpanCollectorMetricsHandler;
import com.github.kristofa.brave.Sampler;
import com.github.kristofa.brave.SpanCollector;
import com.github.kristofa.brave.http.DefaultSpanNameProvider;
import com.github.kristofa.brave.http.HttpSpanCollector;
import com.github.kristofa.brave.okhttp.BraveOkHttpRequestResponseInterceptor;
import com.github.kristofa.brave.servlet.BraveServletFilter;import okhttp3.OkHttpClient;/*** zipkin配置*/
@Configuration
public class ZipkinConfig {@Beanpublic SpanCollector spanCollector() {HttpSpanCollector.Config spanConfig = HttpSpanCollector.Config.builder().compressionEnabled(false)//默認false,span在transport之前是否會被gzipped。.connectTimeout(5000)//5s,默認10s.flushInterval(1)//1s.readTimeout(6000)//5s,默認60s
                                              .build();return HttpSpanCollector.create("http://ip:9411", spanConfig,new EmptySpanCollectorMetricsHandler());}@Beanpublic Brave brave(SpanCollector spanCollector) {Brave.Builder builder = new Brave.Builder("service1");//指定serviceName
        builder.spanCollector(spanCollector);builder.traceSampler(Sampler.create(1));//采集率return builder.build();}@Beanpublic BraveServletFilter braveServletFilter(Brave brave) {/*** 設置sr、ss攔截器*/return new BraveServletFilter(brave.serverRequestInterceptor(), brave.serverResponseInterceptor(),new DefaultSpanNameProvider());}@Beanpublic OkHttpClient okHttpClient(Brave brave){/*** 設置cs、cr攔截器*/return new OkHttpClient.Builder().addInterceptor(new BraveOkHttpRequestResponseInterceptor(brave.clientRequestInterceptor(), brave.clientResponseInterceptor(), new DefaultSpanNameProvider())).build();}}

說明:

  • HttpSpanCollector:span信息收集器
  • Brave:基本實例,注意傳入的參數是serviceName
  • BraveServletFilter:設置sr(server receive),ss(server send)攔截器
  • OkHttpClient:構建client實例,添加攔截器,設置cs(client send),cr(client receive)攔截器

1.3、ZipkinBraveController

package com.xxx.service1.zipkin;import org.springframework.beans.factory.annotation.Autowired;
import org.springframework.web.bind.annotation.RequestMapping;
import org.springframework.web.bind.annotation.RestController;import io.swagger.annotations.Api;
import io.swagger.annotations.ApiOperation;
import okhttp3.OkHttpClient;
import okhttp3.Request;
import okhttp3.Response;@Api("zipkin brave api")
@RestController
@RequestMapping("/zipkin/brave/service1")
public class ZipkinBraveController {@Autowiredprivate OkHttpClient okHttpClient;@ApiOperation("trace第一步")@RequestMapping("/test1")public String myboot() throws Exception {Thread.sleep(100);//100msRequest request = new Request.Builder().url("http://localhost:8032/zipkin/brave/service2/test2").build();/** 1、執行execute()的前后,會執行相應的攔截器(cs,cr)* 2、請求在被調用方執行的前后,也會執行相應的攔截器(sr,ss)*/Response response = okHttpClient.newCall(request).execute();return response.body().string();}}

1.4、application.properties

server.port=8031

2、service2

2.1、pom.xml、ZipkinConfig與service1相似,config部分需要換掉serviceName為"service2"

2.2、controller

package com.xxx.service2.zipkin;import org.springframework.beans.factory.annotation.Autowired;
import org.springframework.web.bind.annotation.RequestMapping;
import org.springframework.web.bind.annotation.RequestMethod;
import org.springframework.web.bind.annotation.RestController;import io.swagger.annotations.Api;
import io.swagger.annotations.ApiOperation;
import okhttp3.OkHttpClient;
import okhttp3.Request;
import okhttp3.Response;@Api("zipkin brave api")
@RestController
@RequestMapping("/zipkin/brave/service2")
public class ZipkinBraveController {@Autowiredprivate OkHttpClient okHttpClient;@ApiOperation("trace第二步")@RequestMapping(value="/test2",method=RequestMethod.GET)public String myboot() throws Exception {Thread.sleep(200);//100msRequest request3 = new Request.Builder().url("http://localhost:8033/zipkin/brave/service3/test3").build();Response response3 = okHttpClient.newCall(request3).execute();String response3Str = response3.body().string();Request request4 = new Request.Builder().url("http://localhost:8034/zipkin/brave/service4/test4").build();Response response4 = okHttpClient.newCall(request4).execute();String response4Str = response4.body().string();return response3Str + "-" +response4Str;}}

2.3、application.properties

server.port=8032

3、service3

3.1、pom.xml、ZipkinConfig與service1相似,config部分需要換掉serviceName為"service3"

3.2、controller

package com.xxx.service3.zipkin;import org.springframework.web.bind.annotation.RequestMapping;
import org.springframework.web.bind.annotation.RequestMethod;
import org.springframework.web.bind.annotation.RestController;import io.swagger.annotations.Api;
import io.swagger.annotations.ApiOperation;@Api("zipkin brave api")
@RestController
@RequestMapping("/zipkin/brave/service3")
public class ZipkinBraveController {@ApiOperation("trace第三步")@RequestMapping(value="/test3",method=RequestMethod.GET)public String myboot() throws Exception {Thread.sleep(300);//100msreturn "service3";}}

3.3、application.properties

server.port=8033

4、service4

4.1、pom.xml、ZipkinConfig與service1相似,config部分需要換掉serviceName為"service4"

4.2、controller

package com.xxx.service4.zipkin;import org.springframework.web.bind.annotation.RequestMapping;
import org.springframework.web.bind.annotation.RequestMethod;
import org.springframework.web.bind.annotation.RestController;import io.swagger.annotations.Api;
import io.swagger.annotations.ApiOperation;@Api("zipkin brave api")
@RestController
@RequestMapping("/zipkin/brave/service4")
public class ZipkinBraveController {@ApiOperation("trace第4步")@RequestMapping(value = "/test4", method = RequestMethod.GET)public String myboot() throws Exception {Thread.sleep(400);//100msreturn "service4";}}

4.3、application.properties

server.port=8034

三、測試

swagger訪問localhost:8031/zipkin/brave/service1/test1,之后查看zipkin webUI即可。

結果:

1、查看調用依賴:

2、查看調用時間對比

點擊第4個span,查看調用詳情:

本文來自互聯網用戶投稿,該文觀點僅代表作者本人,不代表本站立場。本站僅提供信息存儲空間服務,不擁有所有權,不承擔相關法律責任。
如若轉載,請注明出處:http://www.pswp.cn/news/258008.shtml
繁體地址,請注明出處:http://hk.pswp.cn/news/258008.shtml
英文地址,請注明出處:http://en.pswp.cn/news/258008.shtml

如若內容造成侵權/違法違規/事實不符,請聯系多彩編程網進行投訴反饋email:809451989@qq.com,一經查實,立即刪除!

相關文章

Oracle 數據定義語言,oracle 數據定義語言(DDL)語法

DDL語言包括數據庫對象的創建(create)、刪除(drop)和修改(alter)的操作1.創建表語法create table table_name(column_name datatype [null | not null],column_name datatype [null | not null],..........[constraint])constraint 是為表中的列設置約束&#xff0c;常見的有…

Android內存泄漏問題(一)

前言 不少人認為JAVA程序&#xff0c;因為有垃圾回收機制&#xff0c;應該沒有內存泄露。 其實如果我們一個程序中&#xff0c;已經不再使用某個對象&#xff0c;但是因為仍然有引用指向它&#xff0c;垃圾回收器就無法回收它&#xff0c;當然該對象占用的內存就無法被使用&…

向上彈出菜單jQuery插件

插件名&#xff1a;柯樂義英文名&#xff1a;Keleyijs文件名稱&#xff1a;jquery.keleyi.js插件功能&#xff1a;該插件可以讓你輕易地在頁面上構建一個向上彈出的二級菜單。支持瀏覽器&#xff1a;keleyi 0.1.4版本支持IE6以及以上、Chrome、火狐(Firefox)、歐朋(Opera)、Saf…

oracle在線sql數據庫設計,一款在線ER模型設計工具,支持MySQL、SQLServer、Oracle、Postgresql...

在線QQ客服&#xff1a;1922638專業的SQL Server、MySQL數據庫同步軟件介紹一個在線ER模型生成工具&#xff0c;該工具可以在線為多個數據庫的DDL文件生成ER模型圖&#xff0c;并支持MySQL&#xff0c;SQLServer&#xff0c;Oracle&#xff0c;PostgreSQL和其他數據庫。主要功能…

_M_invoke(_Index_tuple_Indices...)

2019獨角獸企業重金招聘Python工程師標準>>> [hadoopiZ25s7cmfyrZ C_script]$ cat test_thread_a.cpp #include <iostream> #include <atomic> #include <thread> #include <vector>std::atomic<int> global_counter(0);void increa…

十年后2023年再讀這篇文章,看看我將會怎么樣?

http://blog.csdn.net/wojiushiwo987/article/details/8453881看到一篇文章不錯【清華差生10年奮斗經歷】 &#xff0c;寫給將要工作的自己&#xff0c;十年后2023年再讀這篇文章&#xff0c;看看我將會怎么樣&#xff1f; 在2012年收關時刻&#xff0c;看到如此激勵的文章&…

1203正規式轉換為有窮自動機

1 #include<stdio.h>2 #include <ctype.h>3 #define ok 14 #define error 05 #define MAXREGLUARLONG 406 #define MAXSTATELONG 40 7 #define MAXCAHRSLONG 40 8 typedef int state;9 int iCurrentState0; //初態以1開始10 int iPreState0;11 in…

fasttext的基本使用 java 、python為例子

fasttext的基本使用 java 、python為例子 今天早上在地鐵上看到知乎上看到有人使用fasttext進行文本分類&#xff0c;到公司試了下情況在GitHub上找了下&#xff0c;最開始是c版本的實現&#xff0c;不過有Java、Python版本的實現了&#xff0c;正好拿下來試試手&#xff0c; p…

oracle spring 分頁查詢,SpringJDBC 調用oracle 通用存儲過程分頁

我博客前面有寫道SpringJDBC調用通用的Oracle存儲過程,今天來講一下通用的Java存儲過程帶分頁的功能,其中里面還有動態查詢的SQL拼接,好的,先上代碼1.Java代碼Autowiredprivate JdbcTemplate jdbcTemplate;/**分頁查詢* return*/ResponseBodyRequestMapping(value "/find…

寶寶頭三年至關重要,不看悔掉腸子

http://www.nowamagic.net/librarys/eight/posts/1885以下是一個早教工作者分享他關于現代父母早期教育中出現的問題和多數父母的誤區。正如作者問自己的&#xff1a;“在孩子人生最重要的頭三年&#xff0c;我做對了嗎&#xff1f;在我的引導下&#xff0c;她能保持強烈的探索…

2015年底總結

2015-12-06 16:17&#xff0c;今天是周日&#xff0c;不需要加班的&#xff0c;到公司看看書&#xff0c;寫寫代碼的&#xff0c;突然想到又是年底了&#xff01;需要寫點東西來記錄總結一下2015年了 年初的時候&#xff0c;入職現在這家成都游戲公司&#xff0c;到現在差不多也…

python腳本

01.用戶三次登錄鎖定猜年齡游戲02.購物車省縣市三級聯動03.函數、文件操作實現數據增刪改查---low版本04.ATM購物商城05.模擬計算器持續更新中...腳本很low&#xff0c;但我一直在學。。。轉載于:https://blog.51cto.com/lyndon/1947437

oracle 命令日志輸出,ORACLE常用命令日志

第一章&#xff1a;日志管理1.forcing log switchessql> alter system switch logfile;2.forcing checkpointssql> alter system checkpoint;3.adding online redo log groupssql> alter database add logfile [group 4]sql> (/disk3/log4a.rdo,/disk4/log4b.rdo) …

[VMware WorkStation]虛擬機網絡

1、簡介&#xff1a; vmware為我們提供了三種網絡工作模式&#xff0c;它們分別是&#xff1a;Bridged&#xff08;橋接模式&#xff09;、NAT&#xff08;網絡地址轉換模式&#xff09;、Host-Only&#xff08;僅主機模式&#xff09;。在我安裝了vmware workstation player 1…

阿里查出售假店主并索賠140萬,這次是大數據幫的忙

阿里巴巴將平臺上一家曾出售假貨的網店起訴至深圳市龍崗區法院&#xff0c;以“違背平臺不得售假約定、侵犯平臺商譽”為由索賠140萬元人民幣。此案為國內首例電商平臺起訴售假店主案。 阿里巴巴目前已經準備了一份超長起訴清單&#xff0c;計劃以違背合同約定、侵犯商譽為由&a…

oracle 升級前備份,rac(exadata)升級前的備份及LVM快照的恢復

1、熱備所有數據庫熱備腳本&#xff1a;10.1.1.200&#xff0c;/backup/scripts/whole_db_backup.sh2、在每個計算節點執行dbserver_backup.sh腳本Run script "dbserver_backup.sh" in each compute node. The script takes backup of "/boot" (to ROOT f…

我心中的MySQL DBA

原文網址鏈接&#xff1a;http://wangwei007.blog.51cto.com/68019/1718311 MySQL是一個跨平臺的開源關系型數據庫管理系統&#xff0c;目前MySQL被廣泛地應用在Internet上的中小型網站中。由于其體積小、速度快、總體擁有成本低&#xff0c;尤其是開放源碼這一特點&#xff0c…

Visual Studio 2015 前瞻 屬性初始化賦值!

通常我們建立屬性的時候如果帶初始化值的時候我們經常會這樣處理。 class MyClass{private string _name "hello world!";public string Name {get{return _name;}set{_name value;}}} 或者也可以這樣寫 &#xff1a; class MyClass{public string Name { set; get…

火狐中的CSS Grid Inspector新增強大的功能

2019獨角獸企業重金招聘Python工程師標準>>> 上周&#xff0c;我談到了日常的網站瀏覽我用Firefox&#xff0c;但是在切圖網做前端開發的時候我會用Chrome。 隨著每個版本&#xff0c;FF Nightly在開發工具箱中有一些越來越棒的工具&#xff0c;這些更新使Firefox成…

Linux內核態之間進程通信,內核態和用戶態通信(二)--實現

本文主要使用netlink套接字實現中斷環境與用戶態進程通信。系統環境&#xff1a;基于linux 2.6.32.27 和 linux 3.16.36Linux內核態和用戶態進程通信方法的提出和實現用戶上下文環境運行在用戶上下文環境中的代碼是可以阻塞的&#xff0c;這樣&#xff0c;便可以使用消息隊列和…