欢迎您访问程序员文章站本站旨在为大家提供分享程序员计算机编程知识!
您现在的位置是: 首页  >  网络运营

浅析docker-compose部署mysql无法访问的问题

程序员文章站 2022-09-24 12:26:33
什么是docker-compose compose项目来源于之前的fig项目,使用python语言编写,与docker/swarm配合度很高。compose 是 dock...

什么是docker-compose

compose项目来源于之前的fig项目,使用python语言编写,与docker/swarm配合度很高。compose 是 docker 容器进行编排的工具,定义和运行多容器的应用,可以一条命令启动多个容器,使用docker compose不再需要使用shell脚本来启动容器。 compose 通过一个配置文件来管理多个docker容器,在配置文件中,所有的容器通过services来定义,然后使用docker-compose脚本来启动,停止和重启应用,和应用中的服务以及所有依赖服务的容器,非常适合组合使用多个容器进行开发的场景。docker-compose默认的模板文件是 docker-compose.yml,其中定义的每个服务都必须通过 image 指令指定镜像或 build 指令(需要 dockerfile)来自动构建。

使用 compose 基本会有如下三步流程:

1.在 dockfile 中定义你的应用环境,使其可以在任何地方复制。
2.在 docker-compose.yml 中定义组成应用程序的服务,以便它们可以在隔离的环境中一起运行。
3.最后,运行dcoker-compose up,compose 将启动并运行整个应用程序。

下面看下docker-compose部署mysql无法访问的问题。

这个问题困扰了我很久,当使用docker-compose部署mysql之后,进行容器后,使用mysql -u root -p 是可以访问的,而使用sql客户端却是无法连接的,于是在google上找了很多资料,终于被我发现,添加 command: --default-authentication-plugin=mysql_native_password 即可解决这个问题,它还是和密码加密方式有关。

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 #这行代码解决无法访问的问题
  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:

总结

以上所述是小编给大家介绍的docker-compose部署mysql无法访问的问题,希望对大家有所帮助