一、簡介mysql
Docker是一個開源的應用容器引擎;linux
Docker支持將軟件編譯成一個鏡像;而後在鏡像中各類軟件作好配置,將鏡像發佈出去,其餘使用者能夠直接使用這個鏡像;redis
運行中的這個鏡像稱爲容器,容器啓動是很是快速的sql
二、核心概念docker
docker主機(Host):安裝了Docker程序的機器(Docker直接安裝在操做系統之上);tomcat
docker客戶端(Client):鏈接docker主機進行操做;服務器
docker倉庫(Registry):用來保存各類打包好的軟件鏡像;網絡
docker鏡像(Images):軟件打包好的鏡像;放在docker倉庫中;tcp
docker容器(Container):鏡像啓動後的實例稱爲一個容器;容器是獨立運行的一個或一組應用;ui
使用Docker的步驟:
1)、安裝Docker
2)、去Docker倉庫找到這個軟件對應的鏡像;
3)、使用Docker運行這個鏡像,這個鏡像就會生成一個Docker容器;
4)、對容器的啓動中止就是對軟件的啓動中止
三、安裝Docker
1)、安裝linux虛擬機
1)、VMWare、VitualBox(安裝);
2)、導入虛擬機文件;
3)、雙擊啓動linux虛擬機;
4)、使用客戶端鏈接linux服務器進行命令操做;
5)、設置虛擬機網絡;
橋接網絡===>選好網卡===>接入網線
6)、設置好網絡以後使用命令重啓虛擬機的網絡
1 service network restart
7)、查看linux的ip地址
1 ip addr
8)、使用客戶端鏈接
2)、在linux虛擬機上安裝docker
步驟:
一、檢查內核版本,必須是3.10及以上
uname -r
二、安裝docker
yum install docker
三、輸入y確認安裝
四、啓動docker
[root@localhost ~]# systemctl start docker
[root@localhost ~]# docker -v
Docker version 1.13.1, build dded712/1.13.1
五、開機啓動docker
[root@localhost ~]# systemctl enable docker
Created symlink from /etc/systemd/system/multi-user.target.wants/docker.service to /usr/lib/systemd/system/docker.service.
六、中止docker
[root@localhost ~]# systemctl stop docker
[root@localhost ~]# docker info
Cannot connect to the Docker daemon at unix:///var/run/docker.sock. Is the docker daemon running?
4、Docker經常使用命令&操做
1)、鏡像操做
操做 | 命令 | 說明 |
檢索 | docker search 關鍵字 eg:docker search redis |
咱們常常去docker hub上檢索鏡像的詳細信息,如鏡像的TAG |
拉取 | docker pull 鏡像名:tag | :tag是可選的,tag表示標籤,多爲軟件的版本,默認是latest |
列表 | docker images | 查看全部本地鏡像 |
刪除 | docker rmi image-id | 刪除指定的本地鏡像 |
2)、容器操做
軟件鏡像----運行鏡像----產生一個容器(正在運行的軟件);
步驟:
一、搜索鏡像
[root@bogon ~]# docker search tomcat
二、拉取鏡像
[root@bogon ~]# docker pull tomcat
三、根據鏡像啓動容器
docker run --name mytomcat -d tomcat:latest
四、docker ps
查看運行中的容器
五、 中止運行中的容器
docker stop 容器的id
六、查看全部的容器
docker ps -a
七、啓動容器
docker start 容器id
八、刪除一個容器
docker rm 容器id
九、啓動一個作了端口映射的tomcat
[root@bogon~]# docker run -d -p 8888:8080 tomcat
-d:後臺運行
-p: 將主機的端口映射到容器的一個端口 主機端口:容器內部的端口
十、爲了演示簡單關閉了linux的防火牆
service firewalld status ;查看防火牆狀態
service firewalld stop:關閉防火牆
十一、查看容器的日誌
docker logs container-name/container-id
更多命令參看
https://docs.docker.com/engine/reference/commandline/docker/
能夠參考每個鏡像的文檔
3)、安裝MySQL示例
錯誤的啓動
1 [root@localhost ~]# docker run --name mysql01 -d mysql 2 42f09819908bb72dd99ae19e792e0a5d03c48638421fa64cce5f8ba0f40f5846 3 4 mysql退出了 5 [root@localhost ~]# docker ps -a 6 CONTAINER ID IMAGE COMMAND CREATED STATUS PORTS NAMES 7 42f09819908b mysql "docker-entrypoint.sh" 34 seconds ago Exited (1) 33 seconds ago mysql01 8 538bde63e500 tomcat "catalina.sh run" About an hour ago Exited (143) About an hour ago compassionate_ 9 goldstine 10 c4f1ac60b3fc tomcat "catalina.sh run" About an hour ago Exited (143) About an hour ago lonely_fermi 11 81ec743a5271 tomcat "catalina.sh run" About an hour ago Exited (143) About an hour ago sick_ramanujan 12 13 14 //錯誤日誌 15 [root@localhost ~]# docker logs 42f09819908b 16 error: database is uninitialized and password option is not specified 17 You need to specify one of MYSQL_ROOT_PASSWORD, MYSQL_ALLOW_EMPTY_PASSWORD and MYSQL_RANDOM_ROOT_PASSWORD;這個三個參數必須指定一個
正確的啓動
1 [root@localhost ~]# docker run --name mysql01 -e MYSQL_ROOT_PASSWORD=123456 -d mysql 2 b874c56bec49fb43024b3805ab51e9097da779f2f572c22c695305dedd684c5f 3 [root@localhost ~]# docker ps 4 CONTAINER ID IMAGE COMMAND CREATED STATUS PORTS NAMES 5 b874c56bec49 mysql "docker-entrypoint.sh" 4 seconds ago Up 3 seconds 3306/tcp mysql01
作了端口映射
1 [root@localhost ~]# docker run -p 3306:3306 --name mysql02 -e MYSQL_ROOT_PASSWORD=123456 -d mysql 2 ad10e4bc5c6a0f61cbad43898de71d366117d120e39db651844c0e73863b9434 3 [root@localhost ~]# docker ps 4 CONTAINER ID IMAGE COMMAND CREATED STATUS PORTS NAMES 5 ad10e4bc5c6a mysql "docker-entrypoint.sh" 4 seconds ago Up 2 seconds 0.0.0.0:3306->3306/tcp mysql02
幾個其餘的高級操做
docker run --name mysql03 -v /conf/mysql:/etc/mysql/conf.d -e MYSQL_ROOT_PASSWORD=my-secret-pw -d mysql:tag
把主機的/conf/mysql文件夾掛載到 mysqldocker容器的/etc/mysql/conf.d文件夾裏面
改mysql的配置文件就只須要把mysql配置文件放在自定義的文件夾下(/conf/mysql)
docker run --name some-mysql -e MYSQL_ROOT_PASSWORD=my-secret-pw -d mysql:tag --character-set-server=utf8mb4 --collation-server=utf8mb4_unicode_ci
指定mysql的一些配置參數