亚洲乱码中文字幕综合,中国熟女仑乱hd,亚洲精品乱拍国产一区二区三区,一本大道卡一卡二卡三乱码全集资源,又粗又黄又硬又爽的免费视频

Docker部署Mysql數(shù)據(jù)庫(kù)步驟詳解

 更新時(shí)間:2023年07月11日 08:48:23   作者:山河亦問(wèn)安  
Docker是一種流行的容器化平臺(tái),可以簡(jiǎn)化應(yīng)用程序的部署和管理,在本博客中,我們將探討如何使用Docker部署兩個(gè)廣泛使用的數(shù)據(jù)庫(kù):MySQL,我們將提供詳細(xì)的步驟和相應(yīng)的命令,以幫助您輕松地在Docker容器中設(shè)置和運(yùn)行這個(gè)數(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)題

    這篇文章主要介紹了docker build鏡像時(shí),無(wú)法訪問(wèn)網(wǎng)絡(luò)問(wèn)題,具有很好的參考價(jià)值,希望對(duì)大家有所幫助,如有錯(cuò)誤或未考慮完全的地方,望不吝賜教
    2024-08-08
  • Docker rocketmq部署的實(shí)現(xiàn)示例

    Docker rocketmq部署的實(shí)現(xiàn)示例

    最近學(xué)習(xí)使用 rocketmq,需要搭建 rocketmq 服務(wù)端,本文主要記錄 rocketmq 搭建過(guò)程以及這個(gè)過(guò)程踩到的一些坑,感興趣的可以了解一下
    2021-12-12
  • CentOS7上安裝Docker的詳細(xì)步驟

    CentOS7上安裝Docker的詳細(xì)步驟

    Docker?是一個(gè)開(kāi)源工具,它可以讓創(chuàng)建和管理?Linux?容器變得簡(jiǎn)單,容器就像是輕量級(jí)的虛擬機(jī),并且可以以毫秒級(jí)的速度來(lái)啟動(dòng)或停止,下面這篇文章主要給大家介紹了關(guān)于CentOS7上安裝Docker的詳細(xì)步驟,需要的朋友可以參考下
    2022-01-01
  • docker官方鏡像下載及使用Dockerfile創(chuàng)建鏡像的方法

    docker官方鏡像下載及使用Dockerfile創(chuàng)建鏡像的方法

    這篇文章主要介紹了docker官方鏡像下載及使用Dockerfile創(chuàng)建鏡像的方法,非常不錯(cuò),具有參考借鑒價(jià)值,需要的朋友可以參考下
    2017-02-02
  • Docker安裝部署RabbitMQ的實(shí)現(xiàn)步驟

    Docker安裝部署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ù)命令(推薦)

    這篇文章主要介紹了如何查看docker run啟動(dòng)參數(shù)命令,本文給大家介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或工作具有一定的參考借鑒價(jià)值,需要的朋友可以參考下
    2020-07-07
  • Docker鏡像管理常用操作代碼示例

    Docker鏡像管理常用操作代碼示例

    這篇文章主要介紹了Docker鏡像管理常用操作代碼示例,文中通過(guò)示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友可以參考下
    2020-10-10
  • docker pull命令拉取鏡像失敗的解決方案

    docker pull命令拉取鏡像失敗的解決方案

    本文介紹了docker pull命令拉取鏡像失敗的解決方案,文中通過(guò)示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面隨著小編來(lái)一起學(xué)習(xí)學(xué)習(xí)吧
    2024-11-11
  • 使用Docker容器運(yùn)行Mysql實(shí)戰(zhàn)記錄

    使用Docker容器運(yùn)行Mysql實(shí)戰(zhàn)記錄

    這篇文章主要給大家介紹了關(guān)于使用Docker容器運(yùn)行Mysql的相關(guān)資料,助大家更好的理解和學(xué)習(xí)使用docker,感興趣的朋友可以了解下,需要的朋友可以參考下
    2023-09-09
  • Docker Nginx容器制作部署實(shí)現(xiàn)方法

    Docker Nginx容器制作部署實(shí)現(xiàn)方法

    這篇文章主要介紹了Docker Nginx容器制作部署實(shí)現(xiàn)方法,文中通過(guò)示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友可以參考下
    2020-11-11

最新評(píng)論