Docker 如何让普罗米修斯在《码头工人》中与格拉法纳合作?

Docker 如何让普罗米修斯在《码头工人》中与格拉法纳合作?,docker,grafana,prometheus,Docker,Grafana,Prometheus,主要目标是将普罗米修斯链接为grafana的后端,但输入http://localhost:9090作为grafana中的url返回HTTP错误错误网关 我启动了一个prometheus docker映像,但它没有监听IPv4上的9090端口 netstat -ntulp Active Internet connections (only servers) Proto Recv-Q Send-Q Local Address Foreign Address St

主要目标是将普罗米修斯链接为grafana的后端,但输入
http://localhost:9090
作为grafana中的url返回
HTTP错误错误网关

我启动了一个prometheus docker映像,但它没有监听IPv4上的9090端口

netstat -ntulp

Active Internet connections (only servers)
Proto Recv-Q Send-Q Local Address           Foreign Address         State       PID/Program name    
tcp        0      0 0.0.0.0:80              0.0.0.0:*               LISTEN      15895/nginx: master 
tcp        0      0 0.0.0.0:22              0.0.0.0:*               LISTEN      3190/sshd           
tcp        0      0 127.0.0.1:5432          0.0.0.0:*               LISTEN      24970/postmaster    
tcp        0      0 127.0.0.1:25            0.0.0.0:*               LISTEN      3148/master         
tcp        0      0 0.0.0.0:443             0.0.0.0:*               LISTEN      15895/nginx: master 
tcp6       0      0 :::9100                 :::*                    LISTEN      16652/node_exporter 
tcp6       0      0 :::80                   :::*                    LISTEN      15895/nginx: master 
tcp6       0      0 :::22                   :::*                    LISTEN      3190/sshd           
tcp6       0      0 :::3000                 :::*                    LISTEN      28436/docker-proxy  
tcp6       0      0 ::1:5432                :::*                    LISTEN      24970/postmaster    
tcp6       0      0 ::1:25                  :::*                    LISTEN      3148/master         
tcp6       0      0 :::9090                 :::*                    LISTEN      31648/docker-proxy  
udp        0      0 0.0.0.0:68              0.0.0.0:*                           2806/dhclient       
udp        0      0 127.0.0.1:323           0.0.0.0:*                           1639/chronyd        
udp6       0      0 ::1:323                 :::*                                1639/chronyd  
这是我的docker命令:

docker run -d -p 9090:9090 --name prometheus -v /etc/prometheus.yml:/etc/prometheus/prometheus.yml -v /mnt/vol-0001/prometheus_data/:/etc/prometheus/data prom/prometheus --log.level=debug
我使用了
-p9090:9090
-p0.0.0:9090
,结果相同

码头工人记录普罗米修斯
返回:

