国产片侵犯亲女视频播放_亚洲精品二区_在线免费国产视频_欧美精品一区二区三区在线_少妇久久久_在线观看av不卡

服務(wù)器之家:專注于服務(wù)器技術(shù)及軟件下載分享
分類導(dǎo)航

云服務(wù)器|WEB服務(wù)器|FTP服務(wù)器|郵件服務(wù)器|虛擬主機(jī)|服務(wù)器安全|DNS服務(wù)器|服務(wù)器知識(shí)|Nginx|IIS|Tomcat|

服務(wù)器之家 - 服務(wù)器技術(shù) - 服務(wù)器知識(shí) - 解決Docker之mysql容器數(shù)據(jù)庫(kù)更改不生效的問(wèn)題

解決Docker之mysql容器數(shù)據(jù)庫(kù)更改不生效的問(wèn)題

2021-05-24 17:41大樹168 服務(wù)器知識(shí)

這篇文章主要介紹了解決Docker之mysql容器數(shù)據(jù)庫(kù)更改不生效的問(wèn)題,具有很好的參考價(jià)值,希望對(duì)大家有所幫助。一起跟隨小編過(guò)來(lái)看看吧

用官方的mysql 鏡像需要修改一些內(nèi)容,比如配置文件的修改,DB數(shù)據(jù)文件的目錄等,更改之后如果重新運(yùn)行容器,改過(guò)的文件就無(wú)效了,新生成的容器不會(huì)有之前改變的內(nèi)容

第一種是修改官方下載的鏡像,修改之后 提交一個(gè)新的鏡像文件 docker commit -m 等新生成的鏡像信息,

第二種MYSQL的DB數(shù)據(jù),容器關(guān)閉后 如果用 docker restart 重啟同一容器,那么數(shù)據(jù)是正常的,如果重新docker run 容器那么數(shù)據(jù)就不會(huì)顯示,因?yàn)槊總€(gè)容器都有一個(gè)文件地址

這就需要把數(shù)據(jù)文件掛載出來(lái),供其它容器讀取,

在docker中啟動(dòng)mysql容器,在mysql容器中對(duì)數(shù)據(jù)庫(kù)的更改(如創(chuàng)建數(shù)據(jù)庫(kù),更改數(shù)據(jù)等),在commit后再次進(jìn)入容器發(fā)現(xiàn)之前的更改全部沒(méi)有保存

1.后臺(tái)運(yùn)行mysql容器,設(shè)置容器名稱為mysql:

[root@localhost ~]# docker run --name=mysql -p 3306:3306 -d owenchen1992/mysql

f80791a0daf194fdba94f16a9d89ebec8ba8fbd8af28d3ea8b599b9d705f85ba

2.進(jìn)入容器bash和mysql,創(chuàng)建一個(gè)數(shù)據(jù)庫(kù)TEST_DB,并驗(yàn)證TEST_DB創(chuàng)建成功:

?
1
2
3
[root@localhost ~]# docker exec -it mysql bash root@f80791a0daf1:/# mysql -uroot -p
show databases;
create database TEST_DB;

3.退出容器,并commit更改到鏡像: 這個(gè)數(shù)據(jù)其實(shí)是在宿主機(jī)上修改,不是mysql鏡像的東西。所以不生效

?
1
2
3
4
5
mysql> exit
Bye
root@f80791a0daf1:/# exit
exit
[root@localhost ~]# docker commit mysql owenchen1992/mysql

4.重新啟動(dòng)容器并進(jìn)入bash和mysql,發(fā)現(xiàn)之前創(chuàng)建的TEST_DB不見了,說(shuō)明之前的更改無(wú)效:

?
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
[root@localhost ~]# docker container stop mysql
mysql
[root@localhost ~]# docker container rm mysql
mysql
[root@localhost ~]# docker run --name=mysql -p 3306:3306 -d owenchen1992/mysql
a1a1b4174caaadda0ec4b01b9fe5f92d6b3464d85284042274f71aebde0915dd
[root@localhost ~]# docker exec -it mysql bash
root@a1a1b4174caa:/# mysql -uroot -p
Enter password:
Welcome to the MySQL monitor. Commands end with ; or \g.
Your MySQL connection id is 3
Server version: 5.7.20 MySQL Community Server (GPL)
 
