赞
踩
Docker是使用最广泛的开源容器引擎
一种操作系统基本的虚拟化技术
一种简单的应用程序打包工具
依赖Linux内核特性:Namespace(资源隔离) 和 Cgroup(资源限制)
注:每个容器拥有一套和宿主机完全隔离的文件系统(共用linux内核),程序在这个虚拟容器里运行,就好像在真实的物理机上运行一样。
- 容器是一个操作系统级别下的虚拟化技术,运行一个容器就行运行一个进程一样
- 容器依赖linux内核特性:Namespace(资源隔离)和Cgroups(资源限制)
资源隔离:
资源限制:
docker设计小巧,部署迁移快速,运行高效,按照应用隔离,管理人员可以看到所有容器的内容。
虚拟化技术比较臃肿,需要先创建新的系统,按照系统隔离,管理员无法看到系统内部信息。
举例:
Docker客户端(Client): docker 命令行工具,用户也可以通过 REST API 与服务器通信
Docker服务器(Docker daemon): 服务器组件,以 Linux 后台服务的方式运行, Docker daemon 运行在 Docker host 上,负责创建、运行、监控容器,构建、存储镜像
Docker镜像(Image): 可将 Docker 镜像看着只读模板,通过它可以创建 Docker 容器
镜像仓库(Registry): Registry 是存放 Docker 镜像的仓库,Registry 分私有和公有两种
Docker容器(Container): Docker 容器就是 Docker 镜像的运行实例
单项目打包
整套项目打包
新开源技术试用
一个项目版本快速迭代的测试场景,需要一个合理的CI(持续集成)/CD(持续部署)环境支撑。
CI/CD是一个周期性自动化项目测试流程,包括构建、部署、测试、发布等工作,很少需要人工干预。
Docker通过项目镜像构建和快速部署,打通测试环境与生产环境,高度保持多个环境之间一致性。
高效的利用资源
单台机器得部署多个应用;
应用之间互相隔离(微服务);
应用之间不能发生资源抢占,每个应用只能使用事先注册申请的资源。
# 1)安装依赖包 yum install -y yum-utils device-mapper-persistent-data lvm2 # 2)添加Docker软件包源(否则doker安装的不是新版本) yum-config-manager \ --add-repo \ https://download.docker.com/linux/centos/docker-ce.repo # 3)安装Docker CE yum install -y docker-ce # 4)启动Docker服务并设置开机启动 systemctl start docker systemctl enable docker # 5)测试docker是否安装成功(hello-world是官方提供的一个测试镜像) docker run hello-world # 6)查看docker基本信息 docker info docker version
# 1、创建一个nginx容器
docker run -it nginx
# 2、查看docker运行的容器(可以获取到这个容器的id)
docker ps
# 3、访问这个容器
# 进入这个nginx容器(进入的文件系统和宿主机是完全隔离的,有自己独立的文件系统)
docker exec -it 73877e65c07d bash
# 4、查看当前容器的 IP
docker inspect 73877e65c07d # 73877e65c07d是通过docekr ps查看到的容器ID
curl 172.17.0.2 # 测试这个nginx容器是否可以访问
Copyright © 2003-2013 www.wpsshop.cn 版权所有,并保留所有权利。