日日操夜夜添-日日操影院-日日草夜夜操-日日干干-精品一区二区三区波多野结衣-精品一区二区三区高清免费不卡

公告:魔扣目錄網(wǎng)為廣大站長提供免費收錄網(wǎng)站服務(wù),提交前請做好本站友鏈:【 網(wǎng)站目錄:http://www.ylptlb.cn 】, 免友鏈快審服務(wù)(50元/站),

點擊這里在線咨詢客服
新站提交
  • 網(wǎng)站:51998
  • 待審:31
  • 小程序:12
  • 文章:1030137
  • 會員:747

>

目錄
  • 1. Docker部署Mysql
    • 1.1 Mysql容器
      • 1.1.1 創(chuàng)建Mysql容器
      • 1.1.2 進入Mysql容器并登錄Mysql
      • 1.1.3 持久化數(shù)據(jù)
    • 1.2 遠程登錄Mysql
      • 1.2.1 修改root加密方式
      • 1.2.2 在容器啟動時配置加密方式為mysql_native_password
    • 1.3 Mysql編碼
      • 1.3.1 Mysql編碼問題
      • 1.3.2 Mysql編碼問題解決辦法

1. Docker部署Mysql

1.1 Mysql容器

1.1.1 創(chuàng)建Mysql容器

首先我們拉取mysql鏡像,要在Docker中部署MySQL數(shù)據(jù)庫,我們首先需要創(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用戶密碼設(shè)置為123456,并將宿主機的3307端口映射到容器的3306端口。

1.1.2 進入Mysql容器并登錄Mysql

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

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

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

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

1.1.3 持久化數(shù)據(jù)

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

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

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

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

1.2 遠程登錄Mysql

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

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

這是什么原因呢?

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

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ù)據(jù)庫
select host, user, authentication_string, plugin from user; #查看root用戶登錄加密方式
 

如下圖:

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

然后我們改變加密命令

alter user 'root'@'%' identified with mysql_native_password by '123456';

然后再次查看root用戶登錄的加密方式

select host, user, authentication_string, plugin from user; #查看root用戶登錄加密方式

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

然后我們重新使用客戶端登錄系統(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編碼問題

當(dāng)我們使用客戶端連接成功我們的docker容器后,然后進行創(chuàng)建數(shù)據(jù)庫,創(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ù)如下圖:

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

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

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

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] 的話就寫一個。

如下圖:

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

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

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

查看表格數(shù)據(jù)

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

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

>

分享到:
標簽:數(shù)據(jù)庫 服務(wù)器 步驟 詳解 部署
用戶無頭像

網(wǎng)友整理

注冊時間:

網(wǎng)站:5 個   小程序:0 個  文章:12 篇

  • 51998

    網(wǎng)站

  • 12

    小程序

  • 1030137

    文章

  • 747

    會員

趕快注冊賬號,推廣您的網(wǎng)站吧!
最新入駐小程序

數(shù)獨大挑戰(zhàn)2018-06-03

數(shù)獨一種數(shù)學(xué)游戲,玩家需要根據(jù)9

答題星2018-06-03

您可以通過答題星輕松地創(chuàng)建試卷

全階人生考試2018-06-03

各種考試題,題庫,初中,高中,大學(xué)四六

運動步數(shù)有氧達人2018-06-03

記錄運動步數(shù),積累氧氣值。還可偷

每日養(yǎng)生app2018-06-03

每日養(yǎng)生,天天健康

體育訓(xùn)練成績評定2018-06-03

通用課目體育訓(xùn)練成績評定