欧美bbbwbbbw肥妇,免费乱码人妻系列日韩,一级黄片

如何讓你的Nginx支持分布式追蹤詳解

 更新時(shí)間:2022年07月04日 08:14:26   作者:woki  
分布式追蹤系統(tǒng)(Tracing)旨在分析請(qǐng)求背后調(diào)用了哪些服務(wù),服務(wù)的調(diào)用順序、耗時(shí)、錯(cuò)誤原因等,下面這篇文章主要給大家介紹了關(guān)于如何讓你的Nginx支持分布式追蹤的相關(guān)資料,需要的朋友可以參考下

Background

NGINX 是一個(gè)通用且流行的應(yīng)用程序。也是最流行的 Web 服務(wù)器,它可用于提供靜態(tài)文件內(nèi)容,但也通常與其他服務(wù)一起用作分布式系統(tǒng)中的組件,在其中它用作反向代理、負(fù)載均衡 或 API 網(wǎng)關(guān)。

分布式追蹤 distributed tracing 是一種可用于分析與監(jiān)控應(yīng)用程序的機(jī)制,將追蹤在從源到目的的整個(gè)過(guò)程中的單個(gè)請(qǐng)求,這與僅通過(guò)單個(gè)應(yīng)用程序域來(lái)追蹤請(qǐng)求的形式不同。

換句話說(shuō),我們可以說(shuō)分布式追蹤是對(duì)跨多個(gè)系統(tǒng)的多個(gè)請(qǐng)求的拼接。拼接通常由一個(gè)或多個(gè)相關(guān) ID 完成,并且跟蹤通常是一組記錄的、跨所有系統(tǒng)的結(jié)構(gòu)化日志事件,存儲(chǔ)在一個(gè)中心位置。

在這種背景的情況下, OpenTracing 應(yīng)運(yùn)而生。OpenTracing 是一個(gè)與應(yīng)用供應(yīng)商無(wú)關(guān)的 API,它可幫助開(kāi)發(fā)人員輕松地跟蹤單一請(qǐng)求的域。目前有多種開(kāi)源產(chǎn)品都支持 OpenTracing(例如,Jaeger, skywalking 等),并將其作為一種檢測(cè)分布式追蹤的標(biāo)準(zhǔn)化方法。

本文將圍繞,從0到1實(shí)現(xiàn)在nginx配置分布式追蹤的架構(gòu)的簡(jiǎn)單實(shí)例說(shuō)明。本文實(shí)例使用的組件為

  • nginx-1.22
  • jaeger-all-in-on v1.38
  • nginx-opentracing v1.22
  • jaeger-client-cpp v0.9

源碼構(gòu)建nginx-opentracing

準(zhǔn)備nginx-opentracing

nginx-opentracing 倉(cāng)庫(kù)中可以看到,官方為每個(gè)nginx版本都提供了一個(gè)編譯好的動(dòng)態(tài)庫(kù)(Nginx1.19.13+),我們可以直接拿來(lái)使用這個(gè)動(dòng)態(tài)庫(kù),如果你想將這個(gè)利用Nginx 提供的編譯參數(shù) --add-module=/path/to/module 構(gòu)建為nginx的內(nèi)置功能的話,可能會(huì)出現(xiàn)一些問(wèn)題,例如下面的一些錯(cuò)誤:

ngx_http_opentracing_module.so/config was found
	/root/nginx-opentracing-0.25.0/opentracing//src/ngx_http_opentracing_module.cpp
In file included from /root/nginx-opentracing-0.25.0/opentracing//src/ngx_http_opentracing_module.cpp:1:0:
/root/nginx-opentracing-0.25.0/opentracing//src/load_tracer.h:3:38: fatal error: opentracing/dynamic_load.h: No such file or directory

根據(jù) issue 中查詢得知 nginx-opentracing 需要嵌入到nginx中,是需要一些 opentracing-cpp 因?yàn)閷?duì)c++不熟,嘗試調(diào)試很久還是上面的錯(cuò)誤,故直接使用了官方提供的動(dòng)態(tài)庫(kù)。

準(zhǔn)備jaeger-client-cpp

