为了解决环境配置的难题,囊括操作系统的设置,各种库和组件的安装。避免自家软件只能在自家的机器上跑起来:
解决办法:
- 虚拟机: 虽然可以通过虚拟机还原软件的原始环境,但是缺点也很多,比如资源占用问题,启动时间长等问题。
- Linux容器: 不是模拟一个完整的操作系统,而是隔离进程,容器里面的进程接触到的资源都是虚拟出来的。
Vagrant和Docker都是虚拟化技术:Vagrant是基于virtualbox的虚拟机构建的开发环境,但是Docker是继续LXC的轻量级容器虚拟技术
Docker属于对于Linux容器的一种封装,直接调用容器的接口即可
它是一个使用Go语言编写的基于Linux的容器,一次封装,到处运行。
它将应用以及应用所需要的东西打包成一个文件,运行这个文件即可生成整个虚拟容器。
Docker的三大用途:
- 提供一次性的环境,提供单元测试和构建的环境
- 云服务,容器可以随时关闭与开启
- 微服务架构,可以使用多个容器运行多个服务 微服务思想:软件把任务外包出去,让各种外部服务完成这些任务,软件本身只是底层服务的调度中心和组装层。
安装运行Docker:
我这里直接使用 sudo apt install docker.io
进行安装
运行Docker命令的时候,需要确保本机起了Docker服务:
sudo service docker start
或者 sudo systemctl start docker
这里注意Docker命令需要sudo权限,所以把用户加入Docker用户组,这样可以避免每次输入sudo:
sudo usermod -aG docker $USER
然后需要把计算机logout 然后login一下
image镜像文件:
Docker把应用以及应用的依赖全部打包到image文件里面 所以通过image文件,可以直接生成Docker容器。
image文件相当于容器的模板,Docker根据这个模板生成一个容器实例,所以可以通过image文件生成多个同时运行的实例。
可以列出本机所有的image文件: docker image ls
也可以删除某个image文件: docker image rm [name]
image文件制作后可以上传到网上的仓库,Docker有一个官方的仓库为Docker Hub。
但是国内访问Docker的速度很慢,所以需要把仓库的网址改成国内的镜像网站:
打开/etc/default/docker文件,然后加上:
DOCKER_OPTS="--registry-mirror=https://registry.docker-cn.com"
然后重启Docker服务: sudo service docker restart
运行一个简单的容器实例:
将image文件抓取到本地: docker image pull library/hello-world
Docker官方提供的image文件都是放在library这个组里面的
然后运行这个image文件:docker container run hello-world
这个docker container run 具有找不到指定文件就会自动抓取的功能
有些容器不会自动终止,因为提供的是服务,所以需要手动终止:
docker container kill [containID]
由于image文件生成的容器实例也是一个容器文件,所以容器生成后,一共两个文件:image文件和容器文件
列出正在运行的container: docker container ls
列出本机所有的container:docker container ls --all
这个生成的是containerID,关闭容器也是需要这个ID
删除容器: docker container rm [ID]
制作一个Docker容器
如何生成image文件:使用Dockerfile文件,他是一个文本文件用于配置image,Docker根据这个文件生成二进制的image文件
例子:让用户在Docker容器里面运行Koa框架:
首先下载源码:
git clone https://github.com/ruanyf/koa-demos.git
cd koa-demos
然后在项目根目录下新建一个文本文件Dockerfile,写入
FROM node:8.4 #表示该image文件继承自官方的node image,这里表示版本为8.4的node
COPY . /app #将当前目录下的所有文件都拷贝到image文件的/app路径下
WORKDIR /app #指定工作目录为/app
RUN npm install --registry=https://registry.npm.taobao.org #在/app这个目录下安装所有依赖,这样所有依赖文件都被打包进了image文件
EXPOSE 3000 #将端口3000暴露出来,允许外部连接这个端口
然后创建image文件:
docker image build -t koa-demo .
docker image build -t koa-demo:0.0.1 .
-t后面表示这个image文件名字,冒号后面指定标签,最后一个点表示Dockerfile文件路径,由于在根目录,所以是一个点
然后生成容器container:
docker container run -p 8000:3000 -it koa-demo:0.0.1 /bin/bash
-p后面的8000:3000,表示将容器的3000端口映射到本机的8000端口
-it 表示容器的shell映射到当前的shell
/bin/bash 表示容器启动后,内部执行的第一个命令,这里是启动bash保证能使用shell
如果一切正常返回:
root@66d80f4aaf1e:/app#
其他有用的命令:
docker container start [containerID] #用来启动已有的停止运行的容器
docker container stop [containerID] #用于终止容器运行
docker container logs [containerID] #用于查看Docker容器的输出
docker container exec -it [containerID] /bin/bash #用于进入一个正在运行的容器
docker container cp [containID]:[/path/to/file] . #用于从正在进行的容器里面将文件拷贝到本机
网友评论