Docker容器是一个开源的利用容器引擎,它可能主动执行重复性工作,例如搭建和配置开发环境,用户能够不便地创立和应用容器,还能够进行版本治理、复制、分享、批改。有很多初学云计算的同学不分明Docker容器的应用办法以及利用场景,接下来就给大家简略分享一下云计算学习路线图素材课件:Docker容器利用场景剖析。
Docker是一个应用 Go 语言开发的,并且开源的利用容器引擎,基于LXC(Linux Container)内核虚拟化技术实现,提供一系列更强的性能,比方镜像、Dockerfile等;
Docker理念是将利用及依赖包打包到一个可移植的容器中,可公布到任意Linux发行版的Docker引擎上,应用沙箱机制运行程序,程序之间互相隔离;
Docker采纳C/S架构,Dcoker daemon作为服务端承受来自客户端申请,并解决这些申请,比方创立、运行容器等;客户端为用户提供一系列指令与Docker Daemon交互;
Docker应用Google公司推出的Go语言进行开发实现,基于Linux内核的cgroup、namespace以及AUFS类的UnionFS等技术,对过程进行封装隔离,属于操作系统层面的虚拟化技术。目前Docker容器的利用场景包含以下几种:
Docker部署Mongodb环境
1、近程获取Mongodb镜像
docker pull mongo
2、创立一个docker容器
docker run -p 27017:27017 -v /data/db --name docker_mongodb -d mongo
在下面的命令中,几个命令参数的具体解释如下:
-p 指定容器的端口映射(非凡阐明:后面的是本机端口,前面的是容器的端口,增加-p参数被动将容器外部端口给暴漏出来,将服务器的27017端口映射到容器的27017端口,这样在外网就可通过 服务器的27017端口拜访到咱们的服务,Mongodb默认端口为27017。
-v 为设置容器的挂载目录,这里是将即本机中的目录挂载到容器中的/data/db中,作为Mongodb的存储目录
--name 为设置该容器的名称
-d 设置容器以守护过程形式运行
3、测试连贯容器中的Mongodb
Docker部署Node我的项目残缺流程(DockerFile实际)
1、应用Koa2初始化一个Node我的项目,通过Mongose中间件连贯Mogodb数据库,实现一个根底接口Mogodb插入数据。
2、在我的项目根目录下创立.dockerignore文件,把不须要打包进Docker Image里的文件进行过滤:
/usr/src/nodejs/dockerstudy/.dockerignore
.git
node_modules
3、在我的项目的根目录中创立Dockerfile文件,部署Node我的项目的时候,会有一个Dockerfile 文件配置。
/usr/src/nodejs/hello-docker/Dockerfile
FROM node:10.0
在容器中创立一个目录
RUN mkdir -p /usr/src/nodejs/
定位到容器的工作目录
WORKDIR /usr/src/nodejs/
RUN/COPY 是分层的,package.json 提前,只有没批改,就不会从新安装包
COPY package.json /usr/src/app/package.json
RUN cd /usr/src/app/
RUN npm i
把当前目录下的所有文件拷贝到 Image 的 /usr/src/nodejs/ 目录下
COPY . /usr/src/nodejs/
EXPOSE 3000
CMD npm start
4、代码环节暂且告一段落,将带有Dockerfile提交到github或gitlab等。
5、首先检出代码,把我的项目克隆到指定目录。
6、进入目录构建。
7、通过镜像dockerstudy创立一个容器并运行。
8、进入容器。
9、日志查看查看运行日志。
优雅部署形式 DockerCompose
Compose是Docker官网开源的一个我的项目,能够治理多个Docker容器组成一个利用,例如Web服务,除了服务自身还有数据库、Redis、Nginx等一系列相关联服务须要装置。有个Compose的反对,咱们只须要定义一个YAML格局的配置文件(docker-compose.yml),来编写一个我的项目所须要的多个容器配置及调用关系,通过简略的命令即可同时开始或者敞开这些容器。Compose定位是定义和运行多个Docker容器的利用。