Hướng dẫn kết nối Grafana với cơ sở dữ liệu MySQL từ xa
Grafana cần dữ liệu để có thể sử dụng. Jack Wallen sẽ hướng dẫn bạn qua quá trình sử dụng cơ sở dữ liệu MySQL làm nguồn dữ liệu trực quan hóa trong Grafana.
Grafana là một trong những công cụ trực quan hóa dữ liệu tương tác phổ biến nhất trên thị trường. Nó là mã nguồn mở, mạnh mẽ, có khả năng cấu hình cao và miễn phí. Tôi đã hướng dẫn bạn cách cài đặt Grafana trên Ubuntu Server 20.04 và lần này, tôi sẽ giúp bạn kết nối nền tảng vừa cài đặt với cơ sở dữ liệu MySQL, để bạn có thể trực quan hóa dữ liệu đó.
Grafana cho phép bạn kết nối với nhiều nguồn dữ liệu khác nhau, chẳng hạn như Google Sheets, Amazon Timestream, Elasticsearch và nhiều cơ sở dữ liệu khác. Vì MySQL là một cơ sở dữ liệu phổ biến như vậy, tôi nghĩ rằng đây sẽ là một nguồn dữ liệu tuyệt vời để sử dụng làm minh họa. Điều này cũng sẽ làm cho bạn nhớ lại cách thiết lập MySQL cho việc kết nối từ xa.
Chuyển đến:
Bạn sẽ cần gì
Để làm việc này, bạn sẽ cần một phiên bản Grafana đang chạy, một phiên bản MySQL đang chạy và một người dùng có đặc quyền sudo.
Cho hướng dẫn này, tôi sẽ giả định rằng phiên bản MySQL của bạn đang chạy trên một máy chủ Linux từ xa.
Cách cấu hình MySQL để kết nối từ xa
Điều đầu tiên chúng ta phải làm là cấu hình máy chủ MySQL cho phép kết nối từ xa. Ngoài ra, chúng ta sẽ tạo một người dùng cụ thể có quyền cụ thể cho cơ sở dữ liệu chúng ta sẽ xem trên Grafana.
SEE: Khám phá các thuật ngữ mã nguồn mở và Linux bạn nên biết.
Cấu hình MySQL để truy cập từ xa
Việc thực hiện các bước dưới đây sẽ giúp đảm bảo MySQL được cấu hình đúng. Trên thực tế, nếu máy chủ MySQL không chạy trên cùng máy chủ với Grafana, bạn cần phải làm theo các bước bên dưới trước, vì một phiên bản MySQL mặc định thường không được cấu hình để cho phép kết nối từ xa.
- Trước tiên, đăng nhập vào máy chủ MySQL và mở tệp cấu hình MySQL bằng câu lệnh:
sudo nano /etc/mysql/mysql.conf.d/mysqld.cnf
- Trong tệp đó, tìm dòng:
bind-address = 127.0.0.1
- Thay đổi thành:
bind-address = 0.0.0.0
- Lưu và đóng tệp, sau đó khởi động lại dịch vụ MySQL bằng câu lệnh:
sudo systemctl restart mysql
Tạo người dùng mới với các quyền cụ thể
Bây giờ chúng ta đã thiết lập máy chủ MySQL để cho phép kết nối từ xa, chúng ta cần tạo một người dùng mới và cấp cho nó các quyền chính xác. Để làm điều này:
- Đăng nhập vào bảng điều khiển MySQL với câu lệnh:
sudo mysql -u root -p
- Hãy chắc chắn rằng bạn biết bạn sẽ sử dụng cơ sở dữ liệu nào. Bạn có thể liệt kê chúng với câu lệnh:
show databases;
- Tạo người dùng mới với câu lệnh:
CREATE USER 'grafanareader' IDENTIFIED BY 'PWORD';
Trong đó, PWORD là mật khẩu mạnh / duy nhất cho người dùng mới.
- Bây giờ, chúng ta có thể cấp cho người dùng mới đó quyền SELECT cho cơ sở dữ liệu với câu lệnh:
GRANT SELECT ON DB.* TO 'grafanareader';
Trong đó, DB là tên cơ sở dữ liệu sẽ được đọc bởi Grafana.
- Xóa các quyền và thoát khỏi bảng điều khiển MySQL với câu lệnh:
flush privileges; exit
Máy chủ cơ sở dữ liệu của bạn hiện đã sẵn sàng.
Cách
Nguồn: https://techtoday.co/how-to-connect-grafana-to-a-remote-mysql-database/
Grafana needs data to be useful. Jack Wallen walks you through the process of using a MySQL database as a source for data visualization in Grafana.
Grafana is one of the most widely-used interactive data visualization tools on the market. It’s open-source, powerful, highly configurable and free to use. I’ve walked you through the process of installing Grafana on Ubuntu Server 20.04, and this time around, I’ll help you connect that newly installed platform to a MySQL database, so you can visualize that data.
Grafana allows you to connect to numerous data sources, such as Google Sheets, Amazon Timestream, Elasticsearch and many databases. Because MySQL is such a popular database, I thought it would be a great data source to use as an illustration. This will also refresh your memory on how to set MySQL up for remote connections.
Jump to:
What you’ll need
To make this work, you’re going to need a running instance of Grafana, a running instance of MySQL and a user with sudo privileges.
For this tutorial, I am going to assume your instance of MySQL is on a remote Linux server.
How to configure MySQL for remote connection
The first thing we must do is configure the MySQL server to allow remote connections. On top of that, we’re going to create a specific user that has specific permissions for the database we’ll view on Grafana.
SEE: Explore these open-source and Linux terms you should know.
Configure MySQL for remote access
Going through the process below will help ensure MySQL is indeed configured correctly. In fact, if the MySQL server is not running on the same server as Grafana, it is critical that you follow the steps below first, as a stock MySQL installation usually is not configured to allow for remote connections.
- First, log into your MySQL server and open the MySQL configuration file with:
sudo nano /etc/mysql/mysql.conf.d/mysqld.cnf
- In that file, look for the line:
bind-address = 127.0.0.1
- Change that to:
bind-address = 0.0.0.0
- Save and close the file, then restart the MySQL service with:
sudo systemctl restart mysql
Create a new user with specific permissions
Now that we’ve set up our MySQL server to allow remote connections, we need to create a new user and give it the correct permissions. To do this:
- Log in to the MySQL console with:
sudo mysql -u root -p
- Make sure you know which database you’re going to be using. You can list them out with:
show databases;
- Create the new user with:
CREATE USER 'grafanareader' IDENTIFIED BY 'PWORD';
Where PWORD is a strong/unique password for the new user.
- Now, we can grant that new user the SELECT permission for the database with:
GRANT SELECT ON DB.* TO 'grafanareader';
Where DB is the name of the database to be read by Grafana.
- Flush the privileges and exit from the MySQL console with:
flush privileges; exit
Your database server is now ready.
How to connect Grafana to MySQL
Log into your Grafana instance, and click the hamburger (3 horizontal lines) icon in the left sidebar. From the resulting pop-up, click Add new connection (Figure A).
Figure A
data:image/s3,"s3://crabby-images/dc906/dc906018bd8e23ecd56f5563187e78feed4efb8a" alt="Screencapture of Grafana interface with Add new connection option and the Options button on highlight."
In the next window, type mysql in the search bar, and hit Enter, or scroll down, and click MySQL from the listing (Figure B).
Figure B
data:image/s3,"s3://crabby-images/e5fae/e5fae401ce148bd81f5e0a96e8b7ee537fe5aa34" alt="The MySQL Grafana configuration selection page."
On the next page, click on the blue Add new data source button in the upper right (Figure C).
Figure C
data:image/s3,"s3://crabby-images/e7995/e79953a29ad12f7a5dde1744e78428b850887951" alt="Prelude to adding a new MySQL connection, with Add new data source button on highlight."
You will then be presented with the necessary configuration options for a MySQL data connection. Here’s what you must fill out:
- Host: The IP address or domain name of the MySQL hosting server, along with the port used for the database server. Note that if you are setting up a connection to localhost:3306, which is the default value specified, you must click into the field and type it in, or else the connection will not work.
- Database: The database to be used as a source.
- User: grafanareader.
- Password: PWORD used to create grafanareader in the MySQL console.
You might also have to enable Skip TLS Verify. And you may want to consider specifying a name for this connection, especially if you need to have multiple MySQL connections from Grafana.
Configure those options, and click Save & Test. You should eventually see Database Connection OK (Figure D).
Figure D
data:image/s3,"s3://crabby-images/44989/44989d9508d425971f887d2a31106db2e0b1c334" alt="The completed connection setup in Grafana."
Congratulations! You now have Grafana connected to a remote MySQL server. In our next piece in the series, we’ll create a new dashboard to view some of the data from the source.
Now that you have successfully connected to your MySQL data source, it’s time to take the next step by adding a dashboard.
SEE: Not satisfied with Grafana? Consider these cost-effective data visualization tools.
[ad_2]