Docker安装MySQL示例

本文详细介绍了使用Docker部署MySQL数据库的过程,包括错误的启动方式及其解决办法,正确的启动配置,以及如何进行端口映射。同时,还分享了几个高级操作技巧,如配置文件的自定义挂载和参数设置。

安装MySQL示例

```shell
docker pull mysql
```

 

错误的启动

```shell
[root@localhost ~]# docker run --name mysql01 -d mysql
42f09819908bb72dd99ae19e792e0a5d03c48638421fa64cce5f8ba0f40f5846

mysql退出了
[root@localhost ~]# docker ps -a
CONTAINER ID        IMAGE               COMMAND                  CREATED             STATUS                           PORTS               NAMES
42f09819908b        mysql               "docker-entrypoint.sh"   34 seconds ago      Exited (1) 33 seconds ago                            mysql01
538bde63e500        tomcat              "catalina.sh run"        About an hour ago   Exited (143) About an hour ago                       compassionate_
goldstine
c4f1ac60b3fc        tomcat              "catalina.sh run"        About an hour ago   Exited (143) About an hour ago                       lonely_fermi
81ec743a5271        tomcat              "catalina.sh run"        About an hour ago   Exited (143) About an hour ago                       sick_ramanujan


//错误日志
[root@localhost ~]# docker logs 42f09819908b
error: database is uninitialized and password option is not specified
  You need to specify one of MYSQL_ROOT_PASSWORD, MYSQL_ALLOW_EMPTY_PASSWORD and MYSQL_RANDOM_ROOT_PASSWORD;这个三个参数必须指定一个
```

正确的启动

```shell
[root@localhost ~]# docker run --name mysql01 -e MYSQL_ROOT_PASSWORD=123456 -d mysql
b874c56bec49fb43024b3805ab51e9097da779f2f572c22c695305dedd684c5f
[root@localhost ~]# docker ps
CONTAINER ID        IMAGE               COMMAND                  CREATED             STATUS              PORTS               NAMES
b874c56bec49        mysql               "docker-entrypoint.sh"   4 seconds ago       Up 3 seconds        3306/tcp            mysql01
```

做了端口映射

```shell
[root@localhost ~]# docker run -p 3306:3306 --name mysql02 -e MYSQL_ROOT_PASSWORD=123456 -d mysql
ad10e4bc5c6a0f61cbad43898de71d366117d120e39db651844c0e73863b9434
[root@localhost ~]# docker ps
CONTAINER ID        IMAGE               COMMAND                  CREATED             STATUS              PORTS                    NAMES
ad10e4bc5c6a        mysql               "docker-entrypoint.sh"   4 seconds ago       Up 2 seconds        0.0.0.0:3306->3306/tcp   mysql02
```

 

几个其他的高级操作

```
docker run --name mysql03 -v /conf/mysql:/etc/mysql/conf.d -e MYSQL_ROOT_PASSWORD=my-secret-pw -d mysql:tag
把主机的/conf/mysql文件夹挂载到 mysqldocker容器的/etc/mysql/conf.d文件夹里面
改mysql的配置文件就只需要把mysql配置文件放在自定义的文件夹下(/conf/mysql)

docker run --name some-mysql -e MYSQL_ROOT_PASSWORD=my-secret-pw -d mysql:tag --character-set-server=utf8mb4 --collation-server=utf8mb4_unicode_ci
指定mysql的一些配置参数

### 在 Windows 上通过 Docker 安装 MySQL 要在 Windows 系统上使用 Docker 安装并运行 MySQL 数据库,可以按照以下方法操作: #### 准备工作 确保已经安装Docker Desktop 并启动服务。如果尚未安装,请先完成安装配置[^1]。 #### 拉取 MySQL 镜像 可以通过 `docker pull` 命令拉取官方的 MySQL 镜像。以下是两种方式: - **拉取最新版本** 使用以下命令获取最新的 MySQL 版本镜像: ```bash docker pull mysql ``` - **指定版本号** 如果需要特定版本(例如 MySQL 8.0 或其他),则可以在镜像名称后加上冒号和版本号: ```bash docker pull mysql:8.0 ``` 此部分描述来源于参考资料[^2]。 #### 启动 MySQL 容器 创建并启动一个基于所下载镜像的容器实例。下面是一个完整的示例命令,其中包含了环境变量设置、端口映射以及数据卷挂载等功能: ```bash docker run --name=mysql-container \ -e MYSQL_ROOT_PASSWORD=your_password_here \ -d -p 3306:3306 \ -v D:\mysql\data:/var/lib/mysql \ mysql:5.7 ``` 上述命令解释如下: - `--name=mysql-container`: 设置容器名为 `mysql-container`。 - `-e MYSQL_ROOT_PASSWORD=your_password_here`: 将根用户的密码设为自定义值 `your_password_here`。 - `-d`: 表明以后台模式运行该容器。 - `-p 3306:3306`: 映射主机上的 3306 端口至容器内的相同端口号。 - `-v D:\mysql\data:/var/lib/mysql`: 把本地路径 `D:\mysql\data` 绑定到容器中的 `/var/lib/mysql` 路径用于持久化存储数据库文件。 - `mysql:5.7`: 利用已拉取下来的 MySQL 5.7 版本来初始化新容器。 这部分内容综合参考了资料[^3]。 #### 进入 MySQL 控制台测试连接 为了确认安装成功与否,可尝试进入正在运行的 MySQL 实例内部执行一些基础查询语句来验证其功能正常性。具体做法如下所示: ```bash docker exec -it mysql-container mysql -uroot -pyour_password_here ``` 一旦登录成功,则表明整个部署流程顺利完成。 #### 使用 Navicat 工具远程管理 MySQL 对于图形界面偏好者来说,还可以借助第三方软件比如 Navicat 来实现更便捷的数据管理和维护作业。只需提供相应的服务器地址(localhost或者IP),用户名(root), 密码(your_password_here)即可建立链接。 ```python # Python 示例代码片段展示如何利用 pymysql 库访问刚才搭建好的 MySQL 数据源 import pymysql.cursors connection = pymysql.connect( host='localhost', user='root', password='your_password_here', database='testdb' ) try: with connection.cursor() as cursor: sql = 'SELECT * FROM users LIMIT 10;' cursor.execute(sql) result = cursor.fetchall() finally: connection.close() print(result) ``` 以上脚本仅作为演示用途,在实际开发环境中应当妥善保管敏感信息如账号凭证等。
评论
成就一亿技术人!
拼手气红包6.0元
还能输入1000个字符
 
红包 添加红包
表情包 插入表情
 条评论被折叠 查看
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值