首页 > 解决方案 > MySQL Docker 容器在首次运行后存储密码

问题描述

到目前为止,我在 Docker 方面的所有经验都让我相信容器是无状态的。

如果是这样,如果我在没有指定卷或绑定挂载的情况下启动它,为什么我的容器会存储我在第一次运行后将其更改为的密码?我特别困惑,因为我对 dbms 所做的其他编辑都没有保留(比如创建表)。

其他详细信息:
版本:
1. Docker - 18.09.0 build 4d60db4
2. 图像 - mysql/mysql-server:latest

命令:
1. $ docker run --name=sql -d mysql/mysql-server:latest
2.$ docker logs sql 2>&1 | grep GENERATED获取首次登录时生成的密码
3. $ docker exec -it sql mysql -uroot -p
4. mysql> Enter Password: <generated password>
5. mysql> ALTER USER 'root'@'localhost' IDENTIFIED BY 'stkoverflw';
6. mysql> exit
7. $ docker stop sql
8. $ docker start sql
9. $ docker exec -it sql mysql -uroot -p
10.mysql> Enter Password: <stkoverflw>

密码配置如何在容器重新启动时保持不变?

标签: mysqldocker

解决方案


容器不是无状态的。容器很容易创建和销毁,因此它们可以用来运行无状态的服务,但每个容器本身都是有状态的。

当容器运行时,有一个包含其根文件系统的卷。您不必告诉 Docker 创建它。Docker 必须创建它,否则容器的文件会去哪里?

当您说docker stop时,容器会停止运行,但不会被销毁。当您说docker start时,相同的容器会以相同的根卷恢复。那就是更改后的密码仍然存在的地方。在容器中运行的进程已停止并启动了一个新进程(因此内存中保存的状态将丢失),但文件系统仍然存在。

要摆脱容器(包括更改的密码),请说docker rm. 然后你可以说docker run从头开始。


推荐阅读