根據(jù) nginx-opentracing 中提到的,還需要一個(gè) jaeger-client-cpptracer 才可以正常運(yùn)行(這也是作為jaeger架構(gòu)中的角色)

來(lái)到 jaeger-client-cpp 看到Release提供的編譯好的動(dòng)態(tài)庫(kù)已經(jīng)很久了,而最新版都沒(méi)有提供相應(yīng)編譯的版本,需要我們自己編譯

說(shuō)明: 編譯依賴CMake 3.3+,gcc 4.9.2+

我們的編譯環(huán)境使用CentOS 7 默認(rèn)gcc與CMake都符合要求需要自行編譯兩個(gè)的版本。

編譯gcc

gcc下載地址:https://ftp.gnu.org/gnu/gcc/

cd gcc-5.4.0
./contrib/download_prerequisites

mkdir gcc-build-5.4.0
cd gcc-build-5.4.0

/usr/local/src/gcc-5.4.0/configure \
	--enable-checking=release \
	--enable-languages=c,c++ \
	--disable-multilib
	
make && make install

引用處理 refer 1

cd /usr/bin/
mv gcc gcc_back
mv g++ g++_back
ln -s /usr/local/bin/gcc gcc
ln -s /usr/local/bin/g++ g++

編譯時(shí)遇到幾個(gè)問(wèn)題

/lib64/libstdc++.so.6: version GLIBCXX_3.4.20' not found

gcc 編譯,libgcc動(dòng)態(tài)庫(kù)有改動(dòng),恢復(fù)原狀即可

configure: error: C++ compiler missing or inoperational

make[2]: \*** [configure-stage1-libcpp] Error 1    
make[2]: Leaving directory `/home/clay/programming/C++/gcc-4.8.1'    
make[1]: \*** [stage1-bubble] Error 2    
make[1]: Leaving directory `/home/clay/programming/C++/gcc-4.8.1'    
make: \*** [all] Error 2

編譯cmake

./configure --prefix=/path/to/app

make
make install

這里遇到一個(gè)小問(wèn)題 編譯過(guò)程中遇到 [libstdc++.so.6: version GLIBCXX_3.4.20 not found

因?yàn)檫@里使用了自己編譯的gcc版本,需要指定下動(dòng)態(tài)庫(kù)的路徑 refer 2

LD_LIBRARY_PATH=/usr/local/lib64 ./configure --prefix=/usr/local/cmake

編譯jaeger-client-cpp

這里根據(jù)官方提供的步驟操作即可

cd jaeger-client-cpp-0.9.0/
mkdir build
cd build
# 這里建議使用下強(qiáng)國(guó)特色上網(wǎng),編譯過(guò)程中會(huì)使用Hunter自動(dòng)下載所需的依賴項(xiàng)
ALL_PROXY=http://x.0.0.x:10811 /usr/local/cmake/bin/cmake .. 
make

注:依賴項(xiàng)挺大的,下載時(shí)間可能很長(zhǎng),會(huì)hang主,只需等待結(jié)束即可

?編譯完成后 libjaegertracing.so.0.9.0 則是我們需要的

編譯nginx

./configure \
	--user=web_www \
	--group=web_www \
	--with-pcre \
	--with-compat \
	--with-http_ssl_module  \
	--with-http_gzip_static_module \
	--prefix=/root/nginx  \
	--with-http_stub_status_module

--with-compat 必須加上,表面允許使用動(dòng)態(tài)庫(kù),否則編譯完在啟動(dòng)時(shí)會(huì)報(bào)下面的錯(cuò)誤

nginx: [emerg] module "/root/nginx/conf/ngx_http_opentracing_module.so" is not binary compatible in /root/nginx/conf/nginx.conf:1

遇到的問(wèn)題,cc nou found,這里只需將 gcc 軟連接一份為 cc 即可

配置nginx

準(zhǔn)備jaeger-client的配置

jaeger.json

