如何连接docker中的MySQL容器

 更新时间:2022年11月30日 10:00:46   作者:Villero  
这篇文章主要介绍了如何连接docker中的MySQL容器问题,具有很好的参考价值,希望对大家有所帮助。如有错误或未考虑完全的地方,望不吝赐教

连接docker中MySQL容器

我以gin web项目为例,演示在容器中运行时mysql的相关配置。

1. 登入MySQL修改访问权限并刷新权限。

update user set host = '%' where user = 'root';

grant all on *.* to admin@'%' identified by 'root' with grant option; 

允许所有用户拿着密码“root”去访问。

flush privileges; 刷新权限

2. 修改密码认证配置。

由于docker上MySQL的版本是8.0.19


而我本地MySQL是5.7两者的认证方式不一样(前者是caching_sha2_password,后者是my_native_password)因此我们对它进行修改。

我修改了所有用户的密码认证配置后才起效。

3. 至此,我已经可以用本地的数据库图形化界面连接docker中的MySQL容器。

但是在关联运行gin_blog_docker_scrach时数据库一直拒绝连接:

最后,我查阅资料得知:

在go应用中使用localhost或则使用127.0.0.1地址都是无法找msyql服务的,因为该地址被解析成了当前go应用docker容器中的ip地址;

修改应用配置中的ip地址:

再次运行容器:

无错发生。

大功告成!

docker中MySQL容器启动

一 下拉镜像

docker pull mysql:5.7

docker images查看镜像

二 运行镜像

1. 运行镜像,如果不挂载路径运行执行以下就可以

docker run -id --name mysql  -p 3306:3306 -e MYSQL_ROOT_PASSWORD=123456 mysql:5.7
  • -i:表示创建并运行容器
  • -d:表示后台运行
  • -p:映射端口,相对于访问宿主机ip:3306 就是访问的mysql容器
  • -e:配置mysql,这里设置了一下root密码,当然也可以也又其它设置选项,在这没用到
  • mysql:5.7:镜像名和版本,如果这个镜像不存在会自动下载镜像

2. 挂载路径

挂载路径的好处一是方便我们修改和查看,比如修改mysql配置文件my.cnf,不挂载的话需要进入容器然后在修改,my.cnf挂载出来后可以直接在宿主机查看,日志文件也是同样的,第二个好处是防止暑假丢失,如果容器不小心停止删除了数据库中的所有数据就丢失了。

docker run  -id --name mysql 
-v /docker/mysql/log/:/var/log  
-v /docker/mysql/data/:/var/lib/mysql  
-v /docker/mysql/my.cnf:/etc/my.cnf 
-p 3306:3306 -e MYSQL_ROOT_PASSWORD=123456 mysql:5.7

用了三个-v,分别挂载出来日志 mysql数据和my.cnf,-v 宿主机文件 容器中文件

直接运行上面命令可能启动失败,需要在宿主机中先创建一个my.cnf,即在宿主机docker/mysql中床新建一个文件my.cnf文件内容为:

[mysqld]
# join_buffer_size = 128M
# sort_buffer_size = 2M
# read_rnd_buffer_size = 2M
skip-host-cache
skip-name-resolve
datadir=/var/lib/mysql
socket=/var/run/mysqld/mysqld.sock
secure-file-priv=/var/lib/mysql-files
user=mysql
 
# Disabling symbolic-links is recommended to prevent assorted security risks
symbolic-links=0
 
#log-error=/var/log/mysqld.log
pid-file=/var/run/mysqld/mysqld.pid
[client]
socket=/var/run/mysqld/mysqld.sock
 
!includedir /etc/mysql/conf.d/
!includedir /etc/mysql/mysql.conf.d/

docker ps查看运行的容器

使用可视化工具连接mysql测试

以上为个人经验,希望能给大家一个参考,也希望大家多多支持脚本之家。

相关文章

  • 利用Docker部署PostgreSQL 12.4主从方式

    利用Docker部署PostgreSQL 12.4主从方式

    这篇文章主要介绍了利用Docker部署PostgreSQL 12.4主从方式,具有很好的参考价值,希望对大家有所帮助,如有错误或未考虑完全的地方,望不吝赐教
    2023-12-12
  • 详解Docker 下开发 hyperf 完整使用示例

    详解Docker 下开发 hyperf 完整使用示例

    这篇文章主要介绍了详解Docker 下开发 hyperf 完整使用示例,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友们下面随着小编来一起学习学习吧
    2020-01-01
  • Docker数据卷和挂载目录的使用

    Docker数据卷和挂载目录的使用

    docker 在容器中管理数据主要有两种方式,包括数据卷和挂载主机目录,本文主要介绍了Docker数据卷和挂载目录的使用,具有一定的参考价值,感兴趣的可以了解一下
    2024-04-04
  • k8s部署docker容器的实现

    k8s部署docker容器的实现

    这篇文章主要介绍了k8s部署docker容器的实现,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友们下面随着小编来一起学习学习吧
    2020-06-06
  • Jenkins整合Docker实现CICD自动化部署的详细过程(若依项目)

    Jenkins整合Docker实现CICD自动化部署的详细过程(若依项目)

    本文介绍了如何使用Jenkins和Docker实现CI/CD自动化部署,文章介绍了环境准备,包括Jenkins、Docker、JDK、Node和Maven,然后讨论了如何配置GitLab环境并利用Webhooks实现代码的自动拉取和部署,最后,展示了如何部署前后端分离的项目,并通过实际操作验证了整个流程的有效性
    2024-10-10
  • Docker中的容器网络以及其配置说明

    Docker中的容器网络以及其配置说明

    这篇文章主要介绍了Docker中的容器网络以及其配置说明,具有很好的参考价值,希望对大家有所帮助,如有错误或未考虑完全的地方,望不吝赐教
    2025-04-04
  • Docker 查看镜像信息的方法

    Docker 查看镜像信息的方法

    这篇文章主要介绍了Docker 查看镜像信息的方法,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友们下面随着小编来一起学习学习吧
    2020-12-12
  • Docker镜像导出与导入与拷贝实例分析

    Docker镜像导出与导入与拷贝实例分析

    在本篇文章里小编给大家整理的是关于Docker镜像导出与导入与拷贝实例分析,有需要的朋友们可以参考下。
    2020-02-02
  • 如何Docker化Python Django应用程序

    如何Docker化Python Django应用程序

    今天小编就为大家分享一篇关于如何Docker化Python Django应用程序的文章,小编觉得内容挺不错的,现在分享给大家,具有很好的参考价值,需要的朋友一起跟随小编来看看吧
    2018-09-09
  • 安装Docker Desktop报错WSL 2 installation is incomplete的问题(解决报错)

    安装Docker Desktop报错WSL 2 installation is incomplete的问题(解决报错)

    这篇文章主要介绍了安装Docker Desktop报错WSL 2 installation is incomplete的问题,解决方法很简单只需我们自己手动更新一下,我们根据提示去微软官网下载最新版的wsl2安装后即可正常打开,需要的朋友可以参考下
    2021-06-06

最新评论