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

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

Apr 18, 2023 am 09:47 AM

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

본 웹사이트의 성명
본 글의 내용은 네티즌들의 자발적인 기여로 작성되었으며, 저작권은 원저작자에게 있습니다. 본 사이트는 이에 상응하는 법적 책임을 지지 않습니다. 표절이나 침해가 의심되는 콘텐츠를 발견한 경우 admin@php.cn으로 문의하세요.

핫 AI 도구

Undresser.AI Undress

Undresser.AI Undress

사실적인 누드 사진을 만들기 위한 AI 기반 앱

AI Clothes Remover

AI Clothes Remover

사진에서 옷을 제거하는 온라인 AI 도구입니다.

Undress AI Tool

Undress AI Tool

무료로 이미지를 벗다

Clothoff.io

Clothoff.io

AI 옷 제거제

AI Hentai Generator

AI Hentai Generator

AI Hentai를 무료로 생성하십시오.

뜨거운 도구

메모장++7.3.1

메모장++7.3.1

사용하기 쉬운 무료 코드 편집기

SublimeText3 중국어 버전

SublimeText3 중국어 버전

중국어 버전, 사용하기 매우 쉽습니다.

스튜디오 13.0.1 보내기

스튜디오 13.0.1 보내기

강력한 PHP 통합 개발 환경

드림위버 CS6

드림위버 CS6

시각적 웹 개발 도구

SublimeText3 Mac 버전

SublimeText3 Mac 버전

신 수준의 코드 편집 소프트웨어(SublimeText3)

Docker exec를 사용하여 Docker 컨테이너에서 명령을 실행하는 방법 Docker exec를 사용하여 Docker 컨테이너에서 명령을 실행하는 방법 Mar 05, 2025 pm 03:42 PM

이 기사에서는 Docker Exec 명령을 사용하여 실행중인 Docker 컨테이너 내에서 명령을 실행하는 방법을 설명합니다. 기본 구문, 옵션 (예 : 인터랙티브 사용 및 분리 모드의 경우 -D), 쉘 액세스, 일반적인 사용 사례 (디버깅, 관리

Docker의 Docker는 무엇입니까? Docker는 무엇입니까? Docker의 Docker는 무엇입니까? Docker는 무엇입니까? Mar 05, 2025 pm 03:49 PM

이 기사에서는 컨테이너화 플랫폼 인 Docker가 응용 프로그램 구축, 운송 및 달리기를 단순화하는 것을 설명합니다. 앱과 고립 된 컨테이너로 의존성을 포장하여 "내 컴퓨터에서 작동하는"문제를 해결하여 CON을 개선합니다.

Docker는 환경 또는 소프트웨어입니다 Docker는 환경 또는 소프트웨어입니다 Mar 05, 2025 pm 03:38 PM

이 기사는 Docker를 설명하여 가상 머신과 대조합니다. Docker는 컨테이너화를 사용하여 가벼운 리소스 효율적인 응용 분리를 위해 호스트 OS 커널을 공유합니다. 주요 장점에는 속도, 이식성, 배치 용이성, a

Docker Swarm 클러스터에 응용 프로그램을 어떻게 배포합니까? Docker Swarm 클러스터에 응용 프로그램을 어떻게 배포합니까? Mar 17, 2025 pm 04:20 PM

이 기사는 응용 프로그램을 Docker Swarm에 배포하고 프로세스 중 준비, 배포 단계 및 보안 조치를 다루는 자세한 내용을 자세히 설명합니다.

Docker의 Docker는 무엇입니까? Docker는 무엇입니까? Docker의 Docker는 무엇입니까? Docker는 무엇입니까? Mar 05, 2025 pm 03:46 PM

Docker는 컨테이너화를 통해 응용 프로그램 구축, 운송 및 실행을 단순화합니다. 일관된 개발 환경, 더 빠른주기, 개선 된 협업 및 간소화 된 CI/CD를 제공하여 휴대용, 확장 가능하며 리소스 효율적인 기능을 제공합니다.

Docker의 Docker는 무엇입니까? Docker는 무엇입니까? Docker의 Docker는 무엇입니까? Docker는 무엇입니까? Mar 05, 2025 pm 03:39 PM

이 기사에서는 응용 프로그램 생성, 배포 및 실행을 단순화하는 컨테이너화 플랫폼 인 Docker가 설명합니다. 효율성, 일관성, 자원 활용 및 간소화 된 배포와 같은 Docker의 이점을 강조합니다. 다양한 사용

Kubernetes에서 응용 프로그램을 어떻게 확장합니까? Kubernetes에서 응용 프로그램을 어떻게 확장합니까? Mar 17, 2025 pm 04:28 PM

이 기사는 수동 스케일링, HPA, VPA 및 클러스터 자동 구동기를 사용하여 Kubernetes의 스케일링 응용 프로그램에 대해 설명하며 스케일링 모니터링 및 자동화를위한 모범 사례 및 도구를 제공합니다.

Kubernetes 포드, 배포 및 서비스는 무엇입니까? Kubernetes 포드, 배포 및 서비스는 무엇입니까? Mar 17, 2025 pm 04:25 PM

이 기사는 Kubernetes의 포드, 배포 및 서비스를 설명하여 컨테이너화 된 응용 프로그램 관리의 역할을 자세히 설명합니다. 이러한 구성 요소가 응용 프로그램 내에서 확장 성, 안정성 및 통신을 향상시키는 방법에 대해 설명합니다. (159 자)

See all articles