概念
虚拟机: 模拟整套操作系统,包括软件硬件环境等。对于底层操作系统来讲,虚拟机就是一个普通文件。
Docker: 容器虚拟化技术,将软件工作所需要的库资源和设置打包到一个隔离的容器。
docker三要素:镜像、容器、仓库
镜像:可以堪称java中的对象。容器模板
容器:可以看作是java中的实例。容器是用镜像创建的实例,一个容器运行一个服务。
仓库:保存镜像。
centOS7安装
$ sudo yum install -y yum-utils
aliyun镜像
$ sudo yum-config-manager
–add-repo
http://mirrors.aliyun.com/docker-ce/linux/centos/docker-ce.repo
两个可选命令,默认禁用可不选
$ sudo yum-config-manager --enable docker-ce-nightly
$ sudo yum-config-manager --enable docker-ce-test
更新yum
yum makecache fast
安装docker-ce 社区版,docker-ce-cli 客户端 containerd.io 容器
$ sudo yum install docker-ce docker-ce-cli containerd.io
$ sudo systemctl start docker
配置阿里镜像加速
注册个阿里账户
镜像命令
帮助命令
docker --help
查询本机可运行容器
docker images
查询容器
docker search tomcat
只展示starts超过50的tomcat
docker search -s 50 tomcat
拉取容器
docker pull tomcat
删除容器
docker rmi -f tomcat
删除所有容器
docker rmi -f $(docker images -q)
容器命令
查询docker运行的进程
docker ps
启动交互式容器
docker run -it image
-i :以交互模式运行容器,通常和-t同时使用
-t :为容器重新分配一个伪输入终端,通常与 -i同时使用
退出容器
exit ----容器停止并退出
ctrl+p+q ------容器不停止退出
启动容器
docker start container
删除停止的容器
docker rm container
启动守护式容器
docker run -d container
通过docker ps查询会发现容器已经退出,是因为容器后台运行,就必须有一个前台进程。
指定运行端口号
docker run -it -p 8888:8080 tomcat
8888是docker暴露的端口
8080是tomcat实体的端口
因为运行是要访问docker内部的tomcat
通过访问localhost:8888来访问docker内部的tomcat
随机分配端口
docker run -it -P tomcat
docker随机分配端口,tomcat端口还是8080
查看容器日志
docker logs -f -t --tail 3 container
-f :持续打印最新日志
-t :显示时间戳
–tail n:显示最后n条
查看容器内的进程
docker top container
查看容器内容细节
docker inspect container
进入正在运行的容器
docker attach container
在宿主机直接使用命令操作容器
docker exec -t container 执行命令
拷贝容器中的内容到宿主机
docker cp 容器id:被拷贝文件路径 拷贝到的路径
提交容器副本成为一个新镜像
docker commit -m=“描述信息” -a=“作者” 容器id 要创建的目标镜像名:[标签名]
容器数据卷(容器数据持久化)
使用命令添加数据卷
docker run -it -v /宿主机绝对路径目录:/容器内目录 镜像名
两个路径内的数据共享
使用DockerFile添加
vim DockerFile
# volume test
FROM centos
VOLUME ["/data1","/data2"]
CMD echo "finished, -----------"
CMD /bin/bash
执行build命令
docker build -f /myfile/DockerFile -t hhh/centos .
-------- /myfile/DockerFile 上边编写的脚本路径
---------hhh/centos 别名
记住最后还有一个点,表示当前路径
执行完之后会生成一个hhh/centos的镜像
执行run命令
docker run -it hhh/centos
这时候会创建两个容器卷data1和data2
通过docker inspect 容器id 查看容器卷对应的宿主机路径
通过执行
docker run -it --name 新容器name --volumes-from 上边哪个容器name hhh/centos
实现容器间的数据共享
DockerFile
dockerFile是docker镜像构建文件
构建步骤:1. 编写dockerfile文件;2. 执行docker build;3. 执行docker run
基础
保留字 | 作用 |
---|---|
FROM | 基础镜像,当前新的镜像是基于哪个镜像的 |
MAINTAINER | 镜像维护者的姓名和邮箱地址 |
RUN | 容器构建时需要运行的命令 |
EXPOSE | 当前容器对外暴露出的端口号 |
WORKDIR | 指定创建容器后,终端默认登陆进来的工作目录 |
ENV | 用来在构建镜像过程中设置环境变量 |
ADD | 将宿主机目录下的文件拷贝进镜像且ADD命令会自动处理URL和解压tar压缩包 |
COPY | 类似ADD拷贝文件和目录到镜像中。 COPY 源路径 镜像内位置 COPY [“源路径”, “目标路径”] |
VOLUME | 容器卷位置 |
CMD | 指定一个容器启动时要运行的命令,可以有多个CMD命令但是只有最后一个生效 shell 格式:CMD <命令> exec 格式:CMD[“可执行文件”,“参数”,“参数”,"…"] 参数列表格式:CMD [“参数”,“参数”,"…"],在指定ENTRYPOINT后,用CMD指定具体参数 |
ENTRYPOINT | 目的和CMD一样,多条表示追加 |
ONBUILD | 当构建一个被继承的DockerFIle时运行命令,父镜像在被子镜像继承后,父镜像的ONBUILD被触发 |
推送镜像
本地容器生成镜像,提交到本地
docker commit -a 作者 -m “说明” 容器id 新镜像名称:自定义版本号
管理选择本地仓库、按照操作指南操作
docker compose服务编排
Docker-compose的安装
#安装pip
yum -y install python-pip
#安装docker-compose
pip install docker-compose
#查看版本
docker-compose --version
#卸载
pip uninstall docker-compose
常用指令(要编写docker-compose.yml):
docker-compose up:默认运行docker-compose.yml,
docker-compose -f hhh.yml up:使用 -f指定运行hhh.yml文件
指令 | 描述 |
---|---|
up | 运行, -d 后台运行 |
stop | 停止容器 |
restart | 重启 |
rm | 删除已停用的compose |
ps | 列出compose应用中的各个容器 |
dowm | 停止应用并删除 |
version: "2" #必须指定的,而且总是位于文件的第一行。它定义了 Compose 文件格式
services: # 定义不同的应用服务
nacos: # 应用服务名称
image: nacos/nacos-server:latest #服务镜像版本
container_name: nacos-standalone #服务运行后的容器名称
# env_file: #从配置文件中添加环境变量
# - ../env/nacos-standlone-mysql.env
environment: #环境变量配置
- PREFER_HOST_MODE=hostname
- MODE=standalone
volumes: #挂载 容器卷
- ./standalone-logs/:/home/nacos/logs
- ./init.d/custom.properties:/home/nacos/init.d/custom.properties
ports: #映射端口
- "8848:8848"