search
HomeOperation and MaintenanceDockerWhat to do if docker container mysql authorization fails

In recent years, Docker container technology has been more and more widely used in various application scenarios. It provides a lightweight, rapid deployment and management method, making application development and operation and maintenance more efficient. When using Docker container technology, we may encounter some problems, such as MySQL authorization failure in the container. This article explains how to resolve this issue.

MySQL authorization failure in the Docker container may lead to issues such as access denial. This situation is usually caused by user authorization not being set correctly in the container. In Docker containers, there are two main methods for MySQL user authorization: password-based authorization and authentication plug-in-based authorization.

Password-based authorization

In password-based authorization, MySQL users need to create an account password in the container and use these credentials for authorization when accessing the container from the outside. You can create a MySQL account through the following steps:

  1. Enter the MySQL server in the Docker container

First, we need to enter the MySQL server in the container, which can be done with the following command Implementation:

docker exec -it mysql-container mysql -u root -p

This command will start an interactive terminal and connect to the MySQL server in the container.

  1. Create a new user

In the MySQL terminal, you can use the following command to create a new user:

CREATE USER 'newuser'@'%' IDENTIFIED BY 'password';

Where, 'newuser' is the new user's Username, '%' means that the user can be accessed from any IP address, 'password' is the password of the new user.

  1. Authorize new users

Similarly, in the MySQL terminal, you can use the following command to authorize new users:

GRANT ALL PRIVILEGES ON *.* TO 'newuser'@'%';

This command will grant new users Access to all databases and tables.

  1. Refresh Permissions

Finally, in order for the changes to take effect, we need to refresh the permissions:

FLUSH PRIVILEGES;

Now, the new user has been successfully created and authorized, The MySQL container can be accessed externally using its username and password.

Authentication plug-in-based authorization

In authentication plug-in-based authorization, the MySQL server uses external authentication plug-ins for user authentication, such as using SSL certificates, Kerberos, etc., for more secure Authenticate the user. In a Docker container, the authentication plugin can be set up using the following steps:

  1. Install the plugin into the MySQL container

In order to use the authentication plugin, we need to install the plugin into the MySQL server in the Docker container. This can be achieved by following these steps:

docker cp auth_plugin.so mysql-container:/usr/lib/mysql/plugin/

This command copies the plugin file auth_plugin.so to the /usr/lib/mysql/plugin/ directory in the container.

  1. Enable plugin

Then, we need to enable the plugin in the MySQL configuration file. The configuration file can be modified with the following command:

docker exec -it mysql-container bash
vi /etc/mysql/my.cnf

In the section that enables the authentication plug-in, you need to add the following lines:

[mysqld]
plugin-load = auth_plugin.so
  1. Create user

In In the MySQL terminal, we need to create a user based on the plug-in. This can be achieved through the following command:

CREATE USER 'newuser'@'%' IDENTIFIED WITH auth_plugin AS 'cred';

Where, 'newuser' is the user name of the new user, and '%' means that the user can access from any IP address For access, 'cred' is a credential encrypted string used to authenticate the user when using the plugin.

  1. Authorize new users

Similarly, in the MySQL terminal, we need to use the following command to authorize the new user:

GRANT ALL PRIVILEGES ON *.* TO 'newuser'@'%';

This command will grant the new user User access to all databases and tables.

  1. Refresh permissions

Finally, we need to refresh permissions:

FLUSH PRIVILEGES;

Now, the plug-in-based user has been successfully created and authorized, and can be used Its credentials are used to access the MySQL container from outside.

Summary

In a Docker container, MySQL authorization failure may cause problems such as access denial. This article introduces two MySQL user authorization methods: password-based authorization and authentication plug-in-based authorization. Regardless of which method is used, user authorization needs to be set up correctly to access the MySQL server in the container from the outside.

The above is the detailed content of What to do if docker container mysql authorization fails. For more information, please follow other related articles on the PHP Chinese website!

