A brief analysis of the problem of mysql being inaccessible when deployed with docker-compose

A brief analysis of the problem of mysql being inaccessible when deployed with docker-compose

What is Docker-Compose

The Compose project originated from the previous fig project. It is written in Python and has a high degree of compatibility with docker/swarm. Compose is a tool for orchestrating Docker containers. It defines and runs multi-container applications. Multiple containers can be started with one command. Using Docker Compose, you no longer need to use shell scripts to start containers. Compose manages multiple Docker containers through a configuration file. In the configuration file, all containers are defined through services, and then the docker-compose script is used to start, stop, and restart the application, the services in the application, and the containers of all dependent services. It is very suitable for scenarios where multiple containers are combined for development. The default template file for docker-compose is docker-compose.yml, in which each service defined must be automatically built by specifying an image through the image instruction or the build instruction (Dockerfile is required).

Using Compose basically involves the following three steps:

1. Define your application environment in a Dockerfile so that it can be replicated anywhere.
2. Define the services that make up your application in docker-compose.yml so that they can run together in an isolated environment.
3. Finally, run docker-compose up and Compose will start and run the entire application.

Let's look at the problem that mysql cannot be accessed when deployed by docker-compose.

This problem has troubled me for a long time. After using docker-compose to deploy mysql, after the container is built, it can be accessed using mysql -u root -p , but it cannot be connected using the sql client. So I searched for a lot of information on Google and finally found that adding command: --default-authentication-plugin=mysql_native_password can solve this problem. It is still related to the password encryption method.

version: "3.3"
services:
 Redis:
 image: sameersbn/redis:latest
 ports:
  - "6379:6379"
 volumes:
  - redis_data:/var/lib/redis
 restart: always
 mysql:
  image: mysql:latest
  restart: always
  command: --default-authentication-plugin=mysql_native_password #This line of code solves the problem of inaccessible networks:
   -dev
  ports:
   - "3306:3306"
  environment:
   MYSQL_ROOT_PASSWORD: abc123
   MYSQL_USER: 'test'
   MYSQL_PASS: 'test'
  volumes:
   -mysql_data:/var/lib/mysql
networks:
 dev:
  driver: bridge
volumes:
 redis_data:
 mysql_data:

Summarize

The above is the problem of inaccessible mysql deployment using docker-compose that I introduced to you. I hope it will be helpful to you. If you have any questions, please leave me a message and I will reply to you in time. I would also like to thank everyone for their support of the 123WORDPRESS.COM website!

You may also be interested in:
  • Explain the deployment and configuration of Clickhouse Docker cluster with examples
  • Detailed explanation of docker-compose deployment php project example
  • Docker-compose one-click deployment of gitlab Chinese version method steps
  • How to deploy gitlab using Docker-compose
  • Tutorial on how to quickly deploy clickhouse using docker-compose

<<:  Based on vue-simple-uploader, encapsulate the global upload plug-in function of file segment upload, instant upload and breakpoint resume

>>:  Instructions for recovering data after accidental deletion of MySQL database

Recommend

How to solve the DOS window garbled problem in MySQL

The garbled code problem is as follows: The reaso...

The actual process of encapsulating axios in the project

Table of contents Preface Benefits of axios encap...

How to quickly modify the host attribute of a MySQL user

When you log in to MySQL remotely, the account yo...

GDB debugging MySQL actual combat source code compilation and installation

Download source code git clone https://github.com...

Tomcat server security settings method

Tomcat is an HTTP server that is the official ref...

A record of pitfalls in JS regular matching

I recently discovered a pitfall in regular expres...

jQuery plugin to achieve code rain effect

This article shares the specific code of the jQue...

SQL implementation LeetCode (176. Second highest salary)

[LeetCode] 176. Second Highest Salary Write a SQL...

Install and configure ssh in CentOS7

1. Install openssh-server yum install -y openssl ...

Case study of dynamic data binding of this.$set in Vue

I feel that the explanation of this.$set on the I...

Detailed explanation of MySQL replication principles and practical applications

This article uses examples to illustrate the prin...

Modify the default scroll bar style in the front-end project (summary)

I have written many projects that require changin...