当前位置: 首页 > news >正文

MySQL 容器已经停止(但仍然存在),但希望重新启动它,并使它的 3306 端口映射到宿主机的 3306 端口是不可行的

  1. 重新启动容器并映射端口是不行的
    由于你已经有一个名为 mysql-container 的 MySQL 容器,你可以使用 docker start 启动它。想要让3306 端口映射到宿主机是不行的,实际上,端口映射是在容器启动时指定的。你无法在容器已经创建的情况下直接修改端口映射。

因此,最简单的方式是 删除当前容器并重新创建一个容器,确保映射了正确的端口。

1.1 启动并重新创建容器
你可以删除已经停止的容器,并重新启动一个带有端口映射的新容器:

docker rm mysql-container # 删除已经停止的容器
然后,使用 docker run 命令重新创建并启动 MySQL 容器,并将容器的 3306 端口映射到宿主机的 3306 端口:

docker run --name mysql-container -e MYSQL_ROOT_PASSWORD=my-secret-pw -p 3306:3306 -d mysql:latest
参数解释:

–name mysql-container:指定容器名称。
-e MYSQL_ROOT_PASSWORD=my-secret-pw:设置 MySQL root 用户的密码为 my-secret-pw,可以根据需要修改密码。
-p 3306:3306:将容器内的 3306 端口映射到宿主机的 3306 端口。这样你就可以通过宿主机的 localhost:3306 连接到 MySQL。
-d:让容器在后台运行。

1.2 重新启动并检查容器
如果容器没有被删除,你也可以直接重新启动它,但你无法改变已经映射的端口。首先尝试重新启动容器:

docker start mysql-container
然后,使用 docker ps 查看是否启动成功并映射了端口:

docker ps
输出会显示容器的状态以及端口映射。

  1. 修改端口映射(如果容器已创建)是不可行的
    如果你已经创建了一个容器,但想修改端口映射,只能通过删除原来的容器并重新创建一个容器来实现。这是因为容器的端口映射在容器创建时就被确定了,不能在容器已经启动的情况下更改。

  2. 新建一个mysql容器mysql-container2并指定端口映射
    docker run --name mysql-container2 -e MYSQL_ROOT_PASSWORD=my-secret-pw -p 3306:3306 -d mysql:latest
    在这里插入图片描述
    C:\Users\Administrator>docker ps
    CONTAINER ID IMAGE COMMAND CREATED STATUS PORTS NAMES
    a92e31d7ce8d mysql:latest “docker-entrypoint.s…” 14 minutes ago Up 14 minutes 0.0.0.0:3306->3306/tcp, 33060/tcp mysql-container2
    374d25dc3768 mysql:latest “docker-entrypoint.s…” 35 minutes ago Up 16 minutes 3306/tcp, 33060/tcp mysql-container

  3. 验证登录mysql数据库
    4.1容器内登录
    E:\workspace_docker>docker exec -it mysql-container2 bash
    bash-5.1# mysql -u root -p
    Enter password:
    Welcome to the MySQL monitor. Commands end with ; or \g.
    Your MySQL connection id is 14
    Server version: 9.2.0 MySQL Community Server - GPL

Copyright © 2000, 2025, Oracle and/or its affiliates.

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> show databases;
±-------------------+
| Database |
±-------------------+
| information_schema |
| mysql |
| performance_schema |
| sys |
±-------------------+
4 rows in set (0.00 sec)

mysql>

4.2外部宿主机上登录
在这里插入图片描述

在这里插入图片描述

总结
你可以通过 docker run 命令重新创建并启动容器,同时确保端口映射到宿主机的 3306 端口。
如果容器已经停止并且不再需要它,可以先使用 docker rm 删除容器,然后重新创建。
端口映射必须在容器启动时指定,无法修改正在运行的容器的端口映射。

http://www.lryc.cn/news/525510.html

相关文章:

  • 汇编实验·顺序程序设计
  • AIGC视频扩散模型新星:Video 版本的SD模型
  • HarmonyOS:通过(SQLite)关系型数据库实现数据持久化
  • 10. SpringCloud Alibaba Sentinel 规则持久化部署详细剖析
  • STM32更新程序OTA
  • MarsCode青训营打卡Day10(2025年1月23日)|稀土掘金-147.寻找独一无二的糖葫芦串、119.游戏队友搜索
  • vue(33) : 安装组件出错解决
  • ChatGPT结合Excel辅助学术数据分析详细步骤分享!
  • stm32f103 单片机(一)第一个工程
  • 云计算和服务器
  • Spring 框架:配置缓存管理器、注解参数与过期时间
  • Linux系统 C/C++编程基础——基于Qt的图形用户界面编程
  • 并发编程 - 线程同步(一)
  • PyTorch入门 - 为什么选择PyTorch?
  • leetcode刷题记录(八十六)——84. 柱状图中最大的矩形
  • Android GLSurfaceView 覆盖其它控件问题 (RK平台)
  • 开源鸿蒙开发者社区记录
  • 【Linux网络编程】传输层协议
  • 10个非常基础的 Javascript 问题
  • Mysql索引(学习自用)
  • eniops库中reduce函数使用方法
  • 阴沟翻船题——Longest Substring Without Repeating Characters
  • Jetpack Compose 和 Compose Multiplatform 还有 KMP 的关系
  • 微信小程序中实现背景图片完全覆盖显示,可以通过设置CSS样式来实现
  • 【0x0012】HCI_Delete_Stored_Link_Key命令详解
  • console的各种方法
  • spring boot关于系统首页自动跳转拼接到index
  • 指针生成网络(PGN)详细指南(引入)
  • 案例研究丨浪潮云洲通过DataEase推进多维度数据可视化建设
  • k8s 蓝绿发布、滚动发布、灰度发布