• 售前

  • 售后

热门帖子
入门百科

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

[复制链接]
浪子孤女 显示全部楼层 发表于 2021-10-25 19:22:49 |阅读模式 打印 上一主题 下一主题
什么是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无法访问的问题。
这个问题困扰了我很久,当使用
  1. docker-compose
复制代码
部署mysql之后,举行容器后,使用
  1. mysql -u root -p
复制代码
是可以访问的,而使用sql客户端却是无法毗连的,于是在google上找了很多资料,终于被我发现,添加
  1. command: --default-authentication-plugin=mysql_native_password
复制代码
即可办理这个问题,它还是和密码加密方式有关。
  1. version: "3.3"
  2. services:
  3. Redis:
  4. image: sameersbn/redis:latest
  5. ports:
  6.   - "6379:6379"
  7. volumes:
  8.   - redis_data:/var/lib/redis
  9. restart: always
  10. mysql:
  11.   image: mysql:latest
  12.   restart: always
  13.   command: --default-authentication-plugin=mysql_native_password #这行代码解决无法访问的问题
  14.   networks:
  15.    - dev
  16.   ports:
  17.    - "3306:3306"
  18.   environment:
  19.    MYSQL_ROOT_PASSWORD: abc123
  20.    MYSQL_USER: 'test'
  21.    MYSQL_PASS: 'test'
  22.   volumes:
  23.    - mysql_data:/var/lib/mysql
  24. networks:
  25. dev:
  26.   driver: bridge
  27. volumes:
  28. redis_data:
  29. mysql_data:
复制代码
总结
以上所述是小编给各人介绍的docker-compose部署mysql无法访问的问题,希望对各人有所帮助,假如各人有任何疑问请给我留言,小编会实时复兴各人的。在此也非常感谢各人对脚本之家网站的支持!

帖子地址: 

回复

使用道具 举报

分享
推广
火星云矿 | 预约S19Pro,享500抵1000!
您需要登录后才可以回帖 登录 | 立即注册

本版积分规则

草根技术分享(草根吧)是全球知名中文IT技术交流平台,创建于2021年,包含原创博客、精品问答、职业培训、技术社区、资源下载等产品服务,提供原创、优质、完整内容的专业IT技术开发社区。
  • 官方手机版

  • 微信公众号

  • 商务合作