欧美bbbwbbbw肥妇,免费乱码人妻系列日韩,一级黄片

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

 更新時間:2023年07月11日 08:48:23   作者:山河亦問安  
Docker是一種流行的容器化平臺,可以簡化應用程序的部署和管理,在本博客中,我們將探討如何使用Docker部署兩個廣泛使用的數(shù)據庫:MySQL,我們將提供詳細的步驟和相應的命令,以幫助您輕松地在Docker容器中設置和運行這個數(shù)據庫

1. Docker部署Mysql

1.1 Mysql容器

1.1.1 創(chuàng)建Mysql容器

首先我們拉取mysql鏡像,要在Docker中部署MySQL數(shù)據庫,我們首先需要創(chuàng)建一個MySQL容器??梢允褂靡韵旅顒?chuàng)建一個MySQL 8..0.24版本的容器:

docker run -d --name mysql-container -e MYSQL_ROOT_PASSWORD=123456  -p 3307:3306 mysql:8.0.24

此命令會創(chuàng)建一個名為mysql-container的容器,將MySQL的root用戶密碼設置為123456,并將宿主機的3307端口映射到容器的3306端口。

1.1.2 進入Mysql容器并登錄Mysql

docker exec -it mysql-container mysql -u root -p

此命令將打開MySQL的命令行客戶端,并要求您輸入MySQL root用戶的密碼如下圖:

然后我們就可以在這里進行數(shù)據庫操作。

1.1.3 持久化數(shù)據

為了在容器重新啟動后保留MySQL數(shù)據,可以將數(shù)據目錄映射到宿主機的目錄。在創(chuàng)建容器時,可以添加以下參數(shù):

-v /docker/mysql/config/my.cnf:/etc/my.cnf #宿主機目錄:mysql容器目錄
-v /docker/mysql/data:/var/lib/mysql 

這里可以進行數(shù)據卷掛載,卷就是目錄或文件,存在于一個或多個容器中,由docker掛載到容器,但不屬于聯(lián)合文件系統(tǒng),因此能夠繞過Union File System提供一些用于持續(xù)存儲或共享數(shù)據的特性,卷的設計目的就是數(shù)據的持久化,完全獨立于容器的生存周期,因此Docker不會在容器刪除時刪除其掛載的數(shù)據卷。數(shù)據卷可在容器之間共享或重用數(shù)據并且卷中的更改可以直接實時生效,數(shù)據卷的生命周期一直持續(xù)到沒有容器使用它為止。如下圖:

1.2 遠程登錄Mysql

在Mysql 8.x版本當我們在云服務器上創(chuàng)建dockier容器后,嘗試遠程登錄Docker容器內數(shù)據庫的時候會遇見如下圖問題:

這是什么原因呢?

出現(xiàn)1251的主要原因是由于mysql版本的問題,mysql8.0版本,與mysql8.0以下版本的加密方式不同,導致錯誤產生。

MySql 8.0.11 換了新的身份驗證插件(caching_sha2_password),而原來的身份驗證插件為(mysql_native_password)。? 而客戶端工具Navicat Premium12 中找不到新的身份驗證插件(caching_sha2_password),因此報上面的錯,所以我們將mysql用戶使用的 登錄密碼加密規(guī)則還原成 mysql_native_password,即可登陸成功。

1.2.1 修改root加密方式

運行下面的命令:

mysql -u root -p  #登陸mysql
use mysql;	# 切換mysql數(shù)據庫
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 在容器啟動時配置加密方式為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編碼問題

當我們使用客戶端連接成功我們的docker容器后,然后進行創(chuàng)建數(shù)據庫,創(chuàng)建表格然后添加數(shù)據如下:

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容器內查詢mysql數(shù)據如下圖:

然后我們發(fā)現(xiàn)了亂碼問題,亂碼一般都是因為編碼引起的,所以我們來查一下數(shù)據庫的編碼

1.3.2 Mysql編碼問題解決辦法

1.修改my.cnf文件

cd /etc/mysql/ #進入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 退出。沒有 [mysql] 的話就寫一個。

如下圖:

然后看一下mysql的字符集,已經變成 utf8mb4 了,這樣就可以解決中文亂碼問題了。

查看表格數(shù)據

至此我們的問題得到了成功解決。

到此這篇關于Docker部署Mysql數(shù)據庫步驟詳解的文章就介紹到這了,更多相關Docker部署Mysql內容請搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關文章希望大家以后多多支持腳本之家!

相關文章

  • docker build鏡像時,無法訪問網絡問題

    docker build鏡像時,無法訪問網絡問題

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

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

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

    CentOS7上安裝Docker的詳細步驟

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

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

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

    Docker安裝部署RabbitMQ的實現(xiàn)步驟

    RabbitMQ是一款開源的消息隊列中間件,能夠在分布式系統(tǒng)中實現(xiàn)可靠的消息傳遞,本文主要介紹了Docker安裝部署RabbitMQ的實現(xiàn)步驟,具有一定的參考價值,感興趣的可以了解一下
    2023-10-10
  • 如何查看docker run啟動參數(shù)命令(推薦)

    如何查看docker run啟動參數(shù)命令(推薦)

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

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

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

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

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

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

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

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

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

最新評論