查看 Docker 容器中 MySQL 版本号。

本文介绍如何在Docker容器中以交互式终端模式登录到MySQL容器实例,并查看其版本号。通过使用docker exec命令结合-it参数,可以打开容器内的bash终端,进一步使用mysql命令连接数据库并显示版本信息。

查看 Docker 容器中 MySQL 版本号。


 # 以交互式终端模式进入 docker 中 mysql 容器的实例。
[root@localhost ~]# docker exec -it mysql_geek /bin/bash

# exec —> 运行容器。
# -i 选项 —> 以交互式命令行模式运行。
# -t 选项 —> 终端
# 		指定 /bin/bash 就是指打开容器后,以 bash 终端命令行模式运行。

root@c80d23a10c46:/# ls
bin   docker-entrypoint-initdb.d  home	 media	proc  sbin  tmp
boot  entrypoint.sh		  lib	 mnt	root  srv   usr
dev   etc				  lib64  opt	run   sys   var

root@c80d23a10c46:/# mysql -uroot -proot
mysql: [Warning] Using a password on the command line interface can be insecure.
Welcome to the MySQL monitor.  Commands end with ; or \g.
Your MySQL connection id is 51
Server version: 8.0.19 MySQL Community Server - GPL

Copyright (c) 2000, 2020, Oracle and/or its affiliates. All rights reserved.

Oracle is a registered trademark of Oracle Corporation and/or its
affiliates. Other names may be trademarks of their respective
owners.

Type 'help;' or '\h' for help. Type '\c' to clear the current input statement.

mysql> 

登录 MySQL 后可以看到版本为 8.0.19

### 如何在Docker查看运行中的MySQL容器版本 要在 Docker查看正在运行的 MySQL 容器的具体版本信息,可以通过多种方法实现。以下是几种常见的操作方式: #### 方法一:进入容器内部执行 SQL 查询 可以使用 `docker exec` 命令进入已启动的 MySQL 容器,并通过 SQL 查询获取版本信息。 ```bash docker exec -it <container_name_or_id> mysql -uroot -p<password> -e "SELECT VERSION();" ``` 此命令会连接到指定的 MySQL 实例并返回其版本号[^1]。如果未设置密码,则可以直接省略 `-p<password>` 部分。 #### 方法二:利用环境变量确认镜像标签 当创建容器时指定了特定版本(如 `mysql:5.7.25`),也可以直接查询容器使用的镜像名称及其标签作为间接验证手段之一。 ```bash docker inspect --format='{{index .Config.Image}}' <container_name_or_id> ``` 这一步骤能够展示当前实例基于哪个具体镜像构建而成,从而推断出大致对应的数据库引擎发行版次序[^3]。 #### 方法三:借助日志文件分析 某些情况下,启动阶段的日志里已经包含了关于服务器软件构成详情的消息记录;因此查阅相关文档可能同样有效果: ```bash docker logs <container_name_or_id> | grep Version ``` 以上三种途径均适用于不同场景下的需求满足情况,请依据实际状况选取合适方案加以运用即可达成目标[^2]。 ```python # 示例 Python 脚本用于演示如何调用 subprocess 模块执行上述 shell 命令 (仅作参考) import subprocess def get_mysql_version(container_name): result = subprocess.run(['docker', 'exec', '-it', container_name, 'mysql', '-uroot', '-proot', '-e', 'SELECT VERSION();'], capture_output=True, text=True) return result.stdout.strip() print(get_mysql_version('your_container_name')) ```
评论 1
成就一亿技术人!
拼手气红包6.0元
还能输入1000个字符
 
红包 添加红包
表情包 插入表情
 条评论被折叠 查看
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

lyfGeek

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值