Ubuntu 16.04에서 '루트' 사용자에 대한 데이터베이스 액세스가 거부되었습니다.
Ubuntu 16.04에서 웹 서버를 사용하여 데이터베이스에 액세스할 때 다음과 같은 문제가 발생할 수 있습니다. "SQLSTATE[HY000] [1698] 'root'@'localhost' 사용자에 대한 액세스가 거부되었습니다." 오류. 이 문제는 모든 권한을 가진 새 사용자를 생성하는데도 발생합니다.
MySQL 5.7의 루트 사용자 제한
이 오류의 근본 원인은 MySQL 5.7에 도입된 변경 사항에 있습니다. 이는 sudo 권한이 없는 '루트' 사용자의 사용을 제한합니다. 이전 버전에서는 사용자가 "mysql -u root" 명령을 사용하여 권한을 높이지 않고도 '루트'로 MySQL에 액세스할 수 있었습니다. 그러나 MySQL 5.7에서는 이 접근 방식이 더 이상 가능하지 않습니다.
해결 방법
이 문제를 해결하려면 필요한 권한이 있는 새 사용자를 생성하고 사용해야 합니다. PHP 애플리케이션이나 기타 명령줄이 아닌 도구에서 데이터베이스 연결을 설정할 때 '루트' 대신 해당 사용자를 사용하세요.
PHP 코드
PHP 코드에서 새로 생성된 사용자의 자격 증명이 포함된 사용자 이름 및 비밀번호:
<code class="php">protected $name = 'new_user'; protected $pass = 'new_password';</code>
명령줄에서 루트 액세스
'루트' 사용자를 직접 사용할 수는 없지만 GUI 또는 명령줄이 아닌 애플리케이션의 경우에도 sudo:
sudo mysql -u root
를 사용하여 명령줄에서 '루트'로 MySQL에 액세스할 수 있습니다. 이 접근 방식은 권한을 높이므로 필요한 경우에만 사용해야 한다는 점을 기억하세요. 보안상의 이유로 '루트' 대신 데이터베이스 관리를 위한 전용 사용자를 생성하고 해당 사용자를 사용하는 것이 좋습니다.
위 내용은 Ubuntu 16.04에서 \'루트\'로 MySQL에 연결할 수 없는 이유는 무엇입니까?의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!