Notice: Function _load_textdomain_just_in_time was called incorrectly. Translation loading for the wordpress-seo domain was triggered too early. This is usually an indicator for some code in the plugin or theme running too early. Translations should be loaded at the init action or later. Please see Debugging in WordPress for more information. (This message was added in version 6.7.0.) in /var/www/vinascript/html/wp-includes/functions.php on line 6114
Kết nối tới MySQL/MariaDB không cần quyền sudo - VinaScript

Latest Post

Triển khai dự án PHP, Mysql với Nginx trên Docker Tìm hiểu về HTML – Ưu điểm, nhược điểm và cách hoạt động của HTML

Trên hệ điều hành Linux, nếu bạn cố gắng kết nối vào MySQL/MariaDB bằng tài khoản người dùng thông thường mà không sử dụng quyền sudo, bạn có thể gặp phải lỗi sau.

Như bạn đã thấy, khi không sử dụng quyền sudo để kết nối đến MySQL/MariaDB trên Ubuntu, bạn sẽ gặp lỗi “Access denied for user…”. Tuy nhiên, khi sử dụng quyền sudo, bạn có thể kết nối thành công.

Nguyên nhân của vấn đề này là do trên Ubuntu, MySQL/MariaDB mặc định chỉ cho phép người dùng “root” đăng nhập thông qua “unix_socket,” và điều này đòi hỏi bạn phải có quyền sudo để thực hiện việc đăng nhập.

Để xác định phương thức đăng nhập mà một người dùng sử dụng, bạn có thể sử dụng lệnh SQL sau:

SELECT user,authentication_string,plugin,host FROM mysql.user;

Vậy để login bạn cần tạo user khác để login. Tuy nhiên bạn có thể thay đổi cơ chế login để user root login thông qua password như thông thường.

Sử dụng các lệnh SQL sau để thay đổi từ unix_socket sang login bằng password thông thường.

  1. Đầu tiên login bằng tài khoản root với quyền sudo
    sudo mysql -u root -p
  2. Sau đó thay đổi lại cơ chế login
    MariaDB []>use mysql;
    MariaDB [mysql]>update user set plugin='' where User='root';
    MariaDB [mysql]>flush privileges;
    MariaDB [mysql]>exit

Bây giờ bạn có thể đăng nhập bình thường mà không phải sử dụng quyền sudo.

Để lại một bình luận

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 *