通过docker部署grafana和mysql
阅读本文需要一定的Linux, Docker与MySQL知识, 例如: 会启动容器, 进入容器; 会创建表, 会使用INSERT语句, 会使用SELECT语句...
- 1. 简介
- 2. 网络设置
- 2.1 docker网络设置
- 2.2 防火墙设置 - 3. MySQL
- 3.1 启动MySQL
- 3.2 配置mysql
- 3.3 创建只读用户
- 3.4 创建数据库 - 4. Grafana
- 4.1 启动Grafana
- 4.2 配置数据源
- 4.3 dashboard与panel - 5. 参考
1. 简介
grafana是一个数据可视化程序, 可通过浏览器查看数据图表. 本文将以MySQL为数据源, 介绍如何通过Docker部署grafana与MySQL.
2. 网络设置
2.1 docker网络设置
既然grafana需要使用MySQL作为数据源, 那么grafana就需要访问MySQL所在的容器. 为了使容器间互通互联, 这里我们创建一个名为my-bridge
的桥接网络, grafana和MySQL都部署在my-bridge
上, 两个容器就可以互联互通了.
# 创建my-bridge网络
$ docker network create --driver bridge --subnet 172.12.0.0/16 --gateway 172.12.0.1 my-bridge
2.2 防火墙设置
如果服务器设置了防火墙, 需要将相应端口打开. MySQL的默认端口为3306, grafana的默认端口为3000.
使用以下命令, 开放3000和3306端口. Debian系可使用ufw设置防火墙.
$ sudo firewall-cmd --add-port=3000/tcp --permanent
$ sudo firewall-cmd --add-port=3306/tcp --permanent
$ sudo firewall-cmd --reload
$ sudo firewall-cmd --list-all
3. MySQL
3.1 启动MySQL
通过以下命令启动MySQL, 启动时, 需要注意以下选项
MYSQL_ROOT_PASSWORD=xxxxxx
中的xxxxxx
为MySQL密码, 自行修改--network my-bridge
中的my-bridge
为刚刚创建的网络的名称, 二者必须要一致--name mysql
中的mysql
为容器名字, 后面会用到
$ docker run -d \
-p 3306:3306 \
-v $HOME/docker/mysql/conf:/etc/mysql/conf.d \
-v $HOME/docker/mysql/data:/var/lib/mysql \
-e 'MYSQL_ROOT_PASSWORD=xxxxxx' \
--network my-bridge \
-h mysql \
--name mysql \
mysql:5.7
3.2 配置mysql
为了使MySQL支持中文, 需设置MySQL的编码为UTF-8
. 进入容器后, 新增或修改/etc/mysql/conf.d/my.cnf
文件, 添加如下内容, 并重启容器使配置生效.
[client]
default-character-set=utf8mb4
[mysql]
default-character-set=utf8mb4
[mysqld]
character-set-server=utf8mb4
collation-server=utf8mb4_unicode_ci
3.3 创建只读用户
因为Grafana并不会检查SQL语句是否安全, 比如DROP TABLE user
, 所以为了安全起见, 我们需要创建一个只拥有读权限的用户, 供Grafana查询数据用.
-- 创建用户前, 先创建一个名为 health 的数据库
CREATE DATABASE health DEFAULT CHARACTER SET utf8;
-- 创建名为 grafana 的用户, 密码为xxxxxx
CREATE USER "grafana"@"%" IDENTIFIED BY 'xxxxxx';
-- 给予 grafana 用户 health 数据库的读权限
GRANT SELECT ON health.* TO 'grafana'@'%';
FLUSH PRIVILEGES;
3.4 创建数据库
本文在health数据库创建一个测试表: thyroid 甲状腺功能. 表设计的不是很合理, 但是本文主要讲述的是通过docker部署grafana和mysql, MySQL仅作为一个数据来源.
通过以下sql语句, 创建表以及插入测试数据, MySQL部分就完结了.
CREATE TABLE thyroid
(
check_time DATETIME NOT NULL COMMENT '检查时间',
norm_name VARCHAR(100) NOT NULL COMMENT '指标名称',
norm_value DECIMAL(15,5) NOT NULL COMMENT '指标值',
norm_range_low DECIMAL(15,5) COMMENT '指标正常范围',
norm_range_high DECIMAL(15,5) COMMENT '指标正常范围',
PRIMARY KEY(norm_name, check_time)
) ENGINE=innodb DEFAULT CHARSET=utf8;
INSERT INTO thyroid VALUES
('2022-01-01 08:00:00', 1,'甲状腺球蛋白抗体', 63.64, '', 0, 115),
('2022-01-01 08:00:00', 1,'甲状腺过氧化物酶抗体', 81.26, '', 0, 34),
('2022-01-01 08:00:00', 1,'甲状腺球蛋白', 48.80, '', 3.5, 77),
('2022-01-01 08:00:00', 1,'TSH受体抗体', 8.14, '', 0, 1.58),
('2022-01-02 09:00:00', 1,'甲状腺球蛋白抗体', 70.59, '', 0, 115),
('2022-01-02 09:00:00', 1,'甲状腺过氧化物酶抗体', 71.26, '', 0, 34),
('2022-01-02 09:00:00', 1,'甲状腺球蛋白', 58.80, '', 3.5, 77),
('2022-01-02 09:00:00', 1,'TSH受体抗体', 9.14, '', 0, 1.58),
('2022-01-03 09:30:00', 1,'甲状腺球蛋白抗体', 73.59, '', 0, 115),
('2022-01-03 09:30:00', 1,'甲状腺过氧化物酶抗体', 70.26, '', 0, 34),
('2022-01-03 09:30:00', 1,'甲状腺球蛋白', 62.80, '', 3.5, 77),
('2022-01-03 09:30:00', 1,'TSH受体抗体', 4.14, '', 0, 1.58);
4. Grafana
4.1 启动Grafana
通过以下命令启动, 启动Grafana时, 也需要注意以下选项
--network my-bridge
中的my-bridge
为刚刚创建的网络的名称, 二者必须要一致
$ docker run -d \
--user root \
-p 30001:3000 \
-v $HOME/docker/grafana/data:/var/lib/grafana \
--network my-bridge \
-h grafana \
--name grafana \
grafana/grafana
4.2 配置数据源
启动后, 浏览器数据服务器IP:3000
进入Grafana界面, 默认用户为admin
, 默认密码为admin
.
进入界面的第一件事, 就是配置数据源, 告诉Grafana从哪里读取数据. 点击 页面左边的设置按钮
-> Data sources
-> Add data source
进入数据源配置界面. 详细配置如下:
Name
表示数据源的名字, 可以随便取, 自己认识就可以, 因为可能存在多个数据源的情况Host
是IP:端口
的格式, 这里想要MySQL, MySQL的IP就是创建MySQL时指定的容器名字, 此处我的配置是mysql:3306
Database
表示使用哪个数据库User
表示MySQL用户名Password
为MySQL的密码
配置完成后, 点击下方的Save & test
按钮即可.
4.3 dashboard与panel
Grafana中两个比较重要的概念就是dashboard与panel. 通俗来说, 一个panel就是一个表格; 一个dashboard可以显示一个或多个panel, dashboard是panel的集合; 一个Grafana实例包含一个或多个dashboard.
点击页面左边的田
字形按钮, 选择New dashboard
, 再点击add a new panel
即可添加一个面板, 添加之后, 会进入的到下图所示的panel设置界面.
- 红色标识处选择之前配置好的Datasource
- 蓝色标识处选择 Builder/Code 模式: Code模式是直接写SQL语句查询数据; Builder是通过图形化界面选择表与过滤条件, 二者效果一样, 可以互相转换
- 蓝色标识处设置panel名字, 与一些其他设置
设置好之后, 一定要点击save
按钮, Grafana不会自动保存任何设置!!!
保存后会回到dashboard界面, 会显示我们刚刚配置好的panel. 点击下图中蓝色线条所在位置, 即可自定义panel中线条的颜色; 点击下图中绿色线条所在位置, 即可隐藏其他线条, 再次点击恢复显示其他线条.
5. 参考
通过docker部署grafana和mysql的更多相关文章
- 使用 Docker 部署 Grafana + Prometheus 监控 MySQL 数据库
一.背景 在平时开发过程当中需要针对 MySQL 数据库进行监控,这里我们可以使用 Grafana 和 Prometheus 来实现监控功能.Grafana 是一款功能强大的仪表盘面板,支持多种数据源 ...
- docker 部署 nginx+php+mysql
系统:centos7 使用root账户 开放80端口 firewall-cmd --zone=public --add-port=80/tcp --permanent 安装docker yum ins ...
- docker部署多个mysql容器,并使用java连接
测试springboot多个数据源配置时,需要安装多个mysql容器,由于资源限制,当前只有一台虚拟机,如果在一台机器上安装多个mysql实例,是可以的,但步骤比较繁琐,使用docker来安装MySQ ...
- Docker部署tomcat+nginx+mysql,创建一个tomcat集群
Docker的部署可以选择虚拟机或者云服务器,我自己选择的是本机安装centos7虚拟机: 1.虚拟机安装登录成功后开始部署docker: 首先了解docker是一个开源应用容器引擎,基于Go语言遵循 ...
- 如何通过 Docker 部署 Logstash 同步 Mysql 数据库数据到 ElasticSearch
在开发过程中,我们经常会遇到对业务数据进行模糊搜索的需求,例如电商网站对于商品的搜索,以及内容网站对于内容的关键字检索等等.对于这些高级的搜索功能,显然数据库的 Like 是不合适的,通常我们采用 E ...
- 手把手教你 Docker部署可视化工具Grafana
一.Grafana的简单介绍 Grafana是开源的.炫酷的可视化监控.分析利器,无论您的数据在哪里,或者它所处的数据库是什么类型,您都可以将它与Grafana精美地结合在一起.它还有丰富的套件供您选 ...
- 使用Docker部署监控系统,Prometheus,Grafana,监控服务器信息及Mysql
使用Docker部署监控系统,Prometheus,Grafana,监控服务器信息及Mysql 一.docker部署prometheus监控系统 1.1 配置安装环境 1.1.1 安装promethe ...
- Docker部署Zabbix+Grafana监控
Docker部署Zabbix+Grafana监控 环境 centos 7 ; Docker 17.12.0-ce ; docker-compose version 1.20.1 2018-4-1 当前 ...
- 【原创】运维基础之Docker(2)通过docker部署zookeeper nginx tomcat redis kibana/elasticsearch/logstash mysql kafka mesos/marathon
通过docker可以从头开始构建集群,也可以将现有集群(配置以及数据)平滑的迁移到docker部署: 1 docker部署zookeeper # usermod -G docker zookeeper ...
- docker 部署django项目(nginx + uwsgi +mysql)
最近在学习用docker部署Django项目,经过百折不挠的鼓捣,终于将项目部署成功,爬过好多坑,也发现很多技能需要提高.特此写下随笔与小伙伴们分享,希望能对大家有所启发. docker的理论我就不赘 ...
随机推荐
- 04-MyBatisPlus条件构造器
一.wapper介绍 Wrapper : 条件构造抽象类,最顶端父类 AbstractWrapper : 用于查询条件封装,生成 sql 的 where 条件 QueryWrapper : Entit ...
- 不懂 Kubernetes 实现云原生是什么体验?
云原生的本质和最终效果 要明白什么是云原生,就要先弄明白云计算是什么有什么问题,云计算将计算资源.网络.存储等基础设施统一管理,通过资源规模化和自动化管理,实现降低资源的成本和提高资源的管理效率,云计 ...
- 从EDR的火热看安全产品的发展
从EDR的火热看安全产品的发展 2021年4月8日23:13 当开始写这篇博客时,外面正是护网进行得如火如荼的时候.作为一个产品经理,在吃瓜的同时,也在思考着安全产品的发展.这几年一些看得到的变化在深 ...
- thinkphp5.1发送邮件的方法
1.安装插件 composer require phpmailer/phpmailer 2.application下的common.php文件里加上一下代码,可自己根据需求稍加修改,我用的是验证码 u ...
- Promtail Pipeline 日志处理配置
转载自:https://mp.weixin.qq.com/s?__biz=MzU4MjQ0MTU4Ng==&mid=2247492144&idx=1&sn=a1cc13a642 ...
- 使用filebeat解析nginx的json格式日志,并且保存原始message字段的值,输出到es中并通过grafana图形化显示
1.nginx日志调成json样式 log_format json '{"@timestamp":"$time_iso8601",' '"server ...
- 「国产系统」Tubian 0.3,兼容Windows和Android的GNU/Linux系统!
0.4版已发布:https://www.cnblogs.com/tubentubentu/p/16741197.html Sourceforge.net主页(提供下载):https://sourcef ...
- 【博学谷学习记录】超强总结,用心分享|Linux修改文件权限方法总结
一.介绍 linux中"一切皆文件".每个文件都设定了针对不同用户的访问权限. 文件权限主要针对以下三种对象: 属主:拥有者 属组:所属的组 其他人:不属于上述两类 二.文件权限 ...
- js读取excel进行批量操作
推荐这款插件 http://oss.sheetjs.com/js-xls/ 具体用法大家查看api! <!DOCTYPE html> <html> <head> & ...
- Hadoop生态系统—数据仓库Hive的安装
一.数据仓库 数据仓库是一个面向主题的.集成的.随时间变化,但信息本身相对稳定的数据集合,相比于传统型数据库,它主要用于支持企业或组织的决策分析处理.主要有以下3个特点: 数据仓库是面向主题的: 数据 ...