Nir*_*man 5 mysql grafana dockerfile docker-compose
我希望设置 2 个 docker 容器:grafana 和 mysql,并允许从 grafana 查询到 mysql 数据库。我有一台AWS机器,我在其中构建了以下文件夹结构:
- docker
- docker-compose.yml
- grafana:
- config.ini
- dashboards:
- grafana_dashboard.json
- provisioning:
- dashboards:
- all.yml
- datasources:
- all.yml
- Dockerfile
- mysql:
- dbcreation.sql
- Dockerfile
- dashboards:
- import.sh
Run Code Online (Sandbox Code Playgroud)
docker-compose.yml 的内容是:
version: '2'
services:
db-service:
build: './mysql'
container_name: mysql
restart: always
ports:
- "3306:3306"
networks:
net:
ipv4_address: 172.16.1.3
grafana-service:
build: './grafana'
container_name: grafana
restart: always
ports:
- "3000:3000"
environment:
GF_SECURITY_ADMIN_PASSWORD: "XXX1"
GF_AUTH_PROXY_ENABLED: "true"
GF_SECURITY_DATA_SOURCE_PROXY_WHITELIST: 172.16.1.3:3306
GF_AUTH_ANONYMOUS_ENABLED: "true"
GF_LOG_LEVEL: "debug"
depends_on:
- db-service
networks:
net:
ipv4_address: 172.16.1.4
networks:
net:
external: true
volumes:
grafanadata:
driver: local
mysqldata:
Run Code Online (Sandbox Code Playgroud)
grafana 的 dockerfile:
FROM grafana/grafana:5.2.2
ADD ./provisioning /etc/grafana/provisioning
ADD ./dashboards /var/lib/grafana/dashboards
ENV DS_DB "grafana"
Run Code Online (Sandbox Code Playgroud)
mysql/Dockerfile 的内容是:
FROM mysql:8.0.12
ENV MYSQL_ROOT_PASSWORD="XXX2"
ENV MYSQL_DATABASE="grafana"
ADD ./dbcreation.sql /docker-entrypoint-initdb.d/dbcreation.sql
EXPOSE 3306
Run Code Online (Sandbox Code Playgroud)
grafana_dashboard.json 文件包含从我在自己的计算机上本地设置的 Grafana 导出的 json。dbcreation.sql 文件包含从我在自己的计算机上本地设置的本地数据库导出的数据。
我正在运行以下命令:
docker network create --gateway 172.16.1.1 --subnet 172.16.1.0/24 net
docker-compose up --build
Run Code Online (Sandbox Code Playgroud)
当将 Grafana 的日志级别设置为调试时,我看到了以下内容:
t=2018-08-19T10:55:20+0000 lvl=dbug msg=getEngine logger=tsdb.mysql connection="root:XXX2@tcp(172.16.1.3:3306)/grafana?collation=utf8mb4_unicode_ci&parseTime=true&loc=UTC&allowNativePasswords=true"
t=2018-08-19T10:55:47+0000 lvl=eror msg="Request Completed" logger=context userId=1 orgId=1 uname=admin method=POST path=/api/tsdb/query status=500 remote_addr=XX.XXX.XXX.XXX time_ms=2 size=195 referer=http://XX.XXX.XXX.XXX:3000/datasources/edit/1
Run Code Online (Sandbox Code Playgroud)
我已经使用以下来源来进行设置: https ://ops.tips/blog/initialize-grafana-with-preconfigured-dashboards/
https://storage.pardot.com/138181/61672/mysql_on_docker_how_to_containerize_your_database.pdf
任何帮助,将不胜感激!谢谢
正如这里所述:
问题是 Grafana 版本和 MySQL 版本之间的兼容性。一旦移动到 docker image mysql:5.7 (也必须迁移数据) - 问题就解决了(还需要更改数据库中的 COLLATION 和 CHAR_SET 以从版本 8.0.12 降级到 5.7)。
| 归档时间: |
|
| 查看次数: |
3647 次 |
| 最近记录: |