Thanos 是一款为 Prometheus 设计的开源监控解决方案它允许用户像操作单个 Prometheus 实例一样无缝地查询分布在多个集群、区域甚至云服务商中的所有监控数据能够解决 Prometheus 在大规模、多数据中心或云原生环境下运行时面临的挑战特别是长期存储、高可用性和全局查询视图。本文将详细介绍如何利用 Docker 在局域网内部署 Thanos 并结合路由侠实现外网访问局域网内部署的 Thanos 。第一步本地部署安装 Thanos1本教程操作环境为 Linux Ubuntu 系统Thanos 依赖 Docker 运行我们需要先确保你的系统上已经安装了 Docker 。如果尚未安装可以参考文档进行安装点此查看。2安装 Docker Compose 。sudo curl -L https://github.com/docker/compose/releases/download/$(curl -s https://api.github.com/repos/docker/compose/releases/latest | grep -Po tag_name: \K.*\d) /usr/local/bin/docker-compose3创建并进入项目目录。mkdir ~/thanos-test cd ~/thanos-test mkdir -p data/{minio,prometheus}4创建 minio-compose.yml 文件用于存储长期数据。sudo vim minio-compose.yml写入以下内容version: 3.8 services: minio: image: minio/minio:latest container_name: minio command: server /data --console-address :9001 environment: - MINIO_ROOT_USERminioadmin - MINIO_ROOT_PASSWORDminioadmin volumes: - ./data/minio:/data ports: - 9000:9000 - 9001:9001 restart: unless-stopped5启动 MinIO 容器。docker-compose -f minio-compose.yml up -d6打开浏览器访问地址 http://你的服务器 IP:9001 使用 minioadmin/minioadmin 登录创建一个名为 thanos 的存储桶。7下载 Thanos 二进制文件。wget https://github.com/thanos-io/thanos/releases/download/v0.34.0/thanos-0.34.0.linux-amd64.tar.gz tar -xzf thanos-0.34.0.linux-amd64.tar.gz sudo mv thanos-0.34.0.linux-amd64/thanos /usr/local/bin/thanos chmod x /usr/local/bin/thanos8下载安装 Prometheus 二进制文件并移动二进制文件到系统路径。wget https://github.com/prometheus/prometheus/releases/download/v2.50.0/prometheus-2.50.0.linux-amd64.tar.gz tar -xzf prometheus-2.50.0.linux-amd64.tar.gzsudo mv prometheus-2.50.0.linux-amd64/prometheus /usr/local/bin/prometheus sudo chmod x /usr/local/bin/prometheus9创建 prometheus.yml 文件配置 Prometheus 。sudo vim prometheus.yml写入以下内容global: scrape_interval: 15s external_labels: monitor: thanos-test replica: replica-01 scrape_configs: - job_name: prometheus static_configs: - targets: [localhost:9090] - job_name: node-exporter static_configs: - targets: [localhost:9100]10创建 thanos-storage.yml 文件。sudo vim thanos-storage.yml写入以下内容type: S3 config: bucket: thanos endpoint: localhost:9000 access_key: minioadmin secret_key: minioadmin insecure: true11启动 Prometheus 项目。nohup /usr/local/bin/prometheus \ --config.fileprometheus.yml \ --storage.tsdb.path./data/prometheus \ --web.listen-address127.0.0.1:9090 \ --storage.tsdb.min-block-duration2h \ --storage.tsdb.max-block-duration2h prometheus.log 12启动 Thanos Sidecar 项目。nohup /usr/local/bin/thanos sidecar \ --prometheus.urlhttp://127.0.0.1:9090 \ --grpc-address0.0.0.0:10901 \ --http-address0.0.0.0:10902 \ --objstore.config-filethanos-storage.yml sidecar.log 13启动 Thanos Query 项目。nohup /usr/local/bin/thanos query \ --http-address0.0.0.0:10903 \ --grpc-address0.0.0.0:10904 \ --query.replica-labelreplica \ --store127.0.0.1:10901 \ query.log 14打开浏览器访问地址 http://你的服务器 IP:10903 就能看到你部署的 Thanos Query 数据界面了。第二步外网访问本地 Thanos安装路由侠内网穿透。1当前未提供网页管理需要先在任意一台 Windows 机器安装路由侠 Windows 版本用作跨机器管理。点此下载2在路由侠客户端主界面进入“ 设备管理 ”点击右下角的“ 添加设备 ”此时可查看到对应的安装码此安装码用于将设备添加到对应账号下可选中后复制。3直接下载后导入wget https://dl.luyouxia.com:8443/v2/lyx-docker-x86_64.tar docker load -i lyx-docker-x86_64.tar4然后使用该镜像启动容器。docker run --name lyx -it --restartalways --nethost -e code这里填写安装码luyouxia/lyx5此时需要等待下载和安装的过程如果一切正常最终可以看到一些输出并且可以看到如下提示[Device] Logged in. Token: ....这就表示安装成功了。当前 Linux 终端这边如果是使用的上面的命令Docker 是运行在前台此时可以按住 Ctrl C 退出路由侠容器也将退出。现在可以使用以下命令将其放入后台持续运行docker start lyx注意如果容器删除重新 docker run 将创建为新的设备。需要注意的是因为容器参数已经添加了 --restartalways 这样开机就会自动启动不需要再手动启动路由侠了。6现在回到 Windows 这边设备列表点击右上角的 × 返回主界面再次进入就可以找到这个设备可以修改名称。7回到主界面点击【内网映射】。8注意右上角的设备名称下拉框这里选中刚刚添加的设备名称此时在这个界面上添加的映射就属于刚刚这个设备。添加或修改一般需要等待 30 秒容器中的路由侠进程就会更新并加载。切换好设备后点击【添加映射】。9选择【原生端口】。10在内网地址填写你的服务器 IP 和 Thanos 端口 10903 后点击【创建】按钮如下图。11创建好后就可以看到一条映射的公网地址鼠标右键点击【复制地址】。12在外网电脑上打开浏览器在地址栏输入从路由侠生成的外网地址就可以看到内网部署的 Thanos 数据界面了。