Docker 使用 Google 公司推出的 Go 语言 进行开发实现,基于 Linux 内核的 cgroup
,namespace
,以及 AUFS 类的 Union FS
等技术,对进程进行封装隔离,属于 操做系统层面的虚拟化技术。因为隔离的进程独立于宿主和其它的隔离的进程,所以也称其为容器。html
Docker 在容器的基础上,进行了进一步的封装,从文件系统、网络互联到进程隔离等等,极大的简化了容器的建立和维护。使得 Docker 技术比虚拟机技术更为轻便、快捷。java
记住最重要的一点,Dokcer实际是宿主机的一个普通的进程,这也是Dokcer与传统虚拟化技术的最大不一样。linux
使用Docker最重要的一点就是Docker能保证运行环境的一致性,不会出现开发、测试、生产因为环境配置不一致致使的各类问题,一次配置屡次运行。使用Docker,可更快地打包、测试以及部署应用程序,并可减小从编写到部署运行代码的周期。nginx
uname -r
yum update
yum remove docker docker-common docker-selinux docker-engine
ll /etc/yum.repos.d/
yum install -y yum-utils device-mapper-persistent-data lvm2
yum-config-manager --add-repo https://download.docker.com/linux/centos/docker-ce.repo
yum list docker-ce --showduplicates | sort -r
yum install docker-ce
yum install docker-ce-<VERSION>
安装指定版本systemctl start docker
dokcer run hello-world
docker search
docker search nginx
Docker就会在Docker Hub中搜索含有“nginx”这个关键词的镜像仓库docker pull
docker pull nginx
Docker就会在Docker Hub中下载含有“nginx”最新版本的镜像docker pull reg.jianzh5.com/nginx:1.7.9
下载指定仓库地址标签的nginx镜像docker images
docker rmi
docker rmi hello-world
删除咱们刚刚下载的hello-world
镜像docker build
docker run
docker run nginx -p 8080:80
,将容器的80端口映射到宿主机的8080端口,而后使用localhost:8080
就能够查看容器中nginx的欢迎页了 docker run -d -p 80:80 -v /dockerData/nginx/conf/nginx.conf:/etc/nginx/nginx.conf nginx
挂载宿主机的/dockerData/nginx/conf/nginx.conf
的文件,这样就能够在宿主机对nginx
进行参数配置了,注意目录须要用绝对路径,不要使用相对路径,若是宿主机目录不存在则会自动建立。 docker run -d -p 80:80 --rm nginx
docker run -name niginx -d -p 80:80 - nginx
docker ps
-a
参数后列出全部的容器(包括已中止的)docker stop
docker stop 5d034c6ea010
后面跟的是容器ID,也可使用容器名称docker start
docker run
是新建容器并启动,docker start
是启动中止的容器,如docker start 5d034c6ea010
docker restart
docker stop
,而后再执行docker start
,如docker restart 5d034c6ea010
docker exec -it 容器id /bin/bash
docker exec -it 5d034c6ea010 /bin/bash
,就至关于进入了容器自己的操做系统docker rm
docker rm 5d034c6ea010
后面跟的是容器ID,删除容器以前须要先中止容器运行docker cp
docker cp 5d034c6ea010:/etc/nginx/nginx.conf /dockerData/nginx/conf/nginx.conf
将容器的目录文件拷贝到宿主机指定位置,容器ID能够替换成容器名。若是咱们须要一个nginx容器,而且须要在宿主机上直接修改nginx的配置文件、默认主页,在宿主机能够实时看到容器nginx的日志。咱们能够按照以下的方式一步一步完成。spring
docker run -d -p 8081:80 --name nginx --rm nginx
docker exec -it 9123b67e428e /bin/bash
docker cp nginx:/etc/nginx/nginx.conf /dockerData/nginx/conf/nginx.conf
导出配置文件 nginx.confdocker cp nginx:/etc/nginx/conf.d /dockerData/nginx/conf/conf.d
导出配置目录 conf.ddocker stop 9123b67e428e
,因为加了--rm参数,容器会自动删除再以以下命令启动容器,完成目录挂载docker
docker run -d -p 8081:80 --name nginx \ -v /dockerData/nginx/conf/nginx.conf:/etc/nginx/nginx.conf \ -v /dockerData/nginx/conf/conf.d:/etc/nginx/conf.d \ -v /dockerData/nginx/www:/usr/share/nginx/html \ -v /dockerData/nginx/logs:/var/log/nginx nginx复制代码
http://192.168.136.129:8081/
/dockerData/nginx/logs
查看日志 /usr/share/nginx/html/
被挂载到了服务器上面的/dockerData/nginx/www
目录下,原来的欢迎页面在dockerData/nginx/www
是没有的,全部就报错了,这里咱们随便建一个。创建默认主页shell
#打开项目文件
cd /dockerData/nginx/www
#使用vim 建立并编辑文件
vi index.html
#此时咱们会进入vim界面,按 i 插入,而后输入
<h1 align="center">Hello,Welcome to Docker World</h1>
#输入完后,按 esc,而后输入 :wq复制代码
咱们可使用Dockfile构建一个镜像,而后直接在docker中运行。Dockerfile文件为一个文本文件,里面包含构建镜像所需的全部的命令,首先咱们来认识一下Dockerfile文件中几个重要的指令。vim
FROM
FROM openjdk:8-jdk-alpine
基础镜像若是能够的话最好使用alpine版本的,采用alpline版本的基础镜像构建出来的镜像会小不少。RUN
RUN指令用来执行命令行命令的。它有一下两种格式:segmentfault
RUN echo '<h1>Hello, Docker!</h1>' > /usr/share/nginx/html/index.html
CMD
CMD指令格式和RUN类似,也是两种格式centos
* shell 格式:CMD <命令> * exec 格式:CMD ["可执行文件", "参数1", "参数2"...] * 参数列表格式:CMD ["参数1", "参数2"...]。在指定了 ENTRYPOINT 指令后,用 CMD 指定具体的参数。 复制代码
ENTRYPOINT
ENTRYPOINT
的格式和 RUN
指令格式同样,分为 exec 格式和 shell 格式。 ENTRYPOINT
的目的和 CMD
同样,都是在指定容器启动程序及参数。ENTRYPOINT
在运行时也能够替代,不过比 CMD
要略显繁琐,须要经过 docker run
的参数 --entrypoint
来指定。
当指定了 ENTRYPOINT
后,CMD
的含义就发生了改变,再也不是直接的运行其命令,而是将 CMD
的内容做为参数传给 ENTRYPOINT
指令,换句话说实际执行时,将变为:
<ENTRYPOINT> "<CMD>"复制代码
COPY & ADD
COPY demo-test.jar app.jar
或ADD demo-test.jar app.jar
。ADD
指令比COPY
高级点,能够指定一个URL地址,这样Docker引擎会去下载这个URL的文件,若是ADD
后面是一个tar
文件的话,Dokcer引擎还会去解压缩。 COPY
,由于 COPY
的语义很明确,就是复制文件而已,而 ADD
则包含了更复杂的功能,其行为也不必定很清晰。EXPOSE
docker run -P
时,会自动随机映射 EXPOSE 的端口。EXPOSE
和在运行时使用 -p <宿主端口>:<容器端口>
区分开来。-p
,是映射宿主端口和容器端口,换句话说,就是将容器的对应端口服务公开给外界访问,而 EXPOSE
仅仅是声明容器打算使用什么端口而已,并不会自动在宿主进行端口映射。ENV
这个指令很简单,就是设置环境变量,不管是后面的其它指令,如 RUN,仍是运行时的应用,均可以直接使用这里定义的环境变量。它有以下两种格式:
ENV <key> <value>
ENV <key1>=<value1> <key2>=<value2>...
VOLUME
VOLUME /tmp
docker run -d -v mydata:/tmp xxxx
LABEL
你能够为你的镜像添加labels,用来组织镜像,记录版本描述,或者其余缘由,对应每一个label,增长以LABEL开头的行,和一个或者多个键值对。以下所示:
LABEL version="1.0" LABEL description="test"复制代码
咱们以一个简单的SpringBoot项目为例构建基于SpringBoot应用的镜像。
功能很简单,只是对外提供了一个say
接口,在进入这个方法的时候打印出一行日志,并将日志写入日志文件。
@SpringBootApplication
@RestController
@Log4j2
public class DockerApplication {
public static void main(String[] args) {
SpringApplication.run(DockerApplication.class, args);
}
@GetMapping("/say")
public String say(){
log.info("get say request...");
return "Hello,Java日知录";
}
}复制代码
咱们使用maven将其打包成jar文件,放入一个单独的文件夹,而后按照下面步骤一步步构建镜像并执行
在当前文件夹创建Dockerfile文件,文件内容以下:
FROM openjdk:8-jdk-alpine
#将容器中的/tmp目录做为持久化目录
VOLUME /tmp
#暴露端口
EXPOSE 8080
#复制文件
COPY docker-demo.jar app.jar
#配置容器启动后执行的命令
ENTRYPOINT ["java","-Djava.security.egd=file:/dev/./urandom","-jar","/app.jar"]复制代码
docker built -t springboot:v1.0 .
.
结尾。docker run -v /app/docker/logs:/logs -p 8080:8080 --rm --name springboot springboot:v1.0
http://192.168.136.129:8080/say
tail -100f /app/docker/logs/docker-demo-info.log
连接:https://segmentfault.com/a/1190000021098609
来源:思否