Databases có thể phát triển theo thời gian và khiến bộ nhớ trên hệ thống bị đầy. Nếu bạn đã cài đặt MariaDB vào cùng một phân vùng với các file hệ thống khác thì có thể gặp tình trạng vị đầy bộ nhớ. Để giải quyết tình trạng này, Vietnix sẽ hướng dẫn bạn cách di chuyển thư mục dữ liệu MariaDB sang các vị trí khác nhằm tối ưu hóa hiệu suất cho hệ thống.
Điều kiện tiên quyết để di chuyển thư mục dữ liệu MariaDB sang vị trí mới trên CentOS 7
Để thực hiện hướng dẫn này, bạn cần phải cần phải đảm bảo thỏa mãn một số điều kiện như sau:
- Một máy chủ CentOS 7 đã cài đặt MariaDB. (Hướng dẫn cài đặt MariaDB trên CentOS 7 chi tiết tại đây)
- Một tài khoản người dùng non-root có quyền
sudo
. - Thiết bị hoặc không gian lưu trữ mới và đã
mount
chúng vào hệ thống để làm nơi lưu trữ mới cho thư mục dữ liệu MariaDB sau khi di chuyển.
Nếu đã đáp ứng đầy đủ thì tiếp tục thực hiện theo các bước hướng dẫn bên dưới đây.
Bước 1 – Di chuyển thư mục dữ liệu MariaDB
Đầu tiên, bạn cần phải khởi chạy MariaDB và xem đường dẫn hiện tại của thư mục dữ liệu MariaDB hiện đang nằm ở đâu:
mysql -u root -p
Bạn cần phải nhập mật khẩu của MariaDB khi được yêu cầu. Sau đó, nhập tiếp lệnh sau:
select @@datadir;
Bạn sẽ thấy output là thông tin về đường dẫn tới vị trí hiện tại của thư mục dữ liệu MariaDB:
Output
+-----------------+
| @@datadir |
+-----------------+
| /var/lib/mysql/ |
+-----------------+
1 row in set (0.00 sec)
Như bên trên thì đường dẫn thư mục dữ liệu hiện là /var/lib/mysql/
. Vậy là bạn đã biết được nơi dữ liệu MariaDB đang được lưu trữ, giờ hãy thoát khỏi phiên đăng nhập này bằng lệnh exit
:
exit
Trước khi bạn tiến hành di chuyển thư mục đó sang nơi mới, hãy tắt MariaDB để đảm bảo tính toàn vẹn của dữ liệu bằng lệnh:
sudo systemctl stop mariadb
Sau đó sử dụng lệnh sau để kiểm tra lại một lần nữa:
sudo systemctl stop mariadb
Nếu kết quả output có dòng Stopped MariaDB database server như bên dưới thì bạn có thể thực hiện bước tiếp theo:
Output
. . .
Dec 16 18:29:26 mysql systemd[1]: Stopped MariaDB database server.
Bây giờ tiến hành sao chép thư mục cơ sở dữ liệu hiện có sang vị trí mới với lệnh rsync
. Sử dụng cờ -a
để giữ nguyên quyền và các thuộc tính của các thư mục khác và cờ -v
để cung cấp output chi tiết để theo dõi tiến độ di chuyển:
sudo rsync -av /var/lib/mysql /new-drive
Lưu ý: Hãy chắc chắn không có dấu gạch chéo ở cuối đường dẫn mysql để đảm bảo di chuyển dữ liệu đúng địa điểm vào thư mục. Bạn có thể thay thế /new-drive
bằng đường dẫn mới tương ứng theo hệ thống.
Sau khi quá trình rsync
hoàn tất, tiến hành đổi tên thư mục hiện tại với phần mở rộng .bak
và giữ cho đến khi việc di chuyển hoàn tất. Điều này nhằm tránh sự nhầm lẫn các file ở vị trí cũ và mới:
sudo mv /var/lib/mysql /var/lib/mysql.bak
Bước 2 – Chỉ định vị trí lưu trữ mới cho MariaDB
Có nhiều cách để ghi đè giá trị trong file cấu hình MySQL. Nhưng theo mặc định, vị trí lưu trữ datadir được đặt trong đường dẫn /var/lib/mysql
theo file /etc/my.cnf
. Vậy bạn chỉ cần chỉnh sửa file này để phản ánh thư mục lưu trữ dữ liệu mới bằng lệnh:
sudo vi /etc/my.cnf
Tìm dòng bắt đầu bằng datadir=
sau đó thay đổi đường dẫn thành đường dẫn tới vị trí mới. Ngoài ra, bạn cũng cần phải cập nhật vị trí socket cho đúng theo đường dẫn mới:
[mysqld]
. . .
datadir=/new-drive/mysql
socket=/new-drive/mysql/mysql.sock
. . .
Ở đây thay thế new-drive bằng đường dẫn mà bạn đã di chuyển theo lệnh resync
ở bước 1. Sau đó chèn các lệnh sau vào vị trí bên dưới file nhưng trên dòng include
để tránh phân tách block [mysqld]
:
[client]
port=3306
socket=/new-drive/mysql/mysql.sock
!includedir /etc/my.cnf.d
Đừng quên thay thế new-drive bằng đường dẫn thư mục mới của bạn. Sau khi bạn hoàn tất, nhấn ESC, sau đó gõ :wq!
để lưu và thoát file.
Bước 3 – Khởi động lại MariaDB
Bây giờ bạn đã cập nhật cấu hình để sử dụng đường dẫn lưu trữ mới, hãy sẵn sàng để khởi động MariaDB và kiểm tra cơ sở dữ liệu bằng lệnh:
sudo systemctl start mariadb
sudo systemctl status mariadb
Sau khi khởi động, tiến hành đăng nhập vào MariaDB:
mysql -u root -p
Và thử xuất đường dẫn lưu trữ cơ sở dữ liệu hiện tại để xem MariaDB đã được cập nhật hay chưa:
select @@datadir;
Nếu bạn thấy output là đường dẫn mới tương tự như đã thực hiện ở các bước 1 và 2 thì quá trình di chuyển đã thành công.
Bây giờ bạn có thể xóa thư mục mysql.bak
đã đổi tên ở phần trước, tuy nhiên trước đó hãy chắc rằng mọi thứ hoạt động ổn định ở đường dẫn mới:
sudo rm -Rf /var/lib/mysql.bak
Để đảm bảo không gian lưu trữ có thể mở rộng linh hoạt theo sự gia tăng của cơ sở dữ liệu MariaDB sau một thời gian sử dụng, bạn có thể xem xét đến việc sử dụng VPS của Vietnix làm nơi lưu trữ dữ liệu sẽ là sự lựa chọn tối ưu nhất. Các gói dịch vụ Cloud Server, VPS Giá Rẻ, VPS Cao Cấp, VPS NVMe, VPS GPU cung cấp đến hàng trăm GB dung lượng ổ cứng và khả năng mở rộng linh hoạt phù hợp có thể đáp ứng mọi nhu cầu sử dụng của bạn.
Vietnix cũng được biết đến là một công ty có kinh nghiệm lâu năm trong lĩnh vực cung cấp giải pháp VPS. Với hơn 10 năm hoạt động, Vietnix đã phục vụ hơn 50.000 khách hàng, bao gồm cá nhân, doanh nghiệp như GTV, iVIVU, Vietnamworks, SEOSONA, SAGO Media. Vietnix đã kích hoạt hơn 100.000 dịch vụ với tỉ lệ khách hàng giới thiệu sau khi sử dụng lên đến 97%. Vietnix cũng tự hào là nhà cung cấp giải pháp VPS được trao giải thưởng Thương hiệu Việt Nam xuất sắc 2022. Với những thành tựu này, hãy an tâm để Vietnix trở thành người đồng hành cùng bạn trong con đường kinh doanh trên internet.
Mọi vấn đề thắc mắc cần tư vấn, quý khách vui lòng liên hệ:
- Địa chỉ: 265 Hồng Lạc, Phường 10, Quận Tân Bình, Thành Phố Hồ Chí Minh
- Hotline: 1800 1093
- Email: sales@vietnix.com.vn
Lời kết
Vậy là qua hướng dẫn về cách di chuyển thư mục dữ liệu MariaDB sang vị trí mới trên CentOS 7 này, bạn đã biết cách di chuyển thư mục cơ sở dữ liệu của MariaDB đến một vị trí mới và cấu hình lại để chúng có thể hoạt động một cách ổn định. Mong rằng bạn có thể áp dụng những thông tin từ bài hướng dẫn này để tối ưu hệ thống và giảm thiểu tình trạng đầy dung lượng do cơ sở dữ liệu mang lại.