gpt4 book ai didi

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

转载 作者:qq735679552 更新时间:2022-09-27 22:32:09 29 4
gpt4 key购买 nike

CFSDN坚持开源创造价值,我们致力于搭建一个资源共享平台,让每一个IT人在这里找到属于你的精彩世界.

这篇CFSDN的博客文章浅析docker-compose部署mysql无法访问的问题由作者收集整理,如果你对这篇文章有兴趣,记得点赞哟.

什么是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 即可解决这个问题,它还是和密码加密方式有关.

?
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
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无法访问的问题,希望对大家有所帮助,如果大家有任何疑问请给我留言,小编会及时回复大家的。在此也非常感谢大家对我网站的支持! 。

原文链接:http://www.cnblogs.com/lori/p/9845648.html 。

最后此篇关于浅析docker-compose部署mysql无法访问的问题的文章就讲到这里了,如果你想了解更多关于浅析docker-compose部署mysql无法访问的问题的内容请搜索CFSDN的文章或继续浏览相关文章,希望大家以后支持我的博客! 。

29 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com