{
  "service_name": "nginx", // 服務(wù)名
  "sampler": {
    "type": "const",
    "param": 1
  },
  "reporter": {
    "localAgentHostPort": "jaeger:6831" // jaeger agent的地址
  },
  "headers": { // jaeger的默認(rèn)的jaeger Baggage頭設(shè)置
    "jaegerDebugHeader": "jaeger-debug-id",
    "jaegerBaggageHeader": "jaeger-baggage",
    "traceBaggageHeaderPrefix": "uberctx-"
  },
  "baggage_restrictions": {
    "denyBaggageOnInitializationFailure": false,
    "hostPort": ""
  }
}

在nginx中開(kāi)啟opentracing

# 加載 OpenTracing 動(dòng)態(tài)模塊。
load_module conf/ngx_http_opentracing_module.so;
worker_processes  1;
user root root;

events {
    worker_connections  1024;
}
http {
    log_format opentracing '{"timestamp":"$time_iso8601",'
                       '"source":"$server_addr",'
                       '"hostname":"$hostname",'
                       '"ip":"$http_x_forwarded_for",'
                       '"traceID":"$opentracing_context_uber_trace_id",'
                       '"client":"$remote_addr",'
                       '"request_method":"$request_method",'
                       '"scheme":"$scheme",'
                       '"domain":"$server_name",'
                       '"referer":"$http_referer",'
                       '"request":"$request_uri",'
                       '"args":"$args",'
                       '"size":$body_bytes_sent,'
                       '"status": $status,'
                       '"responsetime":$request_time,'
                       '"upstreamtime":"$upstream_response_time",'
                       '"upstreamaddr":"$upstream_addr",'
                       '"http_user_agent":"$http_user_agent",'
                       '"https":"$https"'
                       '}';
	# 加載 tracer,這里使用的jaeger,需要傳遞配置文件
    opentracing_load_tracer conf/libjaegertracing.so conf/jaeger.json;
    # 啟用 tracing 
    opentracing on; 
    # 設(shè)置tag,可選參數(shù)
    opentracing_tag http_user_agent $http_user_agent;
    include       mime.types;
    default_type  application/octet-stream;
    sendfile        on;
    keepalive_timeout  65;
    server {
        listen       80;
        server_name  localhost;
        location / {
            opentracing_operation_name $uri;
	    opentracing_propagate_context;
            root   html;
            index  index.html index.htm;
        }
	access_log logs/access.log opentracing;
        error_page   500 502 503 504  /50x.html;
        location = /50x.html {
            root   html;
        }
    }
}

注:這里使用的 opentracing-nginx 的動(dòng)態(tài)庫(kù)為 ot16 ,linux-amd64-nginx-1.22.0-ot16-ngx_http_module.so.tgz ,另外一個(gè)版本不兼容,-t 檢查語(yǔ)法時(shí)會(huì)提示

此時(shí)我們可以在jaeger上查看,可以看到 NGINX 的 span(因?yàn)檫@里只配置了NGINX,沒(méi)有配置更多的后端)。

Reference

1 CentOS7 升級(jí) GCC 到 5.4.0 版本

2 libstdc++.so.6: version GLIBCXX_3.4.20 not found

3 nginx load_module

總結(jié)

到此這篇關(guān)于如何讓你的Nginx支持分布式追蹤的文章就介紹到這了,更多相關(guān)Nginx支持分布式追蹤內(nèi)容請(qǐng)搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持腳本之家!

