当前位置: 首页 > wzjs >正文

杂志网站建设培训网

杂志网站建设,培训网,页面设计素材库,杭州好的做网站公司1. 准备工作 导入必要的库 import contextvars import time from typing import Any, Optional, Dict, List, Union from dataclasses import dataclass, field2. 定义上下文变量 # 定义两个上下文变量,存储当前 Span 和 Trace _current_span: contextvars.Conte…

1. 准备工作

导入必要的库

import contextvars
import time
from typing import Any, Optional, Dict, List, Union
from dataclasses import dataclass, field

2. 定义上下文变量

# 定义两个上下文变量,存储当前 Span 和 Trace
_current_span: contextvars.ContextVar[Optional["Span"]] = contextvars.ContextVar("current_span", default=None
)_current_trace: contextvars.ContextVar[Optional["Trace"]] = contextvars.ContextVar("current_trace", default=None
)

3. 数据模型定义

3.1 SpanContext 类

@dataclass
class SpanContext:"""Span 的上下文信息(用于跨进程传递)"""trace_id: strspan_id: stris_remote: bool = False

3.2 Span 类

@dataclass
class Span:"""表示一个操作的时间段追踪"""name: strcontext: SpanContextparent: Optional["Span"] = Nonestart_time: float = field(default_factory=time.time)end_time: Optional[float] = Noneattributes: Dict[str, Any] = field(default_factory=dict)events: List[Dict[str, Any]] = field(default_factory=list)status: str = "UNSET"def end(self, status: str = "OK") -> None:"""结束 Span 并记录状态"""self.end_time = time.time()self.status = statusdef add_event(self, name: str, attributes: Optional[Dict[str, Any]] = None) -> None:"""添加事件到 Span"""self.events.append({"name": name,"timestamp": time.time(),"attributes": attributes or {}})def __enter__(self) -> "Span":"""支持 with 语句"""return selfdef __exit__(self, exc_type, exc_val, exc_tb) -> None:"""自动结束 Span"""self.end("ERROR" if exc_type else "OK")

3.3 Trace 类

@dataclass
class Trace:"""完整的追踪链"""root_span: Spanspans: List[Span] = field(default_factory=list)def add_span(self, span: Span) -> None:"""添加 Span 到 Trace"""self.spans.append(span)

4. 追踪 API 实现

4.1 辅助函数

def generate_id() -> str:"""生成追踪ID(简化版)"""return f"id-{int(time.time() * 1000)}"def get_current_span() -> Optional[Span]:"""获取当前 Span"""return _current_span.get()def get_current_trace() -> Optional[Trace]:"""获取当前 Trace"""return _current_trace.get()

4.2 核心函数

def start_span(name: str, attributes: Optional[Dict[str, Any]] = None) -> Span:"""创建并激活一个新 Span:param name: Span 名称:param attributes: 附加属性:return: 新创建的 Span"""parent = get_current_span()context = SpanContext(trace_id=parent.context.trace_id if parent else generate_id(),span_id=generate_id())span = Span(name=name, context=context, parent=parent)if attributes:span.attributes.update(attributes)# 设置当前 Span_current_span.set(span)# 如果是根 Span,则创建 Traceif parent is None:trace = Trace(root_span=span)_current_trace.set(trace)else:trace = get_current_trace()if trace:trace.add_span(span)return spandef end_span(status: str = "OK") -> None:"""结束当前 Span 并返回父 Span"""current = get_current_span()if current:current.end(status)_current_span.set(current.parent)

5. 数据导出器

class ConsoleExporter:"""将追踪数据打印到控制台"""@staticmethoddef export(trace: Trace) -> None:print("\n=== Exporting Trace ===")print(f"Trace ID: {trace.root_span.context.trace_id}")for span in trace.spans:duration = (span.end_time or time.time()) - span.start_timeprint(f"Span: {span.name} ({duration:.3f}s), Status: {span.status}")

6. 使用示例

6.1 同步代码示例

# 示例 1: 同步代码
with start_span("main_operation", {"type": "sync"}):# 当前 Span 是 "main_operation"with start_span("child_operation"):# 当前 Span 是 "child_operation"get_current_span().add_event("processing_start")time.sleep(0.1)get_current_span().add_event("processing_end")# 手动创建 Spanspan = start_span("manual_span")time.sleep(0.05)span.end()# 导出追踪数据
if trace := get_current_trace():ConsoleExporter.export(trace)

=== Exporting Trace ===
Trace ID: id-1751643441896
Span: main_operation (0.152s), Status: OK
Span: child_operation (0.101s), Status: OK
Span: manual_span (0.050s), Status: OK

6.2 异步代码示例(可选)

import asyncioasync def async_task():with start_span("async_operation"):print(f"Current span: {get_current_span().name}")await asyncio.sleep(0.1)async def main():tasks = [async_task() for _ in range(3)]await asyncio.gather(*tasks)# 运行异步示例
asyncio.run(main())

Current span: async_operation
Current span: async_operation
Current span: async_operation

7. 可视化追踪数据(可选)

import matplotlib.pyplot as pltdef visualize_trace(trace: Trace):fig, ax = plt.subplots(figsize=(10, 6))for i, span in enumerate(trace.spans):duration = (span.end_time or time.time()) - span.start_timeax.barh(span.name, duration, left=span.start_time, alpha=0.6)ax.text(span.start_time, i, f"{duration:.3f}s", va='center')ax.set_xlabel('Time')ax.set_title('Trace Visualization')plt.show()if trace := get_current_trace():visualize_trace(trace)

在这里插入图片描述
代码:https://github.com/zhouruiliangxian/Awesome-demo/blob/main/Distributed-Tracing/%E7%AE%80%E6%98%93%E5%88%86%E5%B8%83%E5%BC%8F%E8%BF%BD%E8%B8%AA%E7%B3%BB%E7%BB%9F.ipynb

http://www.dtcms.com/wzjs/10663.html

相关文章:

  • 企业网站建设公司名称个人博客网页制作
  • 公司有网站域名后如何建网站seo技术培训东莞
  • 有没有转门做乐器演奏的网站百度快照
  • 软件工程师有前途吗郑州技术支持seo
  • 辽宁购物网站制作网络优化网站
  • 具有口碑的柳州网站建设价格如何设计网站的首页
  • 江苏专业网站建设费用南京百度seo排名优化
  • 如何用dw做php网站代码武汉seo首页优化公司
  • 做空eth网站关键词优化排名要多少钱
  • 企业网站推广17爱站网关键词长尾挖掘工具
  • 有什么可以做兼职的正规网站目前常用的搜索引擎有哪些
  • 做教案比较好的网站引擎seo如何优化
  • wordpress博客只显示几个文章优化关键词排名
  • 做网站哪家最便宜产品推广渠道有哪些方式
  • 做加盟代理的网站个人免费开发app
  • 江苏做网站找谁社群运营
  • 药材网技术网站建设百度关键字
  • 深圳营销网站建设公司排名网络营销工资一般多少
  • 杭州企业展厅设计公司seo对网站优化
  • 派遣公司做网站的好处关键词seo报价
  • 制作单页网站教程视频福州百度首页优化
  • 自学做视频网站中国最新军事新闻
  • 芯片设计公司排名优化关键词的方法正确的是
  • 网站广告位投放所有代刷平台推广
  • 学校网站首页设计图片中国推广网
  • 建设银行投诉网站首页网址最全的浏览器
  • 网站后台怎么做飘窗买卖链接网站
  • 东莞网站维护手游推广渠道和推广方式
  • 怎么做电脑端网站设计稿今日广州新闻头条
  • 重庆平台网站建设宽带营销案例100例