> 운영 및 유지보수 > Docker > docker 컨테이너 mysql 인증이 실패하는 경우 수행할 작업

docker 컨테이너 mysql 인증이 실패하는 경우 수행할 작업

PHPz
풀어 주다: 2023-04-18 10:01:41
원래의
819명이 탐색했습니다.

최근 몇 년 동안 Docker 컨테이너 기술은 다양한 애플리케이션 시나리오에서 점점 더 널리 사용되고 있으며 가볍고 빠른 배포 및 관리 방법을 제공하여 애플리케이션 개발과 운영 및 유지 관리를 더욱 효율적으로 만듭니다. Docker 컨테이너 기술을 사용할 때 컨테이너에서 MySQL 인증 실패와 같은 몇 가지 문제가 발생할 수 있습니다. 이 문서에서는 이 문제를 해결하는 방법을 설명합니다.

Docker 컨테이너에서 MySQL 인증이 실패하면 액세스 거부와 같은 문제가 발생할 수 있습니다. 이 상황은 일반적으로 컨테이너에서 사용자 인증이 올바르게 설정되지 않아 발생합니다. Docker 컨테이너에는 MySQL 사용자 인증을 위한 두 가지 주요 방법, 즉 비밀번호 기반 인증과 인증 플러그인 기반 인증이 있습니다.

비밀번호 기반 인증

비밀번호 기반 인증에서 MySQL 사용자는 컨테이너에 계정 비밀번호를 생성하고 외부에서 컨테이너에 액세스할 때 인증을 위해 이 자격 증명을 사용해야 합니다. 다음 단계에 따라 MySQL 계정을 생성할 수 있습니다.

  1. Docker 컨테이너에 MySQL 서버를 입력합니다.

먼저 컨테이너에 MySQL 서버를 입력해야 합니다. 이는 다음 명령을 사용하여 수행할 수 있습니다.

docker exec -it mysql-container mysql -u root -p
로그인 후 복사

이 명령은 대화형 터미널을 시작하고 컨테이너의 MySQL 서버에 연결합니다.

  1. 새 사용자 만들기

MySQL 터미널에서 다음 명령을 사용하여 새 사용자를 만들 수 있습니다.

CREATE USER 'newuser'@'%' IDENTIFIED BY 'password';
로그인 후 복사

여기서 'newuser'는 새 사용자의 사용자 이름이고 '%'는 사용자가 다음을 수행할 수 있음을 의미합니다. 모든 IP 주소에서 액세스할 경우 'password'는 새 사용자의 비밀번호입니다.

  1. 새 사용자 승인

마찬가지로 MySQL 터미널에서 다음 명령을 사용하여 새 사용자를 승인할 수 있습니다.

GRANT ALL PRIVILEGES ON *.* TO 'newuser'@'%';
로그인 후 복사
로그인 후 복사

이 명령은 새 사용자에게 모든 데이터베이스와 테이블에 대한 액세스 권한을 부여합니다.

  1. Refresh Permissions

마지막으로 변경 사항을 적용하려면 권한을 새로 고쳐야 합니다.

FLUSH PRIVILEGES;
로그인 후 복사
로그인 후 복사

이제 새 사용자가 성공적으로 생성되었으며 사용자 이름과 이름을 사용하여 외부에서 MySQL 컨테이너에 액세스할 수 있는 권한이 부여되었습니다. 비밀번호.

인증 플러그인 기반 인증

인증 플러그인 기반 인증에서 MySQL 서버는 SSL 인증서, Kerberos 등을 사용하는 등 사용자 인증을 위해 외부 인증 플러그인을 사용하여 사용자를 보다 안전하게 인증합니다. Docker 컨테이너에서 인증 플러그인은 다음 단계를 사용하여 설정할 수 있습니다.

  1. MySQL 컨테이너에 플러그인 설치

인증 플러그인을 사용하려면 다음 단계에 있는 MySQL 서버에 플러그인을 설치해야 합니다. 도커 컨테이너. 이는 다음 단계에 따라 수행할 수 있습니다.

docker cp auth_plugin.so mysql-container:/usr/lib/mysql/plugin/
로그인 후 복사

이 명령은 플러그인 파일 auth_plugin.so를 컨테이너의 /usr/lib/mysql/plugin/ 디렉터리에 복사합니다.

  1. 플러그인 활성화

그런 다음 MySQL 구성 파일에서 플러그인을 활성화해야 합니다. 다음 명령을 사용하여 구성 파일을 수정할 수 있습니다.

docker exec -it mysql-container bash
vi /etc/mysql/my.cnf
로그인 후 복사

인증 플러그인이 활성화된 섹션에 다음 줄을 추가해야 합니다.

[mysqld]
plugin-load = auth_plugin.so
로그인 후 복사
  1. Create user

MySQL 터미널에서 다음 줄을 생성해야 합니다. 플러그인 기반 사용자는 다음 명령을 통해 수행할 수 있습니다.

CREATE USER 'newuser'@'%' IDENTIFIED WITH auth_plugin AS 'cred';
로그인 후 복사

여기서 'newuser'는 새 사용자의 사용자 이름이고 '%'는 사용자가 모든 IP 주소에서 액세스할 수 있음을 의미하며 ' cred'는 플러그인 사용자 사용 시 검증에 사용되는 자격 증명 암호화 문자열입니다.

  1. 새 사용자 승인

마찬가지로 MySQL 터미널에서 다음 명령을 사용하여 새 사용자에게 권한을 부여해야 합니다.

GRANT ALL PRIVILEGES ON *.* TO 'newuser'@'%';
로그인 후 복사
로그인 후 복사

이 명령은 새 사용자에게 모든 데이터베이스와 테이블에 대한 액세스 권한을 부여합니다.

  1. 권한 새로 고침

마지막으로 권한을 새로 고쳐야 합니다.

FLUSH PRIVILEGES;
로그인 후 복사
로그인 후 복사

이제 플러그인 기반 사용자가 성공적으로 생성 및 승인되었으며 해당 자격 증명을 사용하여 외부에서 MySQL 컨테이너에 액세스할 수 있습니다.

요약

Docker 컨테이너에서 MySQL 인증 실패는 액세스 거부 등의 문제로 이어질 수 있습니다. 이 기사에서는 비밀번호 기반 인증과 인증 플러그인 기반 인증이라는 두 가지 MySQL 사용자 인증 방법을 소개합니다. 어떤 방법을 사용하든 외부에서 컨테이너 내부의 MySQL 서버에 접근하기 위해서는 사용자 권한을 올바르게 설정해야 한다.

위 내용은 docker 컨테이너 mysql 인증이 실패하는 경우 수행할 작업의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!

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