https://www.runoob.com/docker/docker-compose.html
Compose 使用的三个步骤:
使用 Dockerfile 定义应用程序的环境。
使用 docker-compose.yml 定义构成应用程序的服务,这样它们可以在隔离环境中一起运行。
最后,执行 docker-compose up 命令来启动并运行整个应用程序。
一旦你对容器做出所需的修改,你可以使用 docker commit 命令将容器保存为一个新的镜像。在容器修改后,你可以执行以下命令:
docker commit
new-image-name 是你想要给新镜像命名的名称。
tag 是标签,用于区分不同的镜像版本。
例如:docker commit my-container new-image:latest
kubectl run -i --tty busybox --image=busybox --restart=Never – sh
1.根据基础镜像,生成新镜像,基于镜像运行一个容器,修改容器内容,重新Commit生成新镜像
docker pull centos:latest
docker run -it centos /bin/bash
yum install wget/vim等命令
docker commit 2ef48c7e3da0 centos:shiying生成新镜像
docker commit -m=“首次提交” -a=“一灰灰Blog” dd85eb055fe8 centos:shiying
注意:运行 yum install wget/vim等命令会报错,因为centos:centos8 作为虚拟机来测试linux命令,由于Centos8于2021年年底停止了服务,在使用yum源安装时候
Error: Failed to download metadata for repo ‘appstream‘: Cannot prepare internal mirrorlist
解决方式1
将镜像从 mirror.centos.org 更改为 vault.centos.org
cd /etc/yum.repos.d/
修改镜像
sed -i ‘s/mirrorlist/#mirrorlist/g’ /etc/yum.repos.d/CentOS-* &&
sed -i ‘s|#baseurl=http://mirror.centos.org|baseurl=http://vault.centos.org|g’ /etc/yum.repos.d/CentOS-* &&
yum makecache &&
yum update -y
现在可以正常安装vim了:yum -y install vim
解决方式2
更换镜像版本, 使用centos:centos7
docker commit {容器ID} {镜像名称}
docker run -i -t -d --name test_command centos:shiying
• 其中关键参数为-d,指定容器运行与前台或者后台,不加上时前台
• -i: 打开 STDIN,用于控制台交互
• -t: 支持终端登录
2.获取容器所有信息
docker exec -it test_command /bin/bash
docker inspect test_command
docker logs -f -t --since=“2019-05-11” --tail=10 test_command
docker cp preinstall_check_cloud.sh test_command:/tmp
docker cp test_command:/tmp/ks-script-4luisyla ./
增加组件:
docker cp ./ mynodered:/usr/src/node-red/node_modules/@ali/node-red-contrib-rocketmq
DockerFile指令语法:
FROM 引用基础镜像
ARG 构建参数,ARG指令定义了一个变量,ARG指令定义的参数,在docker build命令中以–build-arg 形式赋值。
ENV 设置环境变量,设置的变量在容器运行时保持,可以在Run 指令中使用
区别:
ARG指令定义了用户可以在编译时或者运行时传递的变量
ENV指令是在dockerfile里面设置环境变量,不能在编译时或运行时传递
RUN 在镜像中执行的命令,每条 RUN 指令将在当前镜像基础上执行指定命令,并提交为新的镜像。当命令较长时可以使用 \ 来换行
COPY 宿主机复制文件到容器中
ADD 与COPY指令类似,唯一的不同点是: 对于ADD指令,如果文件是可识别的压缩格式, 则Docker会帮忙解压缩
——容器启动时执行指令——
WORKDIR 为 RUN、CMD、ENTRYPOINT 指令配置工作目录
ENTRYPOINT容器启动后执行的命令,在一个Dockerfile文件中,当出现多个ENTRYPOINT 时只有最后一次有效,ENTRYPOINT [“/home/admin/start.sh”]
CMD 指定启动容器时执行的命令,每个 Dockerfile 只能有一条 CMD 命令,如果有多条,则只有最后一条会被执行。
EXPOSE 容器需要映射到宿主机器的端口
VOLUME 声明了容器中的目录作为匿名卷,并且我们以这个镜像run了一个容器的时候,docker会在安装目录下的指定目录下面生成一个目录来绑定容器的匿名卷(这个指定目录不同版本的docker会有所不同),我当前的目录为:/var/lib/docker/volumes/{容器ID}
总结: volume只是指定了一个目录,用以在用户忘记启动时指定-v参数也可以保证容器的正常运行。比如mysql,你不能说用户启动时没有指定-v,然后删了容器,就把mysql的数据文件都删了,那样生产上是会出大事故的,所以mysql的dockerfile里面就需要配置volume,这样即使用户没有指定-v,容器被删后也不会导致数据文件都不在了。还是可以恢复的。
例子:
FROM registry.cn-beijing.aliyuncs.com/aihub/edgejdk:8-jdk-alpine
COPY ./target/aies-cluster.jar /app/aies-cluster.jar
COPY ./src/main/resources/work/.sh /app/images/
RUN chmod +x /app/images/.sh
WORKDIR /app
ENTRYPOINT [“java”,“-jar”,“aies-cluster.jar”]
FROM nodered/node-red
WORKDIR /usr/src/node-red
RUN npm install node-red-node-smooth
RUN npm install node-red-contrib-kafka-client
RUN npm install node-red-contrib-aliyun-datahub
RUN npm install node-red-contrib-aliyun-oss
RUN npm install node-red-node-mysql
镜像和容器的关系以及文件结构
Docker 镜像是由多个文件系统(只读层)叠加而成,每个层仅包含了前一层的差异部分。当我们启动一个容器的时候,Docker 会加载镜像层并在其上添加一个可写层。容器上所做的任何更改,譬如新建文件、更改文件、删除文件,都将记录与可写层上。容器层与镜像层的结构如下图所示。
容器 = 镜像 + 读写层
容器与镜像最大的区别就在于可写层上。如果运行中的容器修改了现有的一个已存在的文件,那该文件将会从可写层下的只读层复制到可写层,该文件的只读版本仍然存在,只是已经被可写层中该文件的副本所隐藏。
/var/lib/docker/containers,containers目录中存有每个容器的配置文件、环境变量文件、日志文件,目录随着删除容器而删除;
/var/lib/docker/image/overlay2,存储镜像管理数据的目录,以使用的存储驱动命名
• /var/lib/docker/image/overlay2/repositories.json,存储了镜像资源全局描述
/var/lib/docker/overlay2,layer的文件都放在了overlay2 目录
/var/lib/docker/volumes