浅析docker-compose部署mysql无法访问的问题-创新互联
什么是Docker-Compose
成都创新互联公司基于成都重庆香港及美国等地区分布式IDC机房数据中心构建的电信大带宽,联通大带宽,移动大带宽,多线BGP大带宽租用,是为众多客户提供专业成都服务器托管报价,主机托管价格性价比高,为金融证券行业服务器托管,ai人工智能服务器托管提供bgp线路100M独享,G口带宽及机柜租用的专业成都idc公司。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:
另外有需要云服务器可以了解下创新互联scvps.cn,海内外云服务器15元起步,三天无理由+7*72小时售后在线,公司持有idc许可证,提供“云服务器、裸金属服务器、高防服务器、香港服务器、美国服务器、虚拟主机、免备案服务器”等云主机租用服务以及企业上云的综合解决方案,具有“安全稳定、简单易用、服务可用性高、性价比高”等特点与优势,专为企业上云打造定制,能够满足用户丰富、多元化的应用场景需求。
网页名称:浅析docker-compose部署mysql无法访问的问题-创新互联
浏览路径:http://scyanting.com/article/dpedis.html