Statement
The content of this article is voluntarily contributed by netizens, and the copyright belongs to the original author. This site does not assume corresponding legal responsibility. If you find any content suspected of plagiarism or infringement, please contact admin@php.cn
How do I deploy applications to a Docker Swarm cluster?How do I deploy applications to a Docker Swarm cluster?Mar 17, 2025 pm 04:20 PM

The article details deploying applications to Docker Swarm, covering preparation, deployment steps, and security measures during the process.

What are Kubernetes pods, deployments, and services?What are Kubernetes pods, deployments, and services?Mar 17, 2025 pm 04:25 PM

The article explains Kubernetes' pods, deployments, and services, detailing their roles in managing containerized applications. It discusses how these components enhance scalability, stability, and communication within applications.(159 characters)

How do I scale applications in Kubernetes?How do I scale applications in Kubernetes?Mar 17, 2025 pm 04:28 PM

The article discusses scaling applications in Kubernetes using manual scaling, HPA, VPA, and Cluster Autoscaler, and provides best practices and tools for monitoring and automating scaling.

How do I implement rolling updates in Docker Swarm?How do I implement rolling updates in Docker Swarm?Mar 17, 2025 pm 04:23 PM

The article discusses implementing rolling updates in Docker Swarm to update services without downtime. It covers updating services, setting update parameters, monitoring progress, and ensuring smooth updates.

How do I manage deployments in Kubernetes?How do I manage deployments in Kubernetes?Mar 17, 2025 pm 04:27 PM

The article discusses managing Kubernetes deployments, focusing on creation, updates, scaling, monitoring, and automation using various tools and best practices.

How do I manage services in Docker Swarm?How do I manage services in Docker Swarm?Mar 17, 2025 pm 04:22 PM

Article discusses managing services in Docker Swarm, focusing on creation, scaling, monitoring, and updating without downtime.

How to Implement Rate Limiting and Resource Quotas in Docker Containers?How to Implement Rate Limiting and Resource Quotas in Docker Containers?Mar 12, 2025 pm 06:07 PM

This article details implementing rate limiting and resource quotas in Docker. It covers CPU, memory, and I/O limits using cgroups, emphasizing best practices for preventing resource exhaustion. Network rate limiting, requiring external tools like

What Are the Best Ways to Optimize Docker for Low-Latency Applications?What Are the Best Ways to Optimize Docker for Low-Latency Applications?Mar 14, 2025 pm 02:00 PM

The article discusses strategies to optimize Docker for low-latency applications, focusing on minimizing image size, using lightweight base images, and adjusting resource allocation and network settings.

See all articles

Hot AI Tools

Undresser.AI Undress

Undresser.AI Undress

AI-powered app for creating realistic nude photos

AI Clothes Remover

AI Clothes Remover

Online AI tool for removing clothes from photos.

Undress AI Tool

Undress AI Tool

Undress images for free

Clothoff.io

Clothoff.io

AI clothes remover

AI Hentai Generator

AI Hentai Generator

Generate AI Hentai for free.

Hot Article

R.E.P.O. Energy Crystals Explained and What They Do (Yellow Crystal)
3 weeks agoBy尊渡假赌尊渡假赌尊渡假赌
R.E.P.O. Best Graphic Settings
3 weeks agoBy尊渡假赌尊渡假赌尊渡假赌
R.E.P.O. How to Fix Audio if You Can't Hear Anyone
3 weeks agoBy尊渡假赌尊渡假赌尊渡假赌

Hot Tools

EditPlus Chinese cracked version

EditPlus Chinese cracked version

Small size, syntax highlighting, does not support code prompt function

ZendStudio 13.5.1 Mac

ZendStudio 13.5.1 Mac

Powerful PHP integrated development environment

VSCode Windows 64-bit Download

VSCode Windows 64-bit Download

A free and powerful IDE editor launched by Microsoft

SublimeText3 Mac version

SublimeText3 Mac version

God-level code editing software (SublimeText3)

Dreamweaver Mac version

Dreamweaver Mac version

Visual web development tools