浅析docker-compose部署mysql无法访问的问题
什么是Docker-Compose
Compose项目来源于之前的fig项目,使用python语言编写,与docker/swarm配合度很高。Compose是Docker容器进行编排的工具,定义和运行多容器的应用,可以一条命令启动多个容器,使用DockerCompose不再需要使用shell脚本来启动容器。Compose通过一个配置文件来管理多个Docker容器,在配置文件中,所有的容器通过services来定义,然后使用docker-compose脚本来启动,停止和重启应用,和应用中的服务以及所有依赖服务的容器,非常适合组合使用多个容器进行开发的场景。docker-compose默认的模板文件是docker-compose.yml,其中定义的每个服务都必须通过image指令指定镜像或build指令(需要Dockerfile)来自动构建。
使用Compose基本会有如下三步流程:
1.在Dockfile中定义你的应用环境,使其可以在任何地方复制。
2.在docker-compose.yml中定义组成应用程序的服务,以便它们可以在隔离的环境中一起运行。
3.最后,运行dcoker-composeup,Compose将启动并运行整个应用程序。
下面看下docker-compose部署mysql无法访问的问题。
这个问题困扰了我很久,当使用docker-compose部署mysql之后,进行容器后,使用mysql-uroot-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无法访问的问题,希望对大家有所帮助,如果大家有任何疑问请给我留言,小编会及时回复大家的。在此也非常感谢大家对毛票票网站的支持!