집 >데이터 베이스 >MySQL 튜토리얼 >원격으로 연결할 때 'MySQL 액세스 거부' 오류가 발생하는 이유는 무엇입니까?
원격 MySQL 연결 오류: 액세스 거부 문제 해결
많은 사용자에게 "ERROR 1045(28000): 사용자에 대한 액세스가 거부되었습니다"라는 실망스러운 오류가 발생합니다. " MySQL에 원격으로 액세스하려고 할 때. 이 오류는 인증 제한으로 인해 원격 컴퓨터가 데이터베이스에 연결하는 것을 방지합니다. 이 문제를 자세히 조사하기 위해 특정 시나리오를 살펴보겠습니다.
이 경우 사용자는 로컬 시스템(192.168.233.142)에서 실행 중인 MySQL 서버를 가지고 있으며 다른 시스템에서 원격 연결을 설정하는 데 어려움을 겪고 있습니다. (192.168.233.163). MySQL 포트가 로컬 시스템에서 열려 있는 것으로 확인되었지만 원격 연결 시도에 앞서 언급한 오류가 발생했습니다.
핵심 문제는 루트 사용자에 대한 항목이 두 개만 포함된 MySQL 사용자 테이블에 있습니다. localhost에서 로컬 액세스를 허용하고 모든 IP 주소에서 액세스를 허용합니다(%). 이 문제를 해결하려면 사용자는 원격 시스템에 대한 특정 IP 항목을 mysql.user 테이블에 추가해야 합니다. 이렇게 하면 특정 시스템에 대한 명시적인 권한이 부여됩니다.
그러나 IP 항목을 추가하고 시스템을 다시 시작해도 오류가 지속됩니다. 해결책은 루트로 GRANT 문을 실행하여 원하는 원격 사용자의 IP 주소, 사용자 이름 및 비밀번호를 지정하는 것입니다. 이렇게 하면 필요한 권한이 부여되고 원격 시스템에 데이터베이스에 액세스하는 데 필요한 권한이 있는지 확인됩니다.
"GRANT ALL PRIVILEGES ON . TO 'USERNAME'@'IP'를 사용하여 권한 부여 IDENTIFIED BY 'PASSWORD' with grant option' 문을 사용하면 원격 사용자가 모든 데이터베이스 작업을 수행하고 해당 권한을 다른 사용자에게 전달할 수 있습니다. "FLUSH PRIVILEGES" 문을 실행하거나 MySQL 서버를 다시 시작하면 프로세스가 완료되고 원격 액세스가 가능해집니다.
이러한 단계를 수행하고 이에 따라 사용자 테이블과 권한을 조정하면 사용자는 원격 연결을 성공적으로 설정할 수 있습니다. MySQL 데이터베이스.
위 내용은 원격으로 연결할 때 'MySQL 액세스 거부' 오류가 발생하는 이유는 무엇입니까?의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!