level=info ts=2018-12-19T21:07:59.332452641Z caller=main.go:243 msg="Starting Prometheus" version="(version=2.6.0, branch=HEAD, revision=dbd1d58c894775c0788470944b818cc724f550fb)"
level=info ts=2018-12-19T21:07:59.332554622Z caller=main.go:244 build_context="(go=go1.11.3, user=root@bf5760470f13, date=20181217-15:14:46)"
level=info ts=2018-12-19T21:07:59.332584047Z caller=main.go:245 host_details="(Linux 3.10.0-957.1.3.el7.x86_64 #1 SMP Thu Nov 29 14:49:43 UTC 2018 x86_64 9dd3a9318064 (none))"
level=info ts=2018-12-19T21:07:59.332610547Z caller=main.go:246 fd_limits="(soft=65536, hard=65536)"
level=info ts=2018-12-19T21:07:59.332631287Z caller=main.go:247 vm_limits="(soft=unlimited, hard=unlimited)"
level=info ts=2018-12-19T21:07:59.334232116Z caller=main.go:561 msg="Starting TSDB ..."
level=info ts=2018-12-19T21:07:59.334671887Z caller=repair.go:48 component=tsdb msg="found healthy block" mint=1545204931123 maxt=1545220800000 ulid=01CZ3PHTVQQTW7Q122X7Y15WV4
level=info ts=2018-12-19T21:07:59.334756938Z caller=repair.go:48 component=tsdb msg="found healthy block" mint=1545242400000 maxt=1545249600000 ulid=01CZ44997810VTYP3GV0KJXXN1
level=info ts=2018-12-19T21:07:59.334819198Z caller=repair.go:48 component=tsdb msg="found healthy block" mint=1545220800000 maxt=1545242400000 ulid=01CZ4499ASP4RG8BPR8PE5WAKY
level=info ts=2018-12-19T21:07:59.346244745Z caller=web.go:429 component=web msg="Start listening for connections" address=0.0.0.0:9090
level=info ts=2018-12-19T21:07:59.461554488Z caller=main.go:571 msg="TSDB started"
level=info ts=2018-12-19T21:07:59.461625871Z caller=main.go:631 msg="Loading configuration file" filename=prometheus.yml
level=debug ts=2018-12-19T21:07:59.462558422Z caller=manager.go:213 component="discovery manager scrape" msg="Starting provider" provider=string/0 subs=[prometheus]
level=info ts=2018-12-19T21:07:59.462601563Z caller=main.go:657 msg="Completed loading of configuration file" filename=prometheus.yml
level=info ts=2018-12-19T21:07:59.462615458Z caller=main.go:530 msg="Server is ready to receive web requests."
level=debug ts=2018-12-19T21:07:59.462669264Z caller=manager.go:231 component="discovery manager scrape" msg="discoverer channel closed" provider=string/0
我还尝试禁用防火墙,以确保它不是引起头痛的原因


我不是docker/kubernetes的专家,感谢您的帮助。

您在Grafana数据源输入中引用的
localhost
是Grafana容器本身,因为Grafana内部将
localhost
解析为
127.0.0.1
:可能因为您使用的是GUI,所以您希望查询是通过AJAX/前端调用发出的,但没有,这一切都由后端支持

让使用Docker编制容器,并使用网络连接容器的服务组合:


docker compose up-d
之后,您可以访问端口
:3000处的docker机器IP(或运行docker for Mac的本地主机),然后将Prometheus数据源URL设置为
http://prometheus:9090
它会工作的

您在Grafana数据源输入中引用的
localhost
是Grafana容器本身,因为Grafana内部将
localhost
解析为
127.0.0.1
:可能因为您使用的是GUI,所以您希望查询是通过AJAX/前端调用发出的,但没有,它都是由后端支持的

让使用Docker编制容器,并使用网络连接容器的服务组合:


docker compose up-d
之后,您可以访问端口
:3000处的docker机器IP(或运行docker for Mac的本地主机),然后将Prometheus数据源URL设置为
http://prometheus:9090
它会工作的

谢谢。我希望有办法避免docker compose,因为我还不知道如何缩放它。但至少现在它起作用了:d用作普罗米修斯配置的prometheus.yml文件怎么样?@prometherion很高兴它对你起作用,但对我不起作用。Prometheus在localhost上根本不可用,更不用说尝试在Grafanai中映射数据源了。忽略所有docker compose垃圾,只需在Grafana docker容器(本例中为localhost:3000)上将“访问权限”设置为“浏览器”,似乎就能检测到Prometheus数据源。我尝试使用服务器选项,使用prometheus docker容器的内部IP和docker compose的此方法,但都不起作用。谢谢。我希望有办法避免docker compose,因为我还不知道如何缩放它。但至少现在它起作用了:d用作普罗米修斯配置的prometheus.yml文件怎么样?@prometherion很高兴它对你起作用,但对我不起作用。Prometheus在localhost上根本不可用,更不用说尝试在Grafanai中映射数据源了。忽略所有docker compose垃圾,只需在Grafana docker容器(本例中为localhost:3000)上将“访问权限”设置为“浏览器”,似乎就能检测到Prometheus数据源。我尝试使用服务器选项,使用prometheus docker容器的内部IP和docker compose的这种方法,但都不起作用。
# docker-compose.yaml
version: "3"

services:
  grafana:
    image: grafana/grafana:5.4.1
    ports:
    - 3000:3000
  prometheus:
    image: prom/prometheus:v2.5.0