1. 程式人生 > 實用技巧 >Docker常用命令&操作以及安裝Mysql示例

Docker常用命令&操作以及安裝Mysql示例

一、Docker常用命令&操作

1)、映象操作

操作命令說明
檢索 docker search 關鍵字 eg:docker search redis 我們經常去docker hub上檢索映象的詳細資訊,如映象的TAG。
拉取 docker pull 映象名:tag :tag是可選的,tag表示標籤,多為軟體的版本,預設是latest
列表 docker images 檢視所有本地映象
刪除 docker rmi image-id 刪除指定的本地映象

https://hub.docker.com/

2)、容器操作

軟體映象(QQ安裝程式)----執行映象----產生一個容器(正在執行的軟體,執行的QQ);

步驟:

1、搜尋映象
  [root@localhost ~]# docker search tomcat
2、拉取映象
  [root@localhost ~]# docker pull tomcat
3、根據映象啟動容器
  docker run --name mytomcat -d tomcat:latest
4、docker ps  
    檢視執行中的容器
5、 停止執行中的容器
    docker stop  容器的id
6、檢視所有的容器
    docker ps -a
7、啟動容器
    docker start 容器id
8、刪除一個容器
    docker rm 容器id
9、啟動一個做了埠對映的tomcat [root@localhost ~]# docker run -d -p 8888:8080 tomcat -d:後臺執行 -p: 將主機的埠對映到容器的一個埠 主機埠:容器內部的埠 10、為了演示簡單關閉了linux的防火牆 service firewalld status ;檢視防火牆狀態 service firewalld stop:關閉防火牆 11、檢視容器的日誌 docker logs container-name/container-id 更多命令參看 https://docs.docker.com/engine/reference/commandline/docker/
可以參考每一個映象的文件 12、進入容器 docker exec -it ubantu /bin/bash -i: 互動式操作。 -t: 終端。 ubuntu: ubuntu 映象。 /bin/bash:放在映象名後的是命令,這裡我們希望有個互動式 Shell,因此用的是 /bin/bash。 要退出終端,直接輸入 exit: 13、重啟容器 docker restart 容器id/名字

二、安裝MySQL示例

docker pull mysql

錯誤的啟動:docker run --name mysql01 -d mysql

[root@localhost ~]# docker run --name mysql01 -d mysql
42f09819908bb72dd99ae19e792e0a5d03c48638421fa64cce5f8ba0f40f5846

mysql退出了
[root@localhost ~]# docker ps -a
CONTAINER ID        IMAGE               COMMAND                  CREATED             STATUS                           PORTS               NAMES
42f09819908b        mysql               "docker-entrypoint.sh"   34 seconds ago      Exited (1) 33 seconds ago                            mysql01
538bde63e500        tomcat              "catalina.sh run"        About an hour ago   Exited (143) About an hour ago                       compassionate_
goldstine
c4f1ac60b3fc        tomcat              "catalina.sh run"        About an hour ago   Exited (143) About an hour ago                       lonely_fermi
81ec743a5271        tomcat              "catalina.sh run"        About an hour ago   Exited (143) About an hour ago                       sick_ramanujan

錯誤日誌:docker logs 42f09819908b

//錯誤日誌
[root@localhost ~]# docker logs 42f09819908b
error: database is uninitialized and password option is not specified 
  You need to specify one of MYSQL_ROOT_PASSWORD, MYSQL_ALLOW_EMPTY_PASSWORD and MYSQL_RANDOM_ROOT_PASSWORD;//這個三個引數必須指定一個

正確的啟動:docker run --name 容器Id -e MYSQL_ROOT_PASSWORD=123456 -d mysql

[root@localhost ~]# docker run --name mysql01 -e MYSQL_ROOT_PASSWORD=123456 -d mysql
b874c56bec49fb43024b3805ab51e9097da779f2f572c22c695305dedd684c5f
[root@localhost ~]# docker ps
CONTAINER ID        IMAGE               COMMAND                  CREATED             STATUS              PORTS               NAMES
b874c56bec49        mysql               "docker-entrypoint.sh"   4 seconds ago       Up 3 seconds        3306/tcp            mysql01

做了埠對映:docker run -p 3306:3306 --name mysql02 -e MYSQL_ROOT_PASSWORD=123456 -d mysql

[root@localhost ~]# docker run -p 3306:3306 --name mysql02 -e MYSQL_ROOT_PASSWORD=123456 -d mysql
ad10e4bc5c6a0f61cbad43898de71d366117d120e39db651844c0e73863b9434
[root@localhost ~]# docker ps
CONTAINER ID        IMAGE               COMMAND                  CREATED             STATUS              PORTS                    NAMES
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的一些配置引數

注意:最新版本(8.0以上)安裝遠端連線需要修改mysql的加密機制,不然會報"2059-Authentication plugin 'caching_sha2_password' cannot be loaded"錯誤

進入docker中的mysql容器:

docker exec -it 容器id  /bin/bash

輸入如下5行命令:

1、grant all on *.* to 'root'@'%';  // 授權 
2、flush privileges; 
3、alter user 'root'@'localhost' identified by '123456' password expire never;  //修改加密規則 
4、ALTER USER 'root'@'%' IDENTIFIED WITH mysql_native_password BY '123456';  // 修改密碼 
5、flush privileges; 

在本地用navicat測試連線,連線成功!