Docker部署Mysql數(shù)據(jù)庫(kù)步驟詳解
1. Docker部署Mysql
1.1 Mysql容器
1.1.1 創(chuàng)建Mysql容器
首先我們拉取mysql鏡像,要在Docker中部署MySQL數(shù)據(jù)庫(kù),我們首先需要?jiǎng)?chuàng)建一個(gè)MySQL容器??梢允褂靡韵旅顒?chuàng)建一個(gè)MySQL 8..0.24版本的容器:
docker run -d --name mysql-container -e MYSQL_ROOT_PASSWORD=123456 -p 3307:3306 mysql:8.0.24
此命令會(huì)創(chuàng)建一個(gè)名為mysql-container的容器,將MySQL的root用戶密碼設(shè)置為123456,并將宿主機(jī)的3307端口映射到容器的3306端口。
1.1.2 進(jìn)入Mysql容器并登錄Mysql
docker exec -it mysql-container mysql -u root -p
此命令將打開(kāi)MySQL的命令行客戶端,并要求您輸入MySQL root用戶的密碼如下圖:
然后我們就可以在這里進(jìn)行數(shù)據(jù)庫(kù)操作。
1.1.3 持久化數(shù)據(jù)
為了在容器重新啟動(dòng)后保留MySQL數(shù)據(jù),可以將數(shù)據(jù)目錄映射到宿主機(jī)的目錄。在創(chuàng)建容器時(shí),可以添加以下參數(shù):
-v /docker/mysql/config/my.cnf:/etc/my.cnf #宿主機(jī)目錄:mysql容器目錄 -v /docker/mysql/data:/var/lib/mysql
這里可以進(jìn)行數(shù)據(jù)卷掛載,卷就是目錄或文件,存在于一個(gè)或多個(gè)容器中,由docker掛載到容器,但不屬于聯(lián)合文件系統(tǒng),因此能夠繞過(guò)Union File System提供一些用于持續(xù)存儲(chǔ)或共享數(shù)據(jù)的特性,卷的設(shè)計(jì)目的就是數(shù)據(jù)的持久化,完全獨(dú)立于容器的生存周期,因此Docker不會(huì)在容器刪除時(shí)刪除其掛載的數(shù)據(jù)卷。數(shù)據(jù)卷可在容器之間共享或重用數(shù)據(jù)并且卷中的更改可以直接實(shí)時(shí)生效,數(shù)據(jù)卷的生命周期一直持續(xù)到?jīng)]有容器使用它為止。如下圖:
1.2 遠(yuǎn)程登錄Mysql
在Mysql 8.x版本當(dāng)我們?cè)谠品?wù)器上創(chuàng)建dockier容器后,嘗試遠(yuǎn)程登錄Docker容器內(nèi)數(shù)據(jù)庫(kù)的時(shí)候會(huì)遇見(jiàn)如下圖問(wèn)題:
這是什么原因呢?
出現(xiàn)1251的主要原因是由于mysql版本的問(wèn)題,mysql8.0版本,與mysql8.0以下版本的加密方式不同,導(dǎo)致錯(cuò)誤產(chǎn)生。
MySql 8.0.11 換了新的身份驗(yàn)證插件(caching_sha2_password),而原來(lái)的身份驗(yàn)證插件為(mysql_native_password)。? 而客戶端工具Navicat Premium12 中找不到新的身份驗(yàn)證插件(caching_sha2_password),因此報(bào)上面的錯(cuò),所以我們將mysql用戶使用的 登錄密碼加密規(guī)則還原成 mysql_native_password,即可登陸成功。
1.2.1 修改root加密方式
運(yùn)行下面的命令:
mysql -u root -p #登陸mysql use mysql; # 切換mysql數(shù)據(jù)庫(kù) select host, user, authentication_string, plugin from user; #查看root用戶登錄加密方式
如下圖:
然后我們改變加密命令
alter user 'root'@'%' identified with mysql_native_password by '123456';
然后再次查看root用戶登錄的加密方式
select host, user, authentication_string, plugin from user; #查看root用戶登錄加密方式
然后我們重新使用客戶端登錄系統(tǒng)顯示登錄成功。
1.2.2 在容器啟動(dòng)時(shí)配置加密方式為mysql_native_password
代碼-e identified=mysql_native_password
,配置了加密方式。
docker run -d --name mysql-container -e MYSQL_ROOT_PASSWORD=123456 -p 3307:3306 -e identified=mysql_native_password mysql:8.0.24
1.3 Mysql編碼
1.3.1 Mysql編碼問(wèn)題
當(dāng)我們使用客戶端連接成功我們的docker容器后,然后進(jìn)行創(chuàng)建數(shù)據(jù)庫(kù),創(chuàng)建表格然后添加數(shù)據(jù)如下:
CREATE DATABASE /*!32312 IF NOT EXISTS*/`project` /*!40100 DEFAULT CHARACTER SET utf8mb4 COLLATE utf8mb4_general_ci */ /*!80016 DEFAULT ENCRYPTION='N' */; USE `project`; /*Table structure for table `user` */ DROP TABLE IF EXISTS `user`; CREATE TABLE `user` ( `id` BIGINT NOT NULL AUTO_INCREMENT, `username` VARCHAR(20) DEFAULT NULL, `password` VARCHAR(20) DEFAULT NULL, PRIMARY KEY (`id`) ) ENGINE=INNODB AUTO_INCREMENT=3 DEFAULT CHARSET=utf8mb4 COLLATE=utf8mb4_0900_ai_ci; /*Data for the table `user` */ INSERT INTO `user`(`id`,`username`,`password`) VALUES (1,'張三','123'),(2,'lisi','456');
然后在我們的docker容器內(nèi)查詢mysql數(shù)據(jù)如下圖:
然后我們發(fā)現(xiàn)了亂碼問(wèn)題,亂碼一般都是因?yàn)榫幋a引起的,所以我們來(lái)查一下數(shù)據(jù)庫(kù)的編碼
1.3.2 Mysql編碼問(wèn)題解決辦法
1.修改my.cnf文件
cd /etc/mysql/ #進(jìn)入my.cnf文件中的目錄 vim my.cnf #編輯my.cnf文件
2.出現(xiàn)bash: vim: command not found
提示,需要安裝一下vim,使用如下命令
apt-get update apt-get install vim -y
重新執(zhí)行vim命令。
3. 在 my.cnf文件中[mysql] 下面添加 default-character-set=utf8mb4,然后 :wq 退出。沒(méi)有 [mysql] 的話就寫一個(gè)。
如下圖:
然后看一下mysql的字符集,已經(jīng)變成 utf8mb4 了,這樣就可以解決中文亂碼問(wèn)題了。
查看表格數(shù)據(jù)
至此我們的問(wèn)題得到了成功解決。
到此這篇關(guān)于Docker部署Mysql數(shù)據(jù)庫(kù)步驟詳解的文章就介紹到這了,更多相關(guān)Docker部署Mysql內(nèi)容請(qǐng)搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持腳本之家!
相關(guān)文章
docker build鏡像時(shí),無(wú)法訪問(wèn)網(wǎng)絡(luò)問(wèn)題
這篇文章主要介紹了docker build鏡像時(shí),無(wú)法訪問(wèn)網(wǎng)絡(luò)問(wèn)題,具有很好的參考價(jià)值,希望對(duì)大家有所幫助,如有錯(cuò)誤或未考慮完全的地方,望不吝賜教2024-08-08Docker rocketmq部署的實(shí)現(xiàn)示例
最近學(xué)習(xí)使用 rocketmq,需要搭建 rocketmq 服務(wù)端,本文主要記錄 rocketmq 搭建過(guò)程以及這個(gè)過(guò)程踩到的一些坑,感興趣的可以了解一下2021-12-12docker官方鏡像下載及使用Dockerfile創(chuàng)建鏡像的方法
這篇文章主要介紹了docker官方鏡像下載及使用Dockerfile創(chuàng)建鏡像的方法,非常不錯(cuò),具有參考借鑒價(jià)值,需要的朋友可以參考下2017-02-02Docker安裝部署RabbitMQ的實(shí)現(xiàn)步驟
RabbitMQ是一款開(kāi)源的消息隊(duì)列中間件,能夠在分布式系統(tǒng)中實(shí)現(xiàn)可靠的消息傳遞,本文主要介紹了Docker安裝部署RabbitMQ的實(shí)現(xiàn)步驟,具有一定的參考價(jià)值,感興趣的可以了解一下2023-10-10如何查看docker run啟動(dòng)參數(shù)命令(推薦)
這篇文章主要介紹了如何查看docker run啟動(dòng)參數(shù)命令,本文給大家介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或工作具有一定的參考借鑒價(jià)值,需要的朋友可以參考下2020-07-07使用Docker容器運(yùn)行Mysql實(shí)戰(zhàn)記錄
這篇文章主要給大家介紹了關(guān)于使用Docker容器運(yùn)行Mysql的相關(guān)資料,助大家更好的理解和學(xué)習(xí)使用docker,感興趣的朋友可以了解下,需要的朋友可以參考下2023-09-09Docker Nginx容器制作部署實(shí)現(xiàn)方法
這篇文章主要介紹了Docker Nginx容器制作部署實(shí)現(xiàn)方法,文中通過(guò)示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友可以參考下2020-11-11