這篇文章主要介紹“MySQL鏡像生成容器的下載安裝及配置過程”,在日常操作中,相信很多人在mysql鏡像生成容器的下載安裝及配置過程問題上存在疑惑,小編查閱了各式資料,整理出簡單好用的操作方法,希望對大家解答”mysql鏡像生成容器的下載安裝及配置過程”的疑惑有所幫助!接下來,請跟著小編一起來學習吧!
成都創(chuàng)新互聯(lián)公司是一家專注于網(wǎng)站建設、網(wǎng)站設計與策劃設計,白云鄂網(wǎng)站建設哪家好?成都創(chuàng)新互聯(lián)公司做網(wǎng)站,專注于網(wǎng)站建設十年,網(wǎng)設計領(lǐng)域的專業(yè)建站公司;建站業(yè)務涵蓋:白云鄂等地區(qū)。白云鄂做網(wǎng)站價格咨詢:028-86922220
一、下載官方的mysql鏡像
[root@localhost ~]# docker pull mysql
下載完成后查看鏡像:
[root@localhost ~]# docker images REPOSITORY TAG IMAGE ID CREATED SIZE docker.io/mysql latest 1195b21c3a45 10 weeks ago 380.2 MB
二、生成容器
生成容器時,調(diào)用的啟動腳本是/entrypoint.sh;通過查看/entrypoint.sh腳本內(nèi)容,總結(jié)參數(shù)如下
mysqld #啟動mysql服務,必須使用 MYSQL_ROOT_PASSWORD #設置mysql的root密碼,必須使用 #以下二個參數(shù)添加除root之外的用戶并設置密碼,可選。 MYSQL_USER MYSQL_PASSWORD #設置生成容器時需要新建的數(shù)據(jù)庫,可選 MYSQL_DATABASE #容器的mysql數(shù)據(jù)庫默認的保存路徑是: /var/lib/mysql #容器的配置文件my.cnf的路徑為: /etc/mysql/my.cnf
使用上要的參數(shù)生成新的容器:
[root@localhost mysql_data]# docker run -d -p 3307:3306 --name mysql -P -e mysqld -e MYSQL_ROOT_PASSWORD=123456 -e MYSQL_USER=yope -e MYSQL_PASSWORD=yope -e MYSQL_DATABASE=testDb -v /mysql_data:/var/lib/mysql mysql 492ffa26d8653561208aed28eb62c61e9bae0de91ef911769c35f9e4eae6b272 [root@localhost mysql_data]# docker ps -a CONTAINER ID IMAGE COMMAND CREATED STATUS PORTS NAMES 492ffa26d865 mysql "docker-entrypoint.sh" 10 seconds ago Up 7 seconds 0.0.0.0:3307->3306/tcp mysql
重要參數(shù)說明:
--name mysql
指定容器名稱為 mysql;
-p 3307:3306
指定映射端口 將宿主機端口3307映射到容器3306端口;
-v /mysql_data:/var/lib/mysql
映射數(shù)據(jù)庫存放位置。將宿主機的目錄“/mysql_data”映射到容器的“/var/lib/mysql”目錄;這是因為默認情況下數(shù)據(jù)庫的數(shù)據(jù)庫文件和日志文件都會存放于容器的AUFS文件層,這不僅不使得容器變得越來越臃腫,不便于遷移、備份等管理,而且數(shù)據(jù)庫的性能也會受到影響。因此建議掛載到宿主機的目錄到容器內(nèi)。
查看本地的mysql_data是否生成容器內(nèi)的數(shù)據(jù)庫:
[root@localhost /]# ll /mysql_data/ 總用量 188452 -rw-r----- 1 systemd-bus-proxy ssh_keys 56 8月 20 22:25 auto.cnf -rw-r----- 1 systemd-bus-proxy ssh_keys 1329 8月 20 22:25 ib_buffer_pool -rw-r----- 1 systemd-bus-proxy ssh_keys 79691776 8月 20 22:25 ibdata1 -rw-r----- 1 systemd-bus-proxy ssh_keys 50331648 8月 20 22:25 ib_logfile0 -rw-r----- 1 systemd-bus-proxy ssh_keys 50331648 8月 20 22:25 ib_logfile1 -rw-r----- 1 systemd-bus-proxy ssh_keys 12582912 8月 20 22:25 ibtmp1 drwxr-x--- 2 systemd-bus-proxy ssh_keys 4096 8月 20 22:25 mysql drwxr-x--- 2 systemd-bus-proxy ssh_keys 8192 8月 20 22:25 performance_schema drwxr-x--- 2 systemd-bus-proxy ssh_keys 8192 8月 20 22:25 sys drwxr-x--- 2 systemd-bus-proxy ssh_keys 19 8月 20 22:25 testDb [root@localhost /]#
已經(jīng)生成相關(guān)的文件和默認數(shù)據(jù)庫,同時也新建了"testDb"數(shù)據(jù)庫.
測試方案一:
在宿主機上通過端口訪問容器中的mysql服務
[root@localhost /]# yum -y install mysql
測試登錄:
[root@localhost mysql_data]# mysql -u root -p -h 127.0.0.1 -P 3307 Enter password: Welcome to the MariaDB monitor. Commands end with ; or \g. Your MySQL connection id is 2 Server version: 5.7.13 MySQL Community Server (GPL) Copyright (c) 2000, 2016, Oracle, MariaDB Corporation Ab and others. Type 'help;' or '\h' for help. Type '\c' to clear the current input statement. MySQL [(none)]>
測試方案二:
自己本地利用mysql 連接工具(eg:Navicat 等)進行連接,注意映射出來的真實端口不一定是3306就好了。
需要注意的是:宿主機上的UID和GID是999。這是容器里用戶mysql的UID和GID。千萬別進行權(quán)限變更,否則容器對這個目錄進行讀寫就會出現(xiàn)問題。如果覺得不舒服,可以在本地新建一個mysql_docker的用戶指定UID和GID是999。
(這個注意本人沒有落實驗證,如果描寫信息有錯,還望指出)
三、進入到新生成的容器 (名為mysql的容器)
使用exec進入容器,同時進行相關(guān)操作:
[root@localhost /]# docker exec -it mysql /bin/bash
查看進程:
root@492ffa26d865:/# ps -aux USER PID %CPU %MEM VSZ RSS TTY STAT START TIME COMMAND mysql 1 0.2 9.7 1262696 182200 ? Ssl 14:52 0:00 mysqld root 127 0.2 0.1 20216 1884 ? Ss 14:57 0:00 /bin/bash root 133 0.0 0.0 17492 1148 ? R+ 14:58 0:00 ps -aux
查看數(shù)據(jù)庫所在的文件夾:
root@492ffa26d865:/# ls -l /var/lib/mysql/ total 188452 -rw-r----- 1 mysql mysql 56 Aug 20 14:52 auto.cnf -rw-r----- 1 mysql mysql 1329 Aug 20 14:52 ib_buffer_pool -rw-r----- 1 mysql mysql 50331648 Aug 20 14:52 ib_logfile0 -rw-r----- 1 mysql mysql 50331648 Aug 20 14:52 ib_logfile1 -rw-r----- 1 mysql mysql 79691776 Aug 20 14:52 ibdata1 -rw-r----- 1 mysql mysql 12582912 Aug 20 14:52 ibtmp1 drwxr-x--- 2 mysql mysql 4096 Aug 20 14:52 mysql drwxr-x--- 2 mysql mysql 8192 Aug 20 14:52 performance_schema drwxr-x--- 2 mysql mysql 8192 Aug 20 14:52 sys drwxr-x--- 2 mysql mysql 19 Aug 20 14:52 testDb
進入mysql:
root@492ffa26d865:/# mysql -u root -p Enter password: Welcome to the MySQL monitor. Commands end with ; or \g. Your MySQL connection id is 3 Server version: 5.7.13 MySQL Community Server (GPL) Copyright (c) 2000, 2016, Oracle and/or its affiliates. All rights reserved. Oracle is a registered trademark of Oracle Corporation and/or its affiliates. Other names may be trademarks of their respective owners. Type 'help;' or '\h' for help. Type '\c' to clear the current input statement. mysql>
四、修改容器中mysql的配置文件
默認鏡像中并沒有安裝vi或者vim,需要手工安裝
root@492ffa26d865:/# apt-get update && apt-get -yq install vim
然后就可以使用vim 來修改mysql的配置文件:
root@492ffa26d865:/# vim /etc/mysql/my.cnf
vim編輯器在此不做詳述。
如果已經(jīng)有一個比較成熟的my.cnf的配置方案,可以在宿主機上新建一個文件夾將已經(jīng)設置好的my.cnf和conf.d這二個文件放到里面,
然后在新建容器的時候,直接使用參數(shù)”-v” 將這個文件夾映射到容器的”/etc/mysql”目錄上即可。
到此,關(guān)于“mysql鏡像生成容器的下載安裝及配置過程”的學習就結(jié)束了,希望能夠解決大家的疑惑。理論與實踐的搭配能更好的幫助大家學習,快去試試吧!若想繼續(xù)學習更多相關(guān)知識,請繼續(xù)關(guān)注創(chuàng)新互聯(lián)網(wǎng)站,小編會繼續(xù)努力為大家?guī)砀鄬嵱玫奈恼拢?/p>
標題名稱:mysql鏡像生成容器的下載安裝及配置過程
標題來源:http://weahome.cn/article/jigjsc.html