• 企业400电话
  • 微网小程序
  • AI电话机器人
  • 电商代运营
  • 全 部 栏 目

    企业400电话 网络优化推广 AI电话机器人 呼叫中心 网站建设 商标✡知产 微网小程序 电商运营 彩铃•短信 增值拓展业务
    浅析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 即可解决这个问题,它还是和密码加密方式有关。

    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无法访问的问题,希望对大家有所帮助,如果大家有任何疑问请给我留言,小编会及时回复大家的。在此也非常感谢大家对脚本之家网站的支持!

    上一篇:Nginx location匹配规则的方法示例
    下一篇:nginx配置返回文本或json的方法
  • 相关文章
  • 

    © 2016-2020 巨人网络通讯 版权所有

    《增值电信业务经营许可证》 苏ICP备15040257号-8

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