Create MySQL Data Source, Collector and Dashboard
Video Lecture
(Pay Per View)
Description
In this video, I demonstrate how to set up the MySQL Data Source with a collector, and it's related dashboard.
I also demonstrate how to install a MySQL database server.
I install the MySQL database onto a new sever to also demonstrate the types of issues that you may have when connecting Grafana to another server.
Add the MySQL Data source in Grafana. If you try to save it, it will have some issues. We will next set up a MySQL server ready for the Data Source configuration.
After sourcing your new server (you can always use your existing Grafana server if you prefer) we next can install MySQL onto the new server. SSH onto your new MySQL server.
| # |  | 
| # |  | 
| # |  | 
Now that we have a MySQL server, we will install a dedicated collector that will periodically gather statistics about the MySQL server and store them into a table containing rows with times and values (my2.status).
The dashboard will be the popular 2MySQL Simple Dashboard (7991) that you can download from https://grafana.com/grafana/dashboards?dataSource=mysql
The collector script that I will use can be downloaded from https://github.com/meob/my2Collector
I have MySQL 8.#.#, so I will download the file called my2_80.sql. If you have MySQL 5.#.#, then download my2.sql
SSH onto your new MySQL server and download the script using wget,
| # |  | 
Open the script that was downloaded
| # |  | 
Find these lines at the end of the script where it creates a specific user,
-- Use a specific user (suggested)
-- create user my2@'%' identified by 'P1e@seCh@ngeMe';
-- grant all on my2.* to my2@'%';
-- grant select on performance_schema.* to my2@'%';
uncomment and change the password to something that you think is better. E.g.,
-- Use a specific user (suggested)
create user my2@'localhost' identified by 'password';
grant all on my2.* to my2@'localhost';
grant select on performance_schema.* to my2@'localhost';
Save the changes and then run the SQL script,
| # |  | 
Now open MySQL and do some checks.
| # |  | 
| > > > > > > > > |  | 
If when running the above lines, it shows that the event_scheduler is not enabled, then we will need to enable it so that the collector runs in the background. You can do this by editing the my.cnf file
| # |  | 
Add lines to the end of the file
[mysqld]
event_scheduler = on
Save and restart MySQL.
| # |  | 
The above test lines should also show a new user in the database named my2.
If everything is ok, then we can continue.
Before we can save the MySQL data source configuration in Grafana, we will need to tell it which database and user it should use. The user should be granted select permissions only since Grafana will not validate any SQL commands sent from it. We will create a specific user that can read the my2 database with select permissions only. We won't use the my2 user we created earlier since it has more permissions than our Grafana server actually needs.
Open the MySQL prompt
| # |  | 
We need to know the IP address of our Grafana server that will initiate the connection to the MySQL server.
| > > > > |  | 
Note that we have now added 2 extra database users,
- grafana@###.###.###.###: Used by the Grafana dashboard, to query the collected data from the MySQL server. This user has been granted the SELECT privilege only.
- my2@localhost: Used by the MySQL event scheduler to collect statistics and save them into the DB for use by the Grafana dashboard. This user has been granted ALL privileges.
If you installed your MySQL onto a different server, then by default it will not allow external connections.
To allow remote connections on the MySQL server.
Open the MySQL configuration file
| # |  | 
Change the bind address to 0.0.0.0 or add this text below to the end of the file if it doesn't already exist.
[mysqld]
bind-address    = 0.0.0.0
Save and restart MySQL.
| # |  | 
Save the data source in Grafana and the connection should now be ok.
We can do a quick test using the Explore option on Grafana. Open the Explore tab, select the MySQL data source and use this query below.
| >
 |  | 
Press the [Code] button at the right, and then paste in the above sample query.
Now that we have a MySQL Data Source created, we will install a dashboard for it.
The dashboard will be the popular 2MySQL Simple Dashboard you can download from https://grafana.com/grafana/dashboards?dataSource=mysql (ID 7991)
After several hours, you should see that dashboard visualizations will fill with some data.
Troubleshooting
ERROR : db query error: query failed
If when connecting to a MySQL data source, you see the error db query error: query failed - please inspect Grafana server log for details.
You can tail the Grafana log using the command.
| # |  | 
Your error may be directly visible in the output of the above command, if not, try to connect again using the MySQL data sources Save & Test button, and look for the error as it is logged in real time.
If the error is similar to "Error 1045: Access denied for user 'grafana'@'[IP ADDRESS OF YOUR GRAFANA SERVER]' (using password: YES)", then you haven't added the user to MySQL correctly.
When you add the "read only" user to MySQL, you indicate which IP addresses the user is connecting from and which objects it is allowed to read.
E.g., If your Grafana servers IP Address is 10.20.30.40, and that is the IP address that the MySQL server will get the connection attempt from, then the MySQL commands to create the user and allow read on the tables are,
| > > > |  | 
If you installed MySQL locally on the same server as your Grafana server, then it would connect using localhost, so your commands would then be
| > > > |  | 
ERROR : Duplicate key name 'idx01'
If you run the my2_80.sql script twice, it will error that there is already a duplicate key idx01.
There is no reason to run the script twice, unless you have your reasons, whatever they may be.
You will need to delete the idx01, and any other objects that may have been created on the first run that now prevent the my2_80.sql script from being run twice.
Log onto the MySQL prompt
| # |  | 
and then run these commands
| > > > > > |  | 
And then retry
| # |  | 
Extra Notes
MySQL Secure Installation
Note that in previous versions of this course, I would also run mysql_secure_installation. This is no longer necessary since MySQL version 8.#.# is already secured by default.
Missing Import Button
Instead of pressing a specific button for [Import] on the dashboards page, you now need to select the [New] button first, and then select the Import option.
Daemons using outdated libraries
Since Ubuntu 22.04, installing new packages may give you a full screen prompt to restart other dependent services. Press Tab to highlight the OK option, and press Enter.
Explore MySQL DataSource
Since Grafana 9, when using the Explore option on a MySQL data source, you now get a query wizard. In order to use the custom query editor instead, press the [Code] button at the right of the screen.

It also no longer provides an editable sample query as shown in the video. Instead, paste and run this example below.
| >
 |  | 














 
      
