mysql> show databases;
+--------------------+
| Database   |
+--------------------+
| information_schema |
| mysql    |
| performance_schema |
| sys    |
+--------------------+
4 rows in set (0.00 sec)

問(wèn)題原因:

在mysql的Dockerfile中有這樣一行:

VOLUME /var/lib/mysql

這意味在容器中的目錄/var/lib/mysql的所有修改會(huì)對(duì)應(yīng)到宿主機(jī)的某個(gè)位置,可以通過(guò)命令查看具體對(duì)應(yīng)的宿主機(jī)目錄:docker inspect containerID/name. 當(dāng)運(yùn)行docker commit時(shí),容器中的/var/lib/mysql目錄的更改并不會(huì)提交到鏡像中,但這些更改是隨時(shí)與宿主機(jī)對(duì)應(yīng)的目錄同步的。

當(dāng)重新啟動(dòng)commit后的鏡像時(shí),container會(huì)重新在宿主機(jī)中創(chuàng)建一個(gè)目錄來(lái)保存其數(shù)據(jù)更新,因此并不是原先的宿主機(jī)目錄,所以新開啟的容器看不到之前的數(shù)據(jù)更改。

解決方法:

我們已經(jīng)知道了問(wèn)題發(fā)生的原因,就不難解決這個(gè)問(wèn)題了,步驟如下:

可以直接去這個(gè)目錄下查看為每個(gè)容器生成的數(shù)據(jù)目錄

1.找到mysql容器對(duì)應(yīng)的宿主機(jī)目錄"/var/lib/docker/volumes/8496bbf33782bdadc027cdcf23197e5ebc36d11deb69ee833d63b557b3a7183d/_data":

?
1
2
3
4
5
6
7
[root@localhost ~]# docker inspect mysql
[
......
    "Source": "/var/lib/docker/volumes/8496bbf33782bdadc027cdcf23197e5ebc36d11deb69ee833d63b557b3a7183d/_data",
    "Destination": "/var/lib/mysql",
......
]

把之前的創(chuàng)建容器運(yùn)行的步驟再執(zhí)行一步,運(yùn)行新的容器,然后建一張TEST表,先關(guān)閉容器后刪除容器服務(wù)

4.后臺(tái)運(yùn)行容器新的容器,并將宿主機(jī)對(duì)應(yīng)的目錄掛載到容器的/var/lib/mysql目錄下并開啟讀寫權(quán)限(關(guān)鍵步驟):

[root@localhost ~]# docker run --name=mysql -p 3306:3306 -v /var/lib/docker/volumes/8496bbf33782bdadc027cdcf23197e5ebc36d11deb69ee833d63b557b3a7183d/_data:/var/lib/mysql:rw -d owenchen1992/mysql

5.此時(shí)進(jìn)入新開啟的容器,并查看數(shù)據(jù)庫(kù):發(fā)現(xiàn)剛才創(chuàng)建的數(shù)據(jù)庫(kù)TEST_DB沒(méi)有因?yàn)橹匦逻\(yùn)行容器而消失,問(wèn)題解決

步驟是,1 新建一張表,2 關(guān)掉建表的容器,3重新運(yùn)行容器,并且掛載數(shù)據(jù)目錄到/var/lib/mysql下,問(wèn)題就解決了!

補(bǔ)充知識(shí):docker環(huán)境下使用mysql出現(xiàn)編碼格式問(wèn)題修改編碼格式的方法

方法一(適用于單機(jī)器修改)

首先確定mysql服務(wù)處于開始狀態(tài)

鍵入docker exec -it +服務(wù)名 /bin/bash 進(jìn)入控制臺(tái)

鍵入apt-get update 命令

鍵入apt-get install vim (上述兩條命令用于下載vim編輯器),

輸入vim /etc/mysql/mysql.conf.d/mysqld.cnf 命令 進(jìn)入mysqld.cnf文件

4.使用i打開編輯模式,在文本的最后輸入以下內(nèi)容:

注意:下面的內(nèi)容一定不能輸錯(cuò),否則會(huì)造成配置文件失效

