镜像(Image)
Docker 镜像 是一个特殊的文件系统,除了提供容器运行时所需的程序、库、资源、配置等文件外,
还包含了一些为运行时准备的一些配置参数(如匿名卷、环境变量、用户等)。镜像 不包含 任何动态数据,其内容在构建之后也不会被改变。
容器(Container)
镜像(Image)和容器(Container)的关系,就像是面向对象程序设计中的 类 和 实例 一样,
镜像是静态的定义,容器是镜像运行时的实体。容器可以被创建、启动、停止、删除、暂停等。
仓库(Repository)
容器的实质是进程,但与直接在宿主执行的进程不同,容器进程运行于属于自己的独立的 命名空间。
因此容器可以拥有自己的 root 文件系统、自己的网络配置、自己的进程空间,甚至自己的用户 ID 空间。
容器内的进程是运行在一个隔离的环境里,使用起来,就好像是在一个独立于宿主的系统下操作一样。
这种特性使得容器封装的应用比直接在宿主运行更加安全。
安装docker
- CentOS7 环境下
yum remove docker docker-client docker-client-latest docker-common docker-latest docker-latest-logrotate docker-logrotate docker-selinux docker-engine-selinux docker-engine
yum install -y yum-utils device-mapper-persistent-data lvm2
yum-config-manager --add-repo https://download.docker.com/linux/centos/docker-ce.repo
yum list docker-ce --showduplicates | sort -r
sudo yum install -y docker-ce
sudo systemctl start docker
sudo systemctl enable docker
- 启动
systemctl start docker
- 测试是否成功
docker version
docker pull hello-world
docker run hello-world
- Ubuntu 下
apt-get update
apt-get install ca-certificates curl gnupg lsb-release
mkdir -p /etc/apt/keyrings
curl -fsSL https://download.docker.com/linux/ubuntu/gpg | sudo gpg --dearmor -o /etc/apt/keyrings/docker.gpg
echo "deb [arch=$(dpkg --print-architecture) signed-by=/etc/apt/keyrings/docker.gpg] https://download.docker.com/linux/ubuntu $(lsb_release -cs) stable" | sudo tee /etc/apt/sources.list.d/docker.list > /dev/null
apt-get install docker-ce docker-ce-cli containerd.io docker-compose-plugin
apt-get update
apt-get install docker-ce docker-ce-cli containerd.io docker-compose-plugin
测试是否成功同上
下载安装docker-compose
https://github.com/docker/compose/releases # 也可curl直接下到本地文件
# 下载对应版本的文件并重命名"docker-compose", 放到/usr/local/bin/ 下
mv docker-compose-linux-armv6 docker-compose
sudo chmod +x /usr/local/bin/docker-compose # 添加执行权限
docker-compose --version # 验证安装成功否
一个FastApi用docker-compose部署的小demo
- Dockerfile
FROM python:3.7
ADD requirements.txt .
RUN python -m pip install -r requirements.txt -i https://pypi.tuna.tsinghua.edu.cn/simple
RUN /bin/cp /usr/share/zoneinfo/Asia/Shanghai /etc/localtime && echo 'Asia/Shanghai' >/etc/timezone
WORKDIR /home/data_server
EXPOSE 8899
CMD ["uvicorn", "main:app", "--host=0.0.0.0", "--port=8899"]
- docker-compose.yml
version: "3.8"
services:
data_market:
build: data_market
container_name: data_market
working_dir: /home/data_server
volumes:
- /home/data_server:/home/data_server
ports:
- "8899:8899"
network_mode: "bridge"
- 文件目录层级
PS: 刚接触Docker的同学最容易迷糊的地方就是Dockerfile应该放在哪里
关于Dockerfile可查看https://blog.csdn.net/wyh1618/article/details/125317313?ops_request_misc=%257B%2522request%255Fid%2522%253A%2522167230587416800186517334%2522%252C%2522scm%2522%253A%252220140713.130102334.pc%255Fblog.%2522%257D&request_id=167230587416800186517334&biz_id=0&utm_medium=distribute.pc_search_result.none-task-blog-2blogfirst_rank_ecpm_v1~rank_v31_ecpm-1-125317313-null-null.blog_rank_default&utm_term=docker&spm=1018.2226.3001.4450
/home/data_server/docker
/data_market/
Dockerfile
requirements.txt
/docker-compose.yml
在有docker-compose.yml文件的那一层目录下,执行命令:
docker-compose build
docker-compose up
docker-compose start
......