Chuyển công nghệ lưu trữ database từ MyISAM sang InnoDB - AGOLA Chuyển công nghệ lưu trữ database từ MyISAM sang InnoDB - AGOLA

Hướng dẫn chuyển công nghệ lưu trữ database từ MyISAM sang InnoDB trong phpMyAdmin.

chuyen-cong-nghe-luu-tru-database-tu-myisam-sang-innodb

Nếu bạn chưa biết thì MyISAM và InnoDB là 2 công nghệ lưu trữ (storage engine) dữ liệu database được sử dụng phổ biến nhất hiện nay. MyISAM xuất hiện sớm hơn InnoDB, do đó, nó cũng được sử dụng rộng rãi hơn. Hầu hết các website WordPress hiện nay, dù chạy trên MySQL hay MariaDB, đều đang mặc định sử dụng MyISAM làm công nghệ lưu trữ. Tuy nhiên, InnoDB thực sự vượt trội MyISAM ở nhiều khía cạnh. Do đó, chúng tôi khuyên bạn nên chuyển qua sử dụng InnoDB thay cho MyISAM ngay khi có điều kiện.

Một số ưu điểm vượt trội của InnoDB

Nếu bạn quan tâm đến những lợi thế về mặt kỹ thuật của InnoDB thì:

  • InnoDB hỗ trợ khóa cấp hàng (row-level locking) trong khi MyISAM chỉ có khóa cấp bảng (table-level locking) đầy đủ. Với MyISAM, khi có hành động thực hiện (thêm/ sửa/ xóa) 1 record nào đó trong table thì table đó sẽ bị khóa lại, chờ tới khi hành động này được thực hiện xong thì hành động kia mới tiếp tục được thực hiện (có thể đọc đồng thời nhưng không thể ghi đồng thời).
  • InnoDB hỗ trợ tính toàn vẹn tham chiếu và hỗ trợ đầy đủ các khóa ngoài (RDBMS) trong khi MyISAM thì không (DBMS).
  • InnoDB có hỗ trợ giao dịch cho phép bạn thực hiện thay đổi, cam kết những thay đổi và khôi phục những thay đổi khi cần. MyISAM không có điều đó.
  • InnoDB sử dụng nhật ký giao dịch để phục hồi trong khi MyISAM thì không. Điều này làm cho InnoDB đáng tin cậy và an toàn hơn MyISAM.

MyISAM có cấu trúc đơn giản nên tốc độ đọc và truy xuất dữ liệu rất nhanh, có thể xem là nhanh nhất trong các loại storage engine. Tuy nhiên, nó dễ bị lỗi hơn và sẽ gặp phải vấn đề khi website có dữ liệu thường xuyên thay đổi (yêu cầu nhiều tác vụ thêm/ ghi/ xóa record). InnoDB có khả năng ghi dữ liệu nhanh hơn.

Bỏ qua những thứ khó hiểu bên trên, điều dễ nhận thấy nhất kể từ khi tôi chuyển từ MyISAM sang InnoDB là tính năng “tối ưu database” của các plugin hỗ trợ dọn dẹp database WordPress dường như “mất tác dụng”. Chúng không thể tìm thấy bất cứ table nào cần tối ưu. Bởi vì, database lưu trữ với công nghệ InnoDB luôn luôn ở trạng thái tối ưu nhất. Vậy còn lý do gì để không chuyển từ MyISAM sang InnoDB?

Chuyển từ MyISAM sang InnoDB bằng plugin LiteSpeed Cache

Nếu bạn đang sử dụng plugin LiteSpeed Cache trên website WordPress thì việc chuyển đổi từ MyISAM sang InnoDB vô cùng đơn giản.

Trong giao diện quản trị của WordPress, các bạn truy cập LiteSpeed Cache => Database => [1] Manage => Kéo xuống mục Database Table Engine Converter. Đây là nơi sẽ cho phép các bạn chuyển đổi công nghệ lưu trữ database từ MyISAM sang InnoDB.

litespeed-cache-database-table-engine-converter

Click vào nút Convert to InnoDB tương ứng với các table để tiến hành chuyển đổi. Hãy làm lần lượt cho đến khi nhận được thông báo: “We are good. No table uses MyISAM engine“.

Nếu web server của bạn không hỗ trợ plugin LiteSpeed Cache hoặc mã nguồn website của bạn không phải là WordPress, hãy xem hướng dẫn trong phần tiếp theo.

Chuyển từ MyISAM sang InnoDB trong phpMyAdmin

Trước khi tiến hành, hãy backup dữ liệu database của bạn để đảm bảo an toàn, mặc dù việc chuyển đổi storage engine thường không gây ra lỗi.

1. Truy cập phpMyAdmin của hosting.

click-vao-muc-phpmyadmin-trong-cpanel

2. Trong giao diện phpMyAdmin, click chọn database tương ứng với website của bạn. Danh sách các table của database sẽ hiện ra ở bên phải. Hãy chú ý đến cột Type, đây chính là công nghệ lưu trữ mà các table đang sử dụng.

kiem-tra-cong-nghe-luu-tru-database-trong-phpmyadmin

3. Click vào 1 table mà bạn muốn chuyển đổi công nghệ lưu trữ => click tiếp vào tab Operations.

click-vao-tab-operations-trong-phpmyadmin

4. Trong cột Table options, hãy click vào mục Storage Engine và chọn InnoDB.

click-vao-muc-storage-engine

Click vào nút Go để xác nhận thay đổi.

5. Chờ trong giây lát cho quá trình chuyển đổi hoàn tất, bạn sẽ nhận được thông báo tương tự như thế này.