相關(guān)文章

  • Nginx為T(mén)omcat服務(wù)器作反向代理的配置教程

    Nginx為T(mén)omcat服務(wù)器作反向代理的配置教程

    這篇文章主要介紹了Nginx為T(mén)omcat服務(wù)器作反向代理的配置教程,文中以Windows系統(tǒng)為環(huán)境來(lái)演示驅(qū)動(dòng)JSP程序的示例,需要的朋友可以參考下
    2016-03-03
  • 解決國(guó)內(nèi)k8s的ingress-nginx鏡像無(wú)法正常pull拉取問(wèn)題

    解決國(guó)內(nèi)k8s的ingress-nginx鏡像無(wú)法正常pull拉取問(wèn)題

    本文主要介紹了解決國(guó)內(nèi)k8s的ingress-nginx鏡像無(wú)法正常pull拉取問(wèn)題,文中通過(guò)示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面隨著小編來(lái)一起學(xué)習(xí)學(xué)習(xí)吧
    2022-03-03
  • nginx中域名、目錄的301重定向配置示例

    nginx中域名、目錄的301重定向配置示例

    這篇文章主要介紹了nginx中域名、目錄的301重定向配置示例,分為域名和域名間的跳轉(zhuǎn),目錄跳轉(zhuǎn)等,需要的朋友可以參考下
    2014-07-07
  • Nginx對(duì)某個(gè)目錄設(shè)置密碼保護(hù)例子

    Nginx對(duì)某個(gè)目錄設(shè)置密碼保護(hù)例子

    這篇文章主要介紹了Nginx對(duì)某個(gè)目錄設(shè)置密碼保護(hù)例子,使用htpasswd 生成用戶名和密碼,并解決了打開(kāi)PHP文件變成文件下載的問(wèn)題,需要的朋友可以參考下
    2014-06-06
  • 解決Nginx端口沖突的排查方法示例

    解決Nginx端口沖突的排查方法示例

    這篇文章主要介紹了解決Nginx端口沖突的排查方法示例,文中通過(guò)示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面隨著小編來(lái)一起學(xué)習(xí)學(xué)習(xí)吧
    2020-07-07
  • Nginx如何配置根據(jù)路徑轉(zhuǎn)發(fā)詳解

    Nginx如何配置根據(jù)路徑轉(zhuǎn)發(fā)詳解

    Nginx是作為一個(gè)反向代理,轉(zhuǎn)發(fā),和負(fù)載均衡的服務(wù)器,也可以用于分布式,下面這篇文章主要給大家介紹了關(guān)于Nginx如何配置根據(jù)路徑轉(zhuǎn)發(fā)的相關(guān)資料,文中通過(guò)實(shí)例代碼介紹的非常詳細(xì),需要的朋友可以參考下
    2022-07-07
  • 負(fù)載均衡的基本知識(shí)以及使用nginx進(jìn)行負(fù)載均衡的簡(jiǎn)單例子

    負(fù)載均衡的基本知識(shí)以及使用nginx進(jìn)行負(fù)載均衡的簡(jiǎn)單例子

    今天小編就為大家分享一篇關(guān)于負(fù)載均衡的基本知識(shí)以及使用nginx進(jìn)行負(fù)載均衡的簡(jiǎn)單例子,小編覺(jué)得內(nèi)容挺不錯(cuò)的,現(xiàn)在分享給大家,具有很好的參考價(jià)值,需要的朋友一起跟隨小編來(lái)看看吧
    2018-12-12
  • nginx 502、413和404錯(cuò)誤原因排查和解決辦法總結(jié)

    nginx 502、413和404錯(cuò)誤原因排查和解決辦法總結(jié)

    這篇文章主要給大家介紹了NGINX 502錯(cuò)誤排查,辦法總結(jié),Nginx 413錯(cuò)誤的排查以及Nginx 400錯(cuò)誤排查,文中通過(guò)代碼示例給出了詳細(xì)的排查方法和解決方案,需要的朋友可以參考下
    2023-12-12
  • nginx實(shí)現(xiàn)tomcat動(dòng)靜分離詳解

    nginx實(shí)現(xiàn)tomcat動(dòng)靜分離詳解

    本篇文章主要介紹了nginx實(shí)現(xiàn)tomcat動(dòng)靜分離詳解,小編覺(jué)得挺不錯(cuò)的,現(xiàn)在分享給大家,也給大家做個(gè)參考。一起跟隨小編過(guò)來(lái)看看吧
    2017-06-06
  • Nginx之Http模塊系列之a(chǎn)utoindex模塊的具體使用

    Nginx之Http模塊系列之a(chǎn)utoindex模塊的具體使用

    這篇文章主要介紹了Nginx之Http模塊系列之a(chǎn)utoindex模塊的具體使用,文中通過(guò)示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面隨著小編來(lái)一起學(xué)習(xí)學(xué)習(xí)吧
    2021-03-03

最新評(píng)論