> 데이터 베이스 > MySQL 튜토리얼 > Ubuntu 16.04에서 \'루트\'로 MySQL에 연결할 수 없는 이유는 무엇입니까?

Ubuntu 16.04에서 \'루트\'로 MySQL에 연결할 수 없는 이유는 무엇입니까?

Barbara Streisand
풀어 주다: 2024-10-30 11:53:02
원래의
797명이 탐색했습니다.

Why Can't I Connect to MySQL as 'root' in Ubuntu 16.04?

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 중국어 웹사이트의 기타 관련 기사를 참조하세요!

원천:php.cn
본 웹사이트의 성명
본 글의 내용은 네티즌들의 자발적인 기여로 작성되었으며, 저작권은 원저작자에게 있습니다. 본 사이트는 이에 상응하는 법적 책임을 지지 않습니다. 표절이나 침해가 의심되는 콘텐츠를 발견한 경우 admin@php.cn으로 문의하세요.
저자별 최신 기사
인기 튜토리얼
더>
최신 다운로드
더>
웹 효과
웹사이트 소스 코드
웹사이트 자료
프론트엔드 템플릿