query-has-been-executed-successfully

6. Quay trở lại danh sách table, các bạn sẽ thấy Type của table đã được chuyển thành InnoDB.

chuyen-doi-storage-engine-thanh-cong

Lặp lại các bước bên trên cho đến khi tất cả các table đều được chuyển hết thành InnoDB. Thật đơn giản phải không nào? Chúc các bạn thành công!

Website của bạn đang sử dụng công nghệ lưu trữ database nào? Theo bạn, có nên chuyển từ MyISAM sang InnoDB hay không? Hãy cho chúng tôi biết quan điểm và ý kiến của bạn trong khung bình luận bên dưới.

Nếu bạn thích bài viết này, hãy subscribe blog của tôi để thường xuyên cập nhật những bài viết hay nhất, mới nhất qua email nhé. Cảm ơn rất nhiều. 🙂

Các lý do cần đọc trước khi quyết định liên hệ tôi 

  1. Tham gia group Mua bán Google Ads và Google Shopping :

    https://www.facebook.com/groups/314513929300715

  2. Tham gia group mua bán cho thuê tài khoản BM Agency :

    https://www.facebook.com/groups/1204318359703229

  3. AGOLA chỉ cung cấp dịch vụ không có dịch vụ tư vấn hiểu tới đâu bán tới đó !
  4. Các dịch vụ liên quan đến hướng dẫn : diễn ra từ 5-30 phút thông qua teamview hoặc ultral thời gian càng ngắn giá tiền càng cao nên các bạn đọc kỹ trước khi sử dụng
  5. Các sản phẩm dịch vụ không có thương thảo giá và cũng không có hỏi thêm
  6. Không bán vĩnh viễn mọi dịch vụ mua nhầm đòi đổi sang gói dịch vụ khác
  7. Thông tin bảo hành gần như không có nhưng cũng có một số dịch vụ có bảo hành đề nghị đọc kỹ trước khi quyết định mua
  8. Quyết định mua hàng là đồng ý các điều khoản mua bán và điều khoản không được lấy lại tiền và không bồi hoàn
  9. Mua hàng thì xin đọc kỹ điều khoản ở từng mô tả trước khi quyết định nhấc máy liên hệ ở thông tin của từng gói dịch vụ
  10. Mọi giao dịch đều được phải bắt buộc chụp màn hình chuyển khoản gửi vào Zalo
  11. Các đối tượng cố ý chuyển tiền gói này để trục lợi sử dụng gói khác đều được coi là hình vi lừa đảo ! Cố ý ghi nội dung hiểu lầm về chuyển tiền để đôi co đòi sử dụng gói dịch vụ khác cũng vậy !
  12. Tôi là dân khối A nên việc viết sai lỗi chính tả thì kệ mẹ tôi thích thì mua không thích thì đừng soi đi ra chỗ khác do tôi không có soát lại chính tả nên các bạn đọc thay vì thắc mắc thì thông cảm giùm tôi ! miễn sao tôi truyền tải thông tin bạn đọc bạn thấy hiểu được bạn sử dụng không được bạn tìm bên khác
  13. Tôi không làm việc với bọn cử nhân viên là các công ty Agency , truyền thông gọi hỏi dò hỏi luyên thuyên ! Nếu cố tình tôi sẽ dùng CRM Agency cấm lock chạy Ads vĩnh viễn khi nhìn thấy đuôi theo rõi của doanh nghiệp đó mà tôi đã gán.
  14. Tôi không làm việc với bọn nào thì tôi chạy tiền tỷ tôi tiêu tiền tỷ nhưng chạy demo trước nếu ngon thì vít lớn nhưng sau 3 ngày thuê thấy đéo thấy như cam kết về ngân sách
  15. Tôi không hợp tác ăn chia hay kiểu Win Win đôi bên có lợi
  16. Tất cả những câu hỏi khi gọi điện khiến tôi nghĩ rằng bạn chưa đọc kỹ thông tin trên website sẽ được tôi từ chối vô điều kiện
  17. Không làm việc các công ty có các nhân vật nổi tiếng trên các đài báo truyền hình bởi vậy bớt quảng cáo
  18. Các đối tượng cố tình lên mạng tìm kiểm thông tin tôi và không có trao đổi được tôi dùng Zalo : O9O9.456.866 gửi STK thông tin thanh toán của tôi qua zalo đó mà vẫn chuyển tiền vào tài khoản của tôi được coi là hình vi lừa đảo cố tình trọc phá và lợi dụng sử dụng lừa đảo để mong muốn sử dụng dịch vụ của tôi nhưng vì cấm nên phải làm vậy
  19. Kiến thức của đại đa số dân trên mạng không sai mà chỉ đúng với bọn gà mờ mà thôi kiểu như bạn học lớp 1 cô giáo nói 1 không trừ được cho 2 lên cấp 2 cô giáo nói 1 trừ được cho 2 ! Lúc đó cô giáo cấp 1 hay thầy giáo cấp 2 không nói ai đúng ai sai được mà tại thời điểm đó bạn thấy nó đúng còn khi đi sâu vào nó đéo đúng 😀 ! Cũng như việc tôi bán dịch vụ cho dân trong nghề việc tôi có bắt mấy thằng cấp 1 nuốt kiến thức chuyên sâu của cấp 2 là không được bởi vậy dân nào hiểu sẽ liên hệ mua chứ đừng kiểu lơ mở hỏi cho vui cửa vui nhà

Trả lời

Email của bạn sẽ không được hiển thị công khai. Các trường bắt buộc được đánh dấu *

Call Now Button
X