Docker介绍
Docker 是一个开源的应用容器引擎,基于 Go 语言 并遵从 Apache2.0 协议开源。Docker 可以让开发者打包他们的应用以及依赖包到一个轻量级、可移植的容器中,然后发布到任何流行的 Linux 机器上,也可以实现虚拟化。容器是完全使用沙箱机制,相互之间不会有任何接口(类似 iPhone 的 app),更重要的是容器性能开销极低。
Docker五大优势
持续集成、版本控制、可移植性、隔离性和安全性。
Docker架构
Docker Engine是一个C/S架构的应用程序,主要包含下面几个组件:
Dockerd:常驻后台进程
REST API Server:用来和Dockerd交互的
命令行CLI接口:通过和REST API进行交互(我们经常使用的 docker 命令)
Docker概念图解
常用命令
获取镜像
docker pull [选项] [Docker Registry 地址[:端口]/]仓库名[:标签]
Docker镜像仓库地址:地址的格式一般是 <域名/IP>[:端口号],默认地址是 Docker Hub。
仓库名:这里的仓库名是两段式名称,即<用户名>/<软件名>。对于 Docker Hub,如果不给出用户名,则默认为 library,也就是官方镜像。比如:
docker pull busybox
docker pull busybox:1.24.0
列出镜像
docker image ls
或者
docker images
启动容器
docker run [选项] <镜像>
运行一个小系统,输出字符串
docker run busybox:latest /bin/echo 'Hello world'
运行一个nginx镜像,-p 在本地映射一个端口
docker run --name test-web -d -p 80:80 nginx
查看容器进程
docker ps
进入容器
docker exec -it <容器名称> bash
docker exec -it test-web bash
提交镜像
如果对基础镜像进行了修改,需要保留修改后的镜像,就可以提交到本地。
以上面为nginx容器基础
echo 'commit html' > /usr/share/nginx/html/index.html
exit
查看镜像内容变动
docker diff test-web
保存提交镜像
docker commit --author "cuihao" --message "修改首页内容" test-web nginx:v1
查看所有容器
docker container ls -a
启动/重启/停止/删除容器进程
docker container stop/restart/start/rm <容器名>
删除镜像
docker image rm [选项] <镜像1> [<镜像2> ...]
或者
docker rmi [选项] <镜像1> [<镜像2> ...]
推送镜像到仓库
登陆docker hub
docker login --username=haodevops
修改本地镜像tag
docker tag nginx:v1 haodevops/nginx:v1
上传镜像
docker push haodevops/nginx:v1
导入导出镜像
将镜像导出为文件
docker save nginx:v1 | gzip > nginx-v1.tar.gz
将镜像导入
docker rmi nginx:v1
docker load -i nginx-v1.tar.gz
Dockerfile使用
制作jdk镜像
编写Dockerfile
cat Dockerfile
FROM centos:centos7.6.1810
RUN mkdir /usr/local/jdk
WORKDIR /usr/local/java
ADD jdk-8u181-linux-x64.tar.gz /usr/local/java/
RUN ln -s /usr/local/java/jdk1.8.0_181 /usr/local/java/jdk
ENV JAVA_HOME /usr/local/java/jdk
ENV JRE_HOME ${JAVA_HOME}/jre
ENV CLASSPATH .:${JAVA_HOME}/lib:${JRE_HOME}/lib
ENV PATH $JAVA_HOME/bin:$PATH
构建镜像
docker build -t jdk:1.8.0_181 .
数据挂载
如果数据在容器里面,容器消亡的话数据也会没有,如果想保存下来,可以将容器里面的数据挂载到宿主机。
docker run --name test-web --mount type=bind,source=/tmp/nginxlog/,target=/var/log/nginx/ -d -p 80:80 nginx
source:宿主机本地目录
target:容器里面目录