Docker 在容器的基礎上,進行了進一步的封裝,從文件系統、網絡互聯到進程隔離等等,極大的簡化了容器的建立和維護。使得 Docker 技術比虛擬機技術更爲輕便、快捷。html
下面的圖片比較了 Docker 和傳統虛擬化方式的不一樣之處。傳統虛擬機技術是虛擬出一套硬件後,在其上運行一個完整操做系統,在該系統上再運行所需應用進程;而容器內的應用進程直接運行於宿主的內核,容器內沒有本身的內核,並且也沒有進行硬件虛擬。所以容器要比傳統虛擬機更爲輕便。mysql
若是按面向對象思想:鏡像類好比類,容器類好比實例
公有倉庫:https://hub.docker.com/linux
Docker 引擎是一個包含如下主要組件的客戶端服務器應用程序。git
Docker 引擎組件的流程以下圖所示:github
如下基於Centos7以上版本。
centos7安裝:https://www.osyunwei.com/arch...
docker安裝:
下載安裝web
$ curl -fsSL get.docker.com -o get-docker.sh $ sudo sh get-docker.sh --mirror Aliyun
啓動sql
$ sudo systemctl enable docker $ sudo systemctl start docker
配置Docker 國內加速器docker
$ curl -sSL https://get.daocloud.io/daotools/set_mirror.sh | sh -s http://f1361db2.m.daocloud.io
下載鏡像:shell
$ docker pull tomcat
解析:docker pull [選項] [Docker Registry 地址[:端口號]/]倉庫名[:標籤]
啓動容器:apache
$ docker run -it --rm tomcat bash
$docker run --name webserver -d -p 8080:8080 tomcat
解析: -it 指:i爲交互式操做,t爲終端;--rm指容器退出後隨之將其刪除;tomcat指你要啓動的鏡像;bash指tomcat中的shell控制檯;--name 指定名稱;-d 後臺運行; -p 8080:8080 指定端口號(第一個爲宿主機端口,第二個爲docker的端口。
交互式進入容器:
docker exec -it <容器id> bash
查看運行中的容器:
docker ps -a
刪除容器:
docker rm <容器id>
查看容器運行日誌:
docker logs -f -t <容器id或容器名稱>
解析:
-f:跟蹤容器日誌的最近更新;
-t:顯示容器日誌的時間戳;
清除虛懸鏡像:
docker image prune -a -f
標記本地鏡像,將其納入某一倉庫
docker tag [options "o">] <image>[:tag "o">] [repository/ "o">][username/]name "o">[:tag]
解析:-f 覆蓋已有標記。
將鏡像推送至遠程倉庫,默認爲 Docker Hub
docker push name[:tag "o">]
更多命令能夠參考【這裏】
在一個/usr/local/docker文件中寫一個名爲Dockerfile的文件
#pull down centos image FROM centos MAINTAINER test@test.com #copy jdk and tomcat into image ADD ./apache-tomcat-7.0.70.tar.gz /root ADD ./jdk-7u80-linux-x64.tar.gz /root #set environment variable ENV JAVA_HOME /root/jdk1.7.0_80 ENV PATH $JAVA_HOME/bin:$PATH #define entry point which will be run first when the container starts up ENTRYPOINT /root/apache-tomcat-7.0.70/bin/startup.sh && tail -F /root/apache-tomcat-7.0.70/logs/catalina.out
解析:整體看來就是按照Dockerfile的命令規則進行運行shell指令
關鍵命令:
FROM: 指定基礎鏡像
RUN: 執行命令
COPY: <源路徑>... <目標路徑>
ADD:跟COPY類似,若是源文件是tar包時,會自動解壓。(通常用copy指令)
CMD: 容器啓動命令
ENTRYPOINT: 入口點
VOLUME: 定義匿名卷
EXPOSE: 暴露端口
WORKDIR: 指定工做目錄
USER : 指定當前用戶
ENV: 設置環境變量
編譯構建:
docker build [選項] <上下文路徑/URL/->
### 最後有一個點的,它表示上下文。 docker build -t app .
看到 docker build 命令最後有一個 .。. 表示當前目錄,而 Dockerfile 就在當前目錄。
-t app :指定了最終鏡像的名稱爲app
參考文檔
Docker Compose 將所管理的容器分爲三層,
工程(project) 由一組關聯應用容器組成的一個完整的業務單元。
服務(service) 一個應用的容器,實際上若干個運行着相同鏡像的容器實例。
容器(container)
Compose就是經過命令對項目中的一組容器的生命週期進行便捷的管理。
安裝:官網地址:https://github.com/docker/com...
$ sudo curl -L "https://github.com/docker/compose/releases/download/1.24.0/docker-compose-$(uname -s)-$(uname -m)" -o /usr/local/bin/docker-compose $ sudo chmod +x /usr/local/bin/docker-compose $ sudo ln -s /usr/local/bin/docker-compose /usr/bin/docker-compose $ docker-compose --version
部署項目
在/usr/local/docker目錄下新建一個docker-compose.yml文件
version: "3" services: web: restart: always image: tomcat container_name: web ports: - 8080:8080 volumes: - /usr/local/docker/nblog/webapps:/usr/local/tomcat/webapps mysql: restart: always image: mysql:5.7.25 container_name: mysql ports: - 3306:3306 environment: TZ: Asia/Shanghai MYSQL_ROOT_PASSWORD: root command: --character-set-server=utf8mb4 --collation-server=utf8mb4_general_ci --explicit_defaults_for_timestamp=true --lower_case_table_names=1 --max_allowed_packet=128M volumes: - db_data:/var/lib/mysql volumes: db_data:
docker-compose.yml經常使用參數解析:
restart:啓動容器自自啓動。
image:鏡像
container_name:自定義容器名
ports:端口,第一個是宿主機,第二個是docker中的端口
volumes: 數據卷,就是宿主機的目錄被docker共享。這裏就是你將你的應用放到指定目錄,它就會自動引用進docker容器中。
environment:環境變量設置。
更多配置:https://docs.docker.com/compo...
啓動
$ docker-compose up -d
-d:指後臺運行
跟蹤日誌
$ docker-compose logs -f tomcat
-f:相似於tail -f
卸載
$ docker-compose down
Docker持續集成
Docker與微服務更配哦。
資源:
Docker官方文檔
DockerHub倉庫
DockerCompose
一些經常使用的鏡像
若是對 Java、大數據感興趣請長按二維碼關注一波,我會努力帶給大家價值。以爲對你哪怕有一丁點幫助的請幫忙點個贊或者轉發哦。