Docker MySQL 把數據存儲在本地目錄,很簡單,只須要映射本地目錄到容器便可mysql
一、加上-v參數sql
$ docker run -d -e MYSQL_ROOT_PASSWORD=admin --name mysql -v /data/mysql/data:/var/lib/mysql -p 3306:3306 mysql docker
還能夠指定配置文件數據庫
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 ide
這樣,便可修改配置文件,還能把數據存在本地目錄,一箭雙鵰,-v 參數能夠屢次使用,每次映射一個目錄,經過這種方式,很容易進行配置。。spa
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=1rest
解釋以下:ci
-d 容器在後臺運行同步
-e MYSQL_ROOT_PASSWORD=admin 配置mysql root的密碼it
-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 設置容器的時間與宿主機同步