APM(三):监控 Python 服务链

上一篇我们通过 Skywalking 监控了一个单体的 Python Flask 服务,并在 Skywalking 的 Web UI 中进行展示。这次我们再写一个服务 BService,调用上次创建的 AService,看看在 Skywalking 中的效果如何。

启动后端服务

先启动好后端服务,包括 Skywalking 和 Easysearch。启动完成后能通过 Web UI 访问 Skywalking。

构建 Python 服务 BService

我们编写一个简单的 BService 服务程序,只要访问 localhost:8082/b 就会调用 AService 并返回相关信息。

复制代码
from flask import Flask
import requests

app = Flask(__name__)

SERVICE_A_URL = 'http://localhost:8081/a'

@app.route('/b', methods=['GET'])
def call_service_a():
    response = requests.get(SERVICE_A_URL)
    if response.status_code == 200:
        return f"Hello, I'am Server B and {response.text} from Service A'
    else:
        return 'Error calling Service A'

if __name__ == '__main__':
    app.run(host='0.0.0.0',port=8082)

运行前,要安装好依赖。

复制代码
pip3 install flask
pip3 install apache-skywalking
pip3 install requests

设置环境变量

为了让服务能成功把相关信息发送到 Skywalking 后端,启动前我们还要设置两个环境变量告诉服务程序该往哪里发送信息。

复制代码
export SW_AGENT_COLLECTOR_BACKEND_SERVICES=localhost:11800
export SW_AGENT_NAME=BService-python

启动 Python 程序

一切准备妥当后,运行我们的服务程序。

复制代码
sw-python run python3 BService.py

程序启动后会监听 8082 端口。

我们通过浏览器访问下 BService,它调用了 AService。

在 Skywalking 的 Web UI 上查看服务的信息是否采集到。

相关推荐
雪可问春风19 小时前
docker环境部署
运维·docker·容器
Csvn19 小时前
🌟 LangChain 30 天保姆级教程 · Day 13|OutputParser 进阶!让 AI 输出自动转为结构化对象,并支持自动重试!
python·langchain
lwx91485219 小时前
Linux-Shell算术运算
linux·运维·服务器
Wenweno0o19 小时前
0基础Go语言Eino框架智能体实战-chatModel
开发语言·后端·golang
翻斗包菜19 小时前
PostgreSQL 日常维护完全指南:从基础操作到高级运维
运维·数据库·postgresql
somi719 小时前
ARM-驱动-02-Linux 内核开发环境搭建与编译
linux·运维·arm开发
chenjingming66619 小时前
jmeter线程组设置以及串行和并行设置
java·开发语言·jmeter
财迅通Ai19 小时前
6000万吨产能承压 卫星化学迎来战略窗口期
大数据·人工智能·物联网·卫星化学
cch891820 小时前
Python主流框架全解析
开发语言·python
不爱吃炸鸡柳20 小时前
C++ STL list 超详细解析:从接口使用到模拟实现
开发语言·c++·list