您当前的位置:首页 > 电脑百科 > 站长技术 > 服务器

nginx中加入opentracing能力

时间:2022-04-15 14:27:48  来源:  作者:SRE实战
nginx中加入opentracing能力

 

Why Nginx tracing

Nginx是一个广泛使用的web原件,常用于反向代理、负载均衡服务器、API网关。在日常的使用中,nginx常常要负责各种redirect、rewrite等服务,对于业务或者调用关系负责的情况,tracing能够帮助开发者直观分析请求链路,快速定位性能瓶颈,逐渐优化服务间依赖,也有助于开发者从更宏观的角度更好地理解整个系统。

同时,如果开发者能够在代码内部也加入对tracing的支持,那么对于自己开发的服务整体从将可以以上帝视角直观地看到。

环境要求

nginx stable 1.2+

ngonx-opentracing module

jaeger环境

配置详情

1. nginx.conf

load_module modules/ngx_http_opentracing_module.so;
user  nobody nobody;
worker_processes  auto;
working_directory /search/odin/nginx/core;
worker_rlimit_core 2G;

error_log  logs/error.log error;

pid        /var/run/nginx.pid;


events {
    use epoll;
    worker_connections  51200;
}


http {
    include       /etc/nginx/mime.types;
    default_type  Application/octet-stream;

    opentracing_load_tracer /usr/local/lib/libjaegertracing_plugin.linux_amd64.so /etc/nginx/conf.d/jaeger-config.json;
    opentracing on;
    opentracing_propagate_context;
    opentracing_operation_name nginx-$host;
    opentracing_tag request.id $request_id;

    index index.html index.htm index.shtml;

    set_real_ip_from   10.0.0.0/8;
    set_real_ip_from   192.168.0.0/16;
    real_ip_header     X-Real-IP;

    log_format mAIn '$host $remote_addr [$time_local] "$request" '
                        '$status $body_bytes_sent "$http_referer" "$http_user_agent" '
                        '$cookie_SUID $request_time $cookie_SSUID '
                        '$http_x_forwarded_for $request_length $cookie_YYID '
                        '$connection_requests "$upstream_addr" $request_id';
    log_format mini '$time_local $status $body_bytes_sent $request_time $upstream_cache_status $server_name';
    access_log "logs/${server_name}_access_log" main;
    access_log logs/status_log mini;


    sendfile        on;
    #tcp_nopush     on;

    keepalive_timeout  65;

    gzip  on;
    gzip_min_length  1024;
    gzip_comp_level  6;
    gzip_types       text/plain text/xml application/x-JAVAscript text/css application/xml;


    include /etc/nginx/conf.d/*.conf;
}

首先,加载nginx 模块:
ngx_http_opentracing_module.so

load_module modules/ngx_http_opentracing_module.so;

其次,加载并配置jaeger plugin

opentracing_load_tracer /usr/local/lib/libjaegertracing_plugin.linux_amd64.so /etc/nginx/conf.d/jaeger-config.json;
opentracing on; # 启用opentracing,默认为off
opentracing_propagate_context; # 启用传递context
opentracing_operation_name nginx-$host; # 为请求起个name
opentracing_tag request.id $request_id; # 设置span tag request.id,需要nginx 1.11以上

其中专门设置了一个request.id的tag,这个request.id串起来从nginx到code的所有请求,方便检索请求

最后,附加一个jaeger的配置,localAgentHostPort需要配置成jaeger-agent所在host:port

{
  "service_name": "nginx",
  "diabled": false,
  "reporter": {
    "logSpans": true,
    "localAgentHostPort": "jaeger:6831"
  },
  "sampler": {
    "type": "const",
    "param": "1"
  }
}

2. server.conf

upstream api{
    server 127.0.0.1:8080;
}

server
{
    listen *:80 default_server;
    server_name xx.test;

    opentracing_location_operation_name $request;
    opentracing_propagate_context;
    proxy_set_header X-Request-Id $request_id;

    proxy_set_header  Host $host;
    proxy_http_version 1.1;

    location ~ ^/api/ {
      proxy_pass http://api;
    }
}

以下三条配置分别设置了location name、启用传递context、设置header X-Request-Id为 $request_id

opentracing_location_operation_name $request;
opentracing_propagate_context;
proxy_set_header X-Request-Id $request_id;
nginx中加入opentracing能力

 

 

3. 代码接入opentracing

import (
.....
opentracing "Github.com/opentracing/opentracing-go"
"github.com/opentracing/opentracing-go/ext"
)

func (c *AlertManagerController) Webhook() {
	spanCtx, _ := opentracing.GlobalTracer().Extract(opentracing.HTTPHeaders, opentracing.HTTPHeadersCarrier(c.Ctx.Request.Header))
	span := opentracing.GlobalTracer().StartSpan("Webhook", ext.RPCServerOption(spanCtx)) // 关联为nginx的child
	uuid := c.Ctx.Input.Header("X-Request-Id")
	span.SetTag("request.id", uuid) // 设置request tag
	span.SetBaggageItem("request.id", uuid) // 向后续请求加入request.id
	span.LogKV("request.body", string(c.Ctx.Input.RequestBody))
        ......
}
nginx中加入opentracing能力

 

nginx中加入opentracing能力

 

为什么要用nginx 1.2以上?

nginx opentracing require nginx 1.9.13+

request_id require nginx 1.11.0

nginx 偶数版本是stable

附模块下载地址

ngx_http_opentracing_module.so https://github.com/opentracing-contrib/nginx-opentracing/releases

jaeger plugin https://github.com/jaegertracing/jaeger-client-cpp/releases

参考

https://github.com/opentracing-contrib/nginx-opentracing

https://medium.com/opentracing/how-to-enable-nginx-for-distributed-tracing-9479df18b22c

https://github.com/opentracing-contrib/nginx-opentracing/tree/master/example/trivial/jaeger



Tags:nginx   点击:()  评论:()
声明:本站部分内容及图片来自互联网,转载是出于传递更多信息之目的,内容观点仅代表作者本人,不构成投资建议。投资者据此操作,风险自担。如有任何标注错误或版权侵犯请与我们联系,我们将及时更正、删除。
▌相关推荐
为什么Nginx被称为“反向”代理呢?
Nginx(发音为"engine-x")是一款高性能、轻量级的开源Web服务器软件,也可用作反向代理服务器、负载均衡器和HTTP缓存。Nginx之所以有被称为“反向”代理,是因为它充当客户端设备...【详细内容】
2024-02-01  Search: nginx  点击:(61)  评论:(0)  加入收藏
如何在Java环境中安装Nginx?
1. 下载Nginx:首先,前往Nginx官方网站(https://nginx.org/en/download.html)下载新版本的Nginx。选择适合您操作系统的版本,通常有Windows、Linux和Mac等不同操作系统的版本可供...【详细内容】
2024-01-22  Search: nginx  点击:(71)  评论:(0)  加入收藏
一文教你学会使用Nginx
前段时间,了不起给大家说过如果使用 Docker 发布自己的后端项目,也就不再使用 Jar 包进行项目的发版操作,但是这其中就又涉及到了前端如何发版,为什么这么说,因为资深前端开发,可...【详细内容】
2023-12-27  Search: nginx  点击:(92)  评论:(0)  加入收藏
Nginx 反向代理为什么叫做“反向”?
今天我们来聊聊正向代理和反向代理。01 正向代理(Forward Proxy)正向代理是位于用户设备和互联网之间的服务器。它代理的是客户端,是站在用户一方的。其真实客户端对于服务器不...【详细内容】
2023-12-06  Search: nginx  点击:(93)  评论:(0)  加入收藏
Nginx的负载均衡实现,你学会了吗?
环境 主机 ip 用途 软件 web1 192.168.50.60 nginx-1 httpd web2 192.168.50.61 nginx-2 httpd proxy 192.168.50.62 负载...【详细内容】
2023-12-06  Search: nginx  点击:(146)  评论:(0)  加入收藏
Nginx如何开启GZIP文件压缩,你学会了吗?
简介GZip 是一种改进web应用程序性能的技术,文件压缩后再传输可以减少传输数据,提升传输速度。在Nginx服务器上开启Gzip压缩可以有效减少网络传输流量,提升网站的访问速度和性...【详细内容】
2023-11-30  Search: nginx  点击:(123)  评论:(0)  加入收藏
Nginx配置文件中的关键字是什么?
Nginx 是一款高性能的 Web 服务器软件,同时也是一款反向代理服务器软件。Nginx 的配置文件通常是 /etc/nginx/nginx.conf,以下是一个典型的配置文件,并对其中的关键字进行详细...【详细内容】
2023-11-22  Search: nginx  点击:(148)  评论:(0)  加入收藏
Nginx 大揭秘:读写分离助力您轻松征服高并发
引言在构建高性能、高可用的 Web 应用时,如何有效地处理数据库的读写负担已成为一个十分重要的考虑因素。Nginx 作为一款强大的反向代理服务器,提供了简单而灵活的负载均衡配...【详细内容】
2023-11-14  Search: nginx  点击:(55)  评论:(0)  加入收藏
Kubernetes 部署应用(Nginx)的两种方式,你更喜欢哪一种?
k8s发布应用的两种方式: kubernetes-dashboard kubectl命令行一、Dashboard方式配置部署:包含应用名称、容器镒、pod数量、Service非常的方便,不想设置配置yaml的可以很方便的...【详细内容】
2023-11-06  Search: nginx  点击:(372)  评论:(0)  加入收藏
掌握Nginx的高级用法,构建高性能Web应用
Nginx是一款高性能的Web服务器和反向代理服务器,它广泛用于构建高性能、可靠和安全的Web应用程序。除了基本的用法外,Nginx还提供了一些高级功能和配置选项,可以进一步优化性能...【详细内容】
2023-10-26  Search: nginx  点击:(220)  评论:(0)  加入收藏
▌简易百科推荐
为什么Nginx被称为“反向”代理呢?
Nginx(发音为"engine-x")是一款高性能、轻量级的开源Web服务器软件,也可用作反向代理服务器、负载均衡器和HTTP缓存。Nginx之所以有被称为“反向”代理,是因为它充当客户端设备...【详细内容】
2024-02-01  coderidea  微信公众号  Tags:Nginx   点击:(61)  评论:(0)  加入收藏
哪种服务器操作系统更好呢?
在当今的IT世界中,服务器操作系统扮演着至关重要的角色。它们是确保服务器能够高效、安全地运行的关键因素。然而,对于许多人来说,服务器操作系统的种类和特点可能是一个复杂的...【详细内容】
2024-01-30    简易百科  Tags:操作系统   点击:(80)  评论:(0)  加入收藏
什么是VPS服务器
VPS服务器是一种虚拟化技术,它将一台物理服务器划分为多个虚拟的独立服务器,每个虚拟服务器都可以拥有自己的操作系统、运行环境、应用程序等。这种技术使得每个虚拟服务器可...【详细内容】
2024-01-30    简易百科  Tags:VPS服务器   点击:(75)  评论:(0)  加入收藏
VPS服务器下载速度慢?这五招帮你提速
VPS服务器下载速度慢可能会让用户感到沮丧,尤其是对于需要大量下载和上传数据的用户。幸运的是,有一些方法可以帮助您提高VPS服务器的下载速度,使您的在线体验更加顺畅。在本文...【详细内容】
2024-01-30  IDC行业观察者    Tags:VPS服务器   点击:(60)  评论:(0)  加入收藏
美国VPS和英国VPS:地理位置对服务器性能的影响
在今天的数字时代,VPS已成为在线业务和网站托管的关键组成部分。然而,选择合适的VPS主机服务时,地理位置通常被忽视,尽管它对服务器性能有着重要的影响。本文将探讨美国VPS和英...【详细内容】
2024-01-26  IDC行业观察者    Tags:服务器   点击:(56)  评论:(0)  加入收藏
如何判断服务器所需带宽:基于业务需求和流量模式的关键考量
在选择服务器时,带宽是一个重要的考虑因素。带宽的大小直接影响到网站的加载速度和用户的访问体验。那么,如何判断服务器需要多大的带宽呢?本文将为你揭示这一关键问题的答案...【详细内容】
2024-01-26  源库科技    Tags:服务器   点击:(80)  评论:(0)  加入收藏
服务器内存空间及IO操作原理解析
服务器的内存空间分为内核空间和用户空间,而我们编写的程序通常在用户空间中运行。在进行读写操作时,我们直接操作的是用户缓冲区,而用户缓冲区的内容来自于内核缓冲区。这种内...【详细内容】
2024-01-23  王建立    Tags:服务器   点击:(46)  评论:(0)  加入收藏
如何在Java环境中安装Nginx?
1. 下载Nginx:首先,前往Nginx官方网站(https://nginx.org/en/download.html)下载新版本的Nginx。选择适合您操作系统的版本,通常有Windows、Linux和Mac等不同操作系统的版本可供...【详细内容】
2024-01-22  敲代码的小动    Tags:Nginx   点击:(71)  评论:(0)  加入收藏
服务器证书和SSL证书有啥区别?
在互联网经济时代,随着越来越多的信息以及合作都是从企业官网开始的,因此绝大多数企业都会为自己的网站配置SSL证书,以提高安全性。在接触SSL证书时,也有很多人称之为服务器证书...【详细内容】
2024-01-10  安信SSL证书    Tags:服务器证书   点击:(66)  评论:(0)  加入收藏
宝塔面板怎样部署java项目?
宝塔面板怎样部署java项目?在使用宝塔面板部署Java项目之前,需要确保已经安装了Java Development Kit (JDK)。接下来,将介绍如何使用宝塔面板来部署Java项目的步骤。步骤一:安装...【详细内容】
2024-01-09  西部数码    Tags:宝塔面板   点击:(123)  评论:(0)  加入收藏
站内最新
站内热门
站内头条