1. Kiểm tra các truy vấn chậm
Luôn bắt đầu từ việc xác định vấn đề trước khi tối ưu.
- Bật slow query log:
[mysqld]
slow_query_log = 1
slow_query_log_file = /var/log/mysql/slow.log
long_query_time = 1
log_queries_not_using_indexes = 1
- Phân tích bằng công cụ như
pt-query-digestđể tìm ra truy vấn gây chậm.
2. Tối ưu cấu hình MySQL/MariaDB
| Thông số | Gợi ý tối ưu |
|---|---|
innodb_buffer_pool_size |
Dành 60–70% RAM nếu dùng InnoDB chủ yếu. |
query_cache_type |
Tắt nếu dùng InnoDB (ở MySQL 5.7 trở lên), dùng Redis thay. |
tmp_table_size và max_heap_table_size |
Tăng lên 128M–256M nếu có nhiều sort hoặc group by. |
innodb_io_capacity |
Tăng lên 1000–2000 nếu dùng SSD/NVMe. |
max_connections |
Giảm nếu server RAM thấp, tăng nếu web traffic lớn. |
3. Dùng chỉ mục đúng cách
- Thêm chỉ mục vào các cột thường truy vấn (WHERE, ORDER BY).
- Kiểm tra với
EXPLAINđể biết truy vấn có dùng index hay không. - Xóa index không dùng đến để tránh tăng dung lượng và làm chậm ghi dữ liệu.
4. Sử dụng object cache (Redis/Memcached)
- Cài plugin như Redis Object Cache hoặc dùng
wp configđể kích hoạt. - Giảm đáng kể truy vấn lặp lại trong các lần load trang kế tiếp.
5. Tránh truy vấn không cần thiết
- Giảm số lượng plugin tạo query động.
- Dùng
transient APIđể cache tạm thời các kết quả nặng. - Tối ưu lại các
WP_Queryđể chỉ gọi dữ liệu cần thiết.
6. Tối ưu database định kỳ
- Dùng plugin như WP Optimize hoặc Advanced Database Cleaner.
- Xoá bản nháp, bản revision, transient hết hạn, bảng không dùng đến.
7. Phân tách dữ liệu (nâng cao)
- Tách các bảng lớn như
wp_postmetanếu site có hàng trăm nghìn bài viết. - Chuyển dữ liệu không quan trọng sang bảng riêng hoặc custom table.
8. Theo dõi với công cụ chuyên sâu
- Dùng
mysqltuner.plđể gợi ý cấu hình. - Thường xuyên kiểm tra
SHOW PROCESSLISTvàSHOW STATUS.
Kết luận
Tối ưu MySQL/MariaDB không phải là thao tác “một lần là xong”, mà là quá trình theo dõi – điều chỉnh liên tục. Với các bước trên, bạn sẽ giúp website WordPress hoạt động mượt mà hơn ngay cả khi traffic lớn và dữ liệu ngày càng tăng.
Bình luận