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 定義資料庫不區分表名大小寫
網友的步驟:
拉取mysql 映象
docker pull mysql
執行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 設定容器的時間與宿主機同步