1. 程式人生 > >docker mysql 資料持久化到本地、設定不區別表名大小寫

docker mysql 資料持久化到本地、設定不區別表名大小寫

Docker MySQL 把資料儲存在本地目錄,很簡單,只需要對映本地目錄到容器即可

1、加上-v引數

$ docker run -d -e MYSQL_ROOT_PASSWORD=admin --name mysql -v /data/mysql/data:/var/lib/mysql -p 3306:3306 mysql 

還可以指定配置檔案

docker run -d -e MYSQL_ROOT_PASSWORD=admin --name mysql -v /data/mysql/my.cnf:/etc/mysql/my.cnf -v /data/mysql/data:/var/lib/mysql -p 3306:3306 mysql 

這樣,即可修改配置檔案,還能把資料存在本地目錄,一舉兩得,-v 引數可以多次使用,每次對映一個目錄,通過這種方式,很容易進行配置。。

docker run -d -e MYSQL_ROOT_PASSWORD=admin --name mysql -v /data/mysql/my.cnf:/etc/mysql/my.cnf -v /data/mysql/data:/var/lib/mysql -p 3306:3306 mysql --lower_case_table_names=1

解釋如下:

-d  容器在後臺執行

-e MYSQL_ROOT_PASSWORD=admin    配置mysql root的密碼

-v   對mysql 的配置檔案和資料儲存路徑進行對映到宿主機,對資料持久化

-p   埠對映

--name  定義容器的名稱

--lower_case_table_names=1 定義資料庫不區分表名大小寫

網友的步驟:

  1. 拉取mysql 映象

    docker pull mysql

  2. 執行mysql

docker run 

--net=host 

--restart=always 

--privileged=true 

-v /usr/docker_dat/mysql/data:/var/lib/mysql 

--name mysql 

-p 3306:3306 

-e MYSQL_ROOT_PASSWORD=root 

-v /etc/localtime:/etc/localtime:ro 

-d mysql --lower_case_table_names=1  

3. 引數說明

--restart=always 跟隨docker啟動  

--privileged=true 容器root使用者享有主機root使用者許可權  

-v 對映主機路徑到容器  

-e MYSQL_ROOT_PASSWORD=root 設定root使用者密碼  

-d 後臺啟動  

--lower_case_table_names=1 設定表名引數名等忽略大小寫 

-v /etc/localtime:/etc/localtime:ro   設定容器的時間與宿主機同步