?
1
2
3
4
5
6
[client]
default-character-set=utf8
[mysql]
default-character-set=utf8
[mysqld]
character-set-server=utf8

ESC退出,shift+冒號(hào)wq保存 退出。

5.進(jìn)入mysql控制臺(tái)

6.輸入show variables like ‘char%'; 即可查看到修改后的相應(yīng)信息

解決Docker之mysql容器數(shù)據(jù)庫(kù)更改不生效的問(wèn)題

修改完畢重啟數(shù)據(jù)庫(kù)后:輸入show variables like"char%"即可

解決Docker之mysql容器數(shù)據(jù)庫(kù)更改不生效的問(wèn)題

出現(xiàn)上述結(jié)果說(shuō)明已經(jīng)修改成功

方法二(適用于集群搭建)

將配置文件拷貝出原目錄,使用外部文件修改,此方法用于發(fā)送文件到多臺(tái)服務(wù)器進(jìn)行數(shù)據(jù)庫(kù)默認(rèn)編碼修改

docker exec -it +服務(wù)名 /bin/bash 進(jìn)入控制臺(tái)

輸入cd /etc/mysql/conf.d/ 進(jìn)入配置文件目錄

輸入pwd獲取文件絕對(duì)路徑

輸入cd回退到控制臺(tái),exit退出

輸入docker cp 服務(wù)名:/etc/mysql/conf.d/mysql.cnf /usr/soft ( 將docker中的mysql.cnf文件拷貝到linux下的soft文件夾中)

開啟外部編輯器(如notepad++)進(jìn)行配置文件書寫 如下:

?
1
2
3
4
5
6
7
8
9
10
11
12
[client]
default-character-set=utf8
 
[mysql]
default-character-set=utf8
 
[mysqld]
init_connect=‘SET collation_connection = utf8_unicode_ci'
init_connect=‘SET NAMES utf8'
character-set-server=utf8
collation-server=utf8_unicode_ci
skip-character-set-client-handshake

解決Docker之mysql容器數(shù)據(jù)庫(kù)更改不生效的問(wèn)題

PS:注意配置文件的內(nèi)容要有間隔,這一點(diǎn)很重要

保存好

7.docker cp /usr/soft/mysql.cnf 服務(wù)名:/etc/mysql/conf.d/ 將修改后的文件拷貝到原來(lái)的目錄下覆蓋

8.重啟docker中的mysql服務(wù),然后

9.輸入 show variables like ‘char%';命令即可查看已經(jīng)修改好的字符編碼格式

以上這篇解決Docker之mysql容器數(shù)據(jù)庫(kù)更改不生效的問(wèn)題就是小編分享給大家的全部?jī)?nèi)容了,希望能給大家一個(gè)參考,也希望大家多多支持服務(wù)器之家。

原文鏈接:https://blog.csdn.net/limingcai168/article/details/88088431

延伸 · 閱讀

精彩推薦
主站蜘蛛池模板: 欧洲精品视频在线观看 | 国产不卡一区 | 日韩资源在线 | 亚洲激情视频 | 亚洲日本乱码一区两区在线观看 | 日韩在线视频播放 | 精品麻豆剧传媒av国产九九九 | 成人精品一区二区 | 欧美国产精品一区二区三区 | 免费成人黄色大片 | 国产精品久久久久久久一区探花 | 国产精品视频久久久 | 国产日韩欧美 | 久久99精品久久久 | 久久久久国产精品一区二区 | 日韩免费av| 香蕉久久久久久 | 天天操天天操 | 亚洲青草 | 国内久久精品 | 日韩高清av | 国产激情一区二区三区成人免费 | 亚洲小视频网站 | 91精品国产一区二区三区香蕉 | 日韩欧美视频 | 一级看片 | 国产在线一区二区三区 | 国内精品一区二区三区 | 欧美一级视频 | 久久亚洲精品综合 | 国产在线视频网 | 亚洲成人免费在线 | 成人午夜 | 日韩精品一区二区三区中文在线 | 亚洲精品国产精品国自产在线 | 一区二区久久 | 91激情在线 | www成人精品 | 亚洲不卡| 日韩成人在线网 | 成人福利视频 |