当前位置: 首页 > news >正文

Docker简单快速入门

1. 安装Docker

         基于 Ubuntu 24.04 LTS 安装Docker 。

# 更新包索引并安装依赖包
sudo apt-get update
sudo apt-get install -y apt-transport-https ca-certificates curl software-properties-common# 添加Docker的官方GPG密钥并存储在正确的位置
curl -fsSL https://mirrors.aliyun.com/docker-ce/linux/ubuntu/gpg | sudo gpg --dearmor -o /usr/share/keyrings/docker-archive-keyring.gpg# 添加Docker的APT源(使用阿里云的镜像源)
echo "deb [arch=amd64 signed-by=/usr/share/keyrings/docker-archive-keyring.gpg] https://mirrors.aliyun.com/docker-ce/linux/ubuntu $(lsb_release -cs) stable" | sudo tee /etc/apt/sources.list.d/docker.list > /dev/null# 安装Docker
sudo apt-get install -y docker-ce docker-ce-cli containerd.io# 安装后查看docker版本
docker -v# 运行测试容器
docker run hello-world# 配置Docker非root用户运行(可以查看用户管理相关指令)
sudo usermod -aG docker $USER# 启动一个新的shell会话,更改活动的用户组,让新的用户组在当前会话中生效
newgrp docker

  2. 用户管理相关指令

 2.1 添加用户到 Docker 组

sudo usermod -aG docker $USER

 2.2 查看 Docker 组中的用户 

getent group docker

 2.3 从 Docker 组中移除用户

sudo gpasswd -d $USER docker

2.4 检查用户所属组 

groups $USER

注:$USER表示当前登录的用户名称

3. 查看Docker信息

docker info

Client: Docker Engine - Community               
 Version:    27.0.3                             # 客户端的 Docker 版本
 Context:    default                            # 当前使用的 Docker 上下文
 Debug Mode: false                              # 客户端调试模式是否启用
 Plugins:                                       # 客户端插件信息
  buildx: Docker Buildx (Docker Inc.)           # Docker Buildx 插件
    Version:  v0.15.1                           # Buildx 插件版本
    Path:     /usr/libexec/docker/cli-plugins/docker-buildx  # Buildx 插件路径
  compose: Docker Compose (Docker Inc.)         # Docker Compose 插件
    Version:  v2.28.1                           # Compose 插件版本
    Path:     /usr/libexec/docker/cli-plugins/docker-compose # Compose 插件路径

Server:                                         # 服务器部分,显示 Docker 服务器的状态和配置信息
 Containers: 0                                  # 服务器上存在的总容器数
  Running: 0                                    # 当前正在运行的容器数
  Paused: 0                                     # 当前暂停的容器数
  Stopped: 0                                    # 已停止的容器数
 Images: 0                                      # 服务器上存在的总镜像数
 Server Version: 27.0.3                         # Docker 服务器版本
 Storage Driver: overlay2                       # 使用的存储驱动类型
  Backing Filesystem: extfs                     # 存储驱动的底层文件系统
  Supports d_type: true                         # 文件系统是否支持 d_type(目录类型)
  Using metacopy: false                         # 是否启用了元数据拷贝功能
  Native Overlay Diff: true                     # 是否使用本地 Overlay 差异
  userxattr: false                              # 是否启用用户扩展属性
 Logging Driver: json-file                      # 使用的日志驱动类型
 Cgroup Driver: systemd                         # 使用的 cgroup 管理器
 Cgroup Version: 2                              # 使用的 cgroup 版本
 Plugins:                                       # 插件信息
  Volume: local                                 # 可用的卷插件
  Network: bridge host ipvlan macvlan null overlay  # 可用的网络插件
  Log: awslogs fluentd gcplogs gelf journald json-file local splunk syslog  # 可用的日志插件
 Swarm: inactive                                # Swarm 模式的状态
 Runtimes: runc io.containerd.runc.v2           # 可用的运行时
 Default Runtime: runc                          # 默认的运行时
 Init Binary: docker-init                       # 使用的初始化二进制文件
 containerd version: 2bf793ef6dc9a18e00cb12efb64355c2c9d5eb41  # containerd 版本
 runc version: v1.1.13-0-g58aa920               # runc 版本
 init version: de40ad0                          # init 版本
 Security Options:                              # 启用的安全选项
  apparmor                                      # AppArmor 安全选项
  seccomp                                       # Seccomp 安全选项
   Profile: builtin                             # 使用的 Seccomp 配置文件
  cgroupns                                      # cgroup 命名空间安全选项
 Kernel Version: 6.8.0-31-generic               # 操作系统内核版本
 Operating System: Ubuntu 24.04 LTS             # 操作系统及其版本
 OSType: linux                                  # 操作系统类型
 Architecture: x86_64                           # 系统架构类型
 CPUs: 2                                        # 可用的 CPU 数量
 Total Memory: 3.778GiB                         # 总内存大小
 Name: liber-VMware-Virtual-Platform            # 机器名称
 ID: 506c4663-2c48-4b6e-a3a2-7868e2eb6990       # Docker 守护进程的唯一 ID
 Docker Root Dir: /var/lib/docker               # Docker 根目录
 Debug Mode: false                              # Docker 守护进程调试模式是否启用
 Experimental: false                            # 是否启用了实验特性
 Insecure Registries:                           # 配置的不安全镜像仓库
  127.0.0.0/8                                   # 允许本地网络范围内的不安全仓库
 Live Restore Enabled: false                    # 是否启用了 Live Restore 功能(容器在 Docker 守护进程重启时保持运行)

4. 创建Nginx容器

4.1 配置镜像加速器

4.1.1 获取阿里云加速地址

4.1.2 编辑Docker配置文件
sudo mkdir -p /etc/docker
sudo tee /etc/docker/daemon.json <<-'EOF'
{"registry-mirrors": ["https://xxxx.mirror.aliyuncs.com"]
}
EOF
sudo systemctl daemon-reload
sudo systemctl restart docker

 参考文献:配置镜像加速器_容器镜像服务(ACR)-阿里云帮助中心 

4.2 拉取Nginx镜像

docker pull nginx

4.3 运行 Nginx 容器

docker run --name mynginx -d -p 80:80 nginx

5. 镜像相关

5.1 查看本地所有镜像 

docker images

例:

 liber@liber-VMware-Virtual-Platform:~$ docker images
REPOSITORY   TAG       IMAGE ID       CREATED       SIZE
nginx        latest    605c77e624dd   2 years ago   141MB 

REPOSITORY:镜像的名称或存储库的名称。这个名称标识了镜像的来源或用途。
TAG: 镜像的标签,用于标识镜像的不同版本。
IMAGE ID: 镜像的唯一标识符。Docker 使用这个标识符来唯一地识别镜像。
CREATED: 镜像的创建时间,表示这个镜像在什么时候被构建。
SIZE: 镜像的大小,表示镜像占用的磁盘空间。

 5.2 查看特定镜像的详细信息

docker inspect <image_id>

 liber@liber-VMware-Virtual-Platform:~$ docker images
REPOSITORY   TAG       IMAGE ID       CREATED       SIZE
nginx        latest    605c77e624dd   2 years ago   141MB
liber@liber-VMware-Virtual-Platform:~$ docker inspect 605c77e624dd

5.3 拉取镜像

docker pull <repository>:<tag>

例:

liber@liber-VMware-Virtual-Platform:~$ docker images
REPOSITORY   TAG       IMAGE ID       CREATED       SIZE
nginx        latest    605c77e624dd   2 years ago   141MB
liber@liber-VMware-Virtual-Platform:~$ docker pull nginx:latest
 

 5.4 标记镜像

docker tag <image_id> <repository>:<tag>

例:docker tag 605c77e624dd mynginx:v1 

5.5 查看镜像的构建历史 

docker history <image_id>

5.6 删除镜像

docker rmi <image_id>

例:

liber-VMware-Virtual-Platform:~$ docker images
REPOSITORY   TAG       IMAGE ID       CREATED       SIZE
nginx        latest    605c77e624dd   2 years ago   141MB
liber@liber-VMware-Virtual-Platform:~$ docker rmi  605c77e624dd
Error response from daemon: conflict: unable to delete 605c77e624dd (cannot be forced) - image is being used by running container fb2661b753dd  #删除的容器在运行需要先停止
liber@liber-VMware-Virtual-Platform:~$ docker stop mynginx #停止容器
mynginx

liber@liber-VMware-Virtual-Platform:~$ docker rmi  605c77e624dd #再次在线删除指令
Error response from daemon: conflict: unable to delete 605c77e624dd (must be forced) - image is being used by stopped container fb2661b753dd #镜像正在被一个停止的容器引用。在这种情况下,你需要先删除这个停止的容器,然后再删除镜像。

liber@liber-VMware-Virtual-Platform:~$ docker ps -a #列出所有容器,包括停止的容器
CONTAINER ID   IMAGE     COMMAND                   CREATED          STATUS                     PORTS     NAMES
fb2661b753dd   nginx     "/docker-entrypoint.…"   41 minutes ago   Exited (0) 7 minutes ago             mynginx
liber@liber-VMware-Virtual-Platform:~$
docker rm fb2661b753dd #删除容器
fb2661b753dd
liber@liber-VMware-Virtual-Platform:~$
docker rmi 605c77e624dd #移除镜像
Untagged: nginx:latest
Untagged: nginx@sha256:0d17b565c37bcbd895e9d92315a05c1c3c9a29f762b011a10c54a66cd53c9b31

# 镜像的强制删除
docker rmi -f <image_id>

5.7 导出和导入镜像

5.7.1 导出镜像为tar文件
docker save -o <path_to_tar> <image_id>

 例:

liber@liber-VMware-Virtual-Platform:~$ docker save -o nginx.tar 605c77e624dd
liber@liber-VMware-Virtual-Platform:~$ ls
公共  模板  视频  图片  文档  下载  音乐  桌面  nginx.tar  snap

5.7.2 导入tar文件为镜像
docker load -i <path_to_tar>

6. 容器相关

常用选项
  • -d: 后台运行容器,并返回容器 ID。
  • -i: 保持容器的标准输入(stdin)打开,即使没有附加到容器上。
  • -t: 为容器分配一个伪终端,使你能够在容器内运行命令行界面。通常与 -i 一起使用。
  • --name <container_name>: 为容器指定一个名称。
  • -e <ENV_VAR>=<value>: 设置环境变量。
  • -p <host_port>:<container_port>: 端口映射,将主机的端口映射到容器的端口。
  • -v <host_dir>:<container_dir>: 卷挂载,将主机目录或文件挂载到容器的目录或文件。
  • --rm: 在容器停止后自动删除容器。
  • --network <network_name>: 指定容器连接到的网络。
  • --link <name_or_id>:alias: 添加链接到另一个容器。

6.1 创建新的容器

6.1.1 创建后台运行容器
docker run --name <container_name> -d -p <host_port>:<container_port> <image>

#使用 docker run 命令来创建并运行一个新的容器 

docker run --name mynginx -d -p 80:80 nginx

  • --name mynginx:指定容器的名称为 mynginx
  • -d:让容器在后台运行(分离模式)。
  • -p 80:80:将主机的 80 端口映射到容器的 80 端口。
  • nginx:使用的镜像名称。
6.1.2 创建运行交互式容器
docker run -it [options] <image> [command]
[options] 是一个占位符,表示你可以在这里添加其他选项来配置容器的运行环境。
以下是一些常用的选项:
--name <container_name>: 为容器指定一个名称,这样你可以通过名称而不是容器 ID 来引用容器。
-d: --detach,让容器在后台运行,并返回容器 ID。使用这个选项可以让容器在后台继续运行,而不阻塞当前终端。
-p <host_port>:<container_port>: 端口映射,将主机的端口映射到容器的端口
-v <host_dir>:<container_dir>: 卷挂载,将主机目录或文件挂载到容器的目录或文件。
-e <ENV_VAR>=<value>: 设置环境变量,在容器运行时配置。
--rm: 在容器停止后自动删除容器。
--network <network_name>: 指定容器连接到的网络。
--link <name_or_id>:alias: 添加链接到另一个容器。

例子:

liber@liber-VMware-Virtual-Platform:~$ docker run -it --name mysql -e MYSQL_ROOT_PASSWORD=123456 mysql:latest /bin/bash

  • docker run: 创建并运行一个新的容器。
  • -it: 交互模式运行容器并分配伪终端。
  • --name mysql: 将容器命名为mysql。
  • -e MYSQL_ROOT_PASSWORD=123456: 设置环境变量,指定 MySQL 的 root 用户密码。
  • mysql:latest: 使用官方 MySQL 镜像的最新版本。
  • /bin/bash: 在容器启动时运行的命令。

使用官方的 MySQL 启动命令:docker-entrypoint.sh mysqld

连接到运行中的 MySQL 容器:

liber@liber-VMware-Virtual-Platform:~$ docker exec -it mysql mysql -uroot -p #进入一个正在运行的容器
Enter password: 
Welcome to the MySQL monitor.  Commands end with ; or \g.

6.2 查看当前运行的容器

docker ps

CONTAINER ID   IMAGE     COMMAND  CREATED    STATUS  PORTS   NAMES

注解:
CONTAINER ID: 容器的唯一标识符。
IMAGE: 用于创建容器的镜像名称。
COMMAND: 容器启动时运行的命令。
CREATED: 容器创建的时间。

STATUS(通常包含以下5种): 容器的当前状态,包括运行时间。
1. Up: 容器正在运行。
2. Exited: 容器已停止运行。
3. Created: 容器已创建但未启动。
4. Paused: 容器已暂停。
5. Restarting:容器正在重启。

PORTS: 容器暴露的端口信息。
NAMES: 容器的名字,如果没有指定名字,Docker会自动生成一个随机名字。

6.3 查看所有容器(包括停止的容器)

docker ps -a

6.4 查看最近创建的容器 

docker ps -l

6.5 查看容器日志

docker logs <CONTAINER ID>

例:

liber@liber-VMware-Virtual-Platform:~$ docker ps -l
CONTAINER ID   IMAGE     COMMAND                   CREATED              STATUS              PORTS                               NAMES
fb2661b753dd   nginx     "/docker-entrypoint.…"   About a minute ago   Up About a minute   0.0.0.0:80->80/tcp, :::80->80/tcp   mynginx
liber@liber-VMware-Virtual-Platform:~$ docker logs fb2661b753dd
/docker-entrypoint.sh: /docker-entrypoint.d/ is not empty, will attempt to perform configuration
/docker-entrypoint.sh: Looking for shell scripts in /docker-entrypoint.d/
/docker-entrypoint.sh: Launching /docker-entrypoint.d/10-listen-on-ipv6-by-default.sh
10-listen-on-ipv6-by-default.sh: info: Getting the checksum of /etc/nginx/conf.d/default.conf
10-listen-on-ipv6-by-default.sh: info: Enabled listen on IPv6 in /etc/nginx/conf.d/default.conf
/docker-entrypoint.sh: Launching /docker-entrypoint.d/20-envsubst-on-templates.sh
/docker-entrypoint.sh: Launching /docker-entrypoint.d/30-tune-worker-processes.sh
/docker-entrypoint.sh: Configuration complete; ready for start up
2024/07/20 00:48:50 [notice] 1#1: using the "epoll" event method
2024/07/20 00:48:50 [notice] 1#1: nginx/1.21.5 

6.6 检查容器状态 

docker inspect --format '{{.State.Status}}' <container_id>

例:

liber@liber-VMware-Virtual-Platform:~$ docker ps
CONTAINER ID   IMAGE     COMMAND                   CREATED         STATUS         PORTS                               NAMES
fb2661b753dd   nginx     "/docker-entrypoint.…"   5 minutes ago   Up 5 minutes   0.0.0.0:80->80/tcp, :::80->80/tcp   mynginx
liber@liber-VMware-Virtual-Platform:~$ docker inspect --format '{{.State.Status}}' fb2661b753dd
running 

6.7 启动容器 

docker start <container-name>

6.8 停止容器 

docker stop <container-name>

 6.9 删除容器

docker rm <container-name>

6.10 访问容器 

docker exec -it <container_name_or_id> <command>
  • docker exec: 在一个正在运行的容器中执行命令。
  • -it: 交互模式,分配一个伪终端。
  • <container_name_or_id>: 目标容器的名称或 ID。
  • <command>: 要在容器中执行的命令(如 /bin/bash)。

7. 网络配置 

  7.1 查看所有网络

docker network ls

 例:

liber@liber-VMware-Virtual-Platform:~$ docker network ls
NETWORK ID     NAME      DRIVER    SCOPE
e4a84feb27d8   bridge    bridge    local
21db5cf6fb61   host      host      local
b86a38a046d2   none      null      local

NETWORK ID: 网络的唯一标识符。Docker使用这个标识符来唯一地识别网络。
NAME: 网络的名称。用户可以使用这个名称来引用和管理网络。
DRIVER: 网络驱动程序,用于管理网络的实现方式。常见的驱动程序包括 bridge、host、null 等。
SCOPE: 网络的作用范围,表示网络的可见性范围。local 表示网络仅在本地Docker守护进程上可见。

7.2 查看特定网络

docker network inspect <network_id>

例:

 liber@liber-VMware-Virtual-Platform:~$ docker images
REPOSITORY   TAG       IMAGE ID       CREATED       SIZE
nginx        latest    605c77e624dd   2 years ago   141MB
liber@liber-VMware-Virtual-Platform:~$ docker inspect 605c77e624dd

7.3 创建网络 

docker network create mynetwork

7.4 连接网络

在启动容器时,通过 --network 选项将其连接到自定义网络。

liber@liber-VMware-Virtual-Platform:~$ docker run --name mynginx --network mynetwork -d -p 80:80 nginx

如果容器已经在运行,可以使用 docker network connect 命令将其连接到自定义网络。

docker network connect mynetwork mynginx

 7.5 访问网络

liber@liber-VMware-Virtual-Platform:~$ docker exec -it mynginx /bin/bash #进入容器
root@0004faebf897:/#  curl mynginx:80 #访问网络
<!DOCTYPE html>
<html>
<head>
<title>Welcome to nginx!</title>
<style>
html { color-scheme: light dark; }
body { width: 35em; margin: 0 auto;
font-family: Tahoma, Verdana, Arial, sans-serif; }
</style>
</head>
<body>
<h1>Welcome to nginx!</h1>
<p>If you see this page, the nginx web server is successfully installed and
working. Further configuration is required.</p>

<p>For online documentation and support please refer to
<a href="http://nginx.org/">nginx.org</a>.<br/>
Commercial support is available at
<a href="http://nginx.com/">nginx.com</a>.</p>

<p><em>Thank you for using nginx.</em></p>
</body>
</html>

8. 数据管理

8.1 数据卷

        数据卷是 Docker 管理的专用目录,存储在主机文件系统中,但 Docker 提供了对其的完全管理。

8.1.1 创建数据卷

        数据卷是 Docker 管理的专用目录,存储在主机文件系统中,但 Docker 提供了对其的完全管理。

docker volume create myvolume
8.1.2 查看数据卷
docker volume ls

liber@liber-VMware-Virtual-Platform:~$ docker volume ls
DRIVER    VOLUME NAME
local     3e257cc31097122d7dbd2341b5610853473a98b71708e676099648c49903b65b
local     myvolume 

 8.1.3 查详细信息
docker volume inspect myvolume

liber@liber-VMware-Virtual-Platform:~$ docker volume inspect myvolume
[
    {
        "CreatedAt": "2024-07-20T15:37:41+08:00",
        "Driver": "local",
        "Labels": null,
        "Mountpoint": "/var/lib/docker/volumes/myvolume/_data",
        "Name": "myvolume",
        "Options": null,
        "Scope": "local"
    }
]
 

8.1.4 使用数据卷

        将数据卷挂载到容器中,使得容器可以持久化存储数据。

docker run -d -p 80:80 -v myvolume:/usr/share/nginx/html nginx
-v myvolume:/usr/share/nginx/html:将数据卷myvolume挂载到容器的/usr/share/nginx/html目录。
8.1.5 备份数据卷 

      将数据卷中的数据备份到主机目录。

docker run --rm -v myvolume:/volume -v $(pwd):/backup mginx tar cvf /backup/backup.tar /volume
  • --rm:容器在退出时自动删除。
  • -v myvolume:/volume:将数据卷 myvolume 挂载到容器的 /volume 目录。
  • -v $(pwd):/backup:将当前主机目录挂载到容器的 /backup 目录。
  • tar cvf /backup/backup.tar /volume:将 /volume 目录(即数据卷内容)打包为 backup.tar 并存储在主机的当前目录。

liber@liber-VMware-Virtual-Platform:~$ docker run --rm -v myvolume:/volume -v $(pwd):/backup nginx tar cvf /backup/backup.tar /volume
tar: Removing leading `/' from member names
/volume/
/volume/50x.html
/volume/index.html
liber@liber-VMware-Virtual-Platform:~$ ls
公共  模板  视频  图片  文档  下载  音乐  桌面  backup.tar  nginx_latest.tar  snap

 8.1.6 恢复数据卷
docker run --rm -v myvolume:/volume -v $(pwd):/backup nginx bash -c "cd /volume && tar xvf /backup/backup.tar --strip 1"
  •  tar xvf /backup/backup.tar --strip 1:将 backup.tar 文件解压到 /volume 目录中,--strip 1 选项用于去除路径中的第一级目录。

liber@liber-VMware-Virtual-Platform:~$ docker run --rm -v myvolume:/volume -v $(pwd):/backup nginx bash -c "cd /volume && tar xvf /backup/backup.tar --strip 1"
volume/50x.html
volume/index.html

liber@liber-VMware-Virtual-Platform:~$ docker run -it --name new_nginx -v myvolume:/volume -p 81:82 nginx /bin/bash #运行并挂载数据卷
root@14c73202ba4f:/# cd volume #进入容器后,访问挂载目录
root@14c73202ba4f:/volume# ls
50x.html  index.html

8.2 绑定挂载

        绑定挂载将主机文件系统中的文件或目录挂载到容器中,可以在容器和主机之间共享数据。

docker run -v /path/on/host:/path/in/container <image> <command>
/path/on/host:主机上的路径,是你希望挂载到容器内的文件或目录的路径。
/path/in/container:容器内的路径,是你希望将主机文件或目录挂载到容器内的文件或目录的路径。

例子:

root@liber-VMware-Virtual-Platform:/opt# mkdir -p /opt/nginx
root@liber-VMware-Virtual-Platform:/opt# echo "Docker Nginx" > /opt/nginx/index.html
root@liber-VMware-Virtual-Platform:/opt# docker run -d -p 80:80 -v /opt/nginx:/usr/share/nginx/html nginx
9befe205cddd3719993bd8bef47eb4ced0b6408cd7142f409a21287b766f19e1
root@liber-VMware-Virtual-Platform:/opt# echo "Update Docker Nginx" > /opt/nginx/index.html

可以访问80端口的地址检验实时生效。 

9. Docker Compose 

9.1 安装Docker Compose

# 安装docker-compose
sudo wget "https://github.com/docker/compose/releases/download/v2.20.2/docker-compose-$(uname -s)-$(uname -m)" -O /usr/local/bin/docker-compose# 赋予执行文件
sudo chmod +x /usr/local/bin/docker-compose# 验证安装
docker-compose --version

9.2 基本命令

9.2.1 启动服务
docker-compose up
9.2.2 后台启动服务 
docker-compose up -d
9.2.3 停止服务
docker-compose down
9.2.4 查看服务日志 
docker-compose logs
9.2.5 查看运行中的容器 
docker-compose ps
9.2.6 构建或重新构建服务 
docker-compose build

9.3 简单案例 

9.3.1 项目结构:

9.3.2 docker-compose.yml 
version: '3.8'  # 指定 docker-compose 文件的版本services:  # 定义应用的各个服务web:  # 服务名称image: nginx:latest  # 使用的镜像ports:- "80:80"  # 端口映射volumes:- ./:/usr/share/nginx/html  # 绑定挂载
volumes:  # 定义数据卷db_data:

9.3.3 启动结果

liber@liber-VMware-Virtual-Platform:/opt/web$ docker-compose up
[+] Running 1/0
 ✔ Container web-web-1  Created                                                                                                                                                           0.0s 
Attaching to web-web-1
web-web-1  | /docker-entrypoint.sh: /docker-entrypoint.d/ is not empty, will attempt to perform configuration
web-web-1  | /docker-entrypoint.sh: Looking for shell scripts in /docker-entrypoint.d/
web-web-1  | /docker-entrypoint.sh: Launching /docker-entrypoint.d/10-listen-on-ipv6-by-default.sh
web-web-1  | 10-listen-on-ipv6-by-default.sh: info: IPv6 listen already enabled
web-web-1  | /docker-entrypoint.sh: Launching /docker-entrypoint.d/20-envsubst-on-templates.sh
web-web-1  | /docker-entrypoint.sh: Launching /docker-entrypoint.d/30-tune-worker-processes.sh
web-web-1  | /docker-entrypoint.sh: Configuration complete; ready for start up
web-web-1  | 2024/07/20 09:49:57 [notice] 1#1: using the "epoll" event method
web-web-1  | 2024/07/20 09:49:57 [notice] 1#1: nginx/1.21.5
web-web-1  | 2024/07/20 09:49:57 [notice] 1#1: built by gcc 10.2.1 20210110 (Debian 10.2.1-6) 
web-web-1  | 2024/07/20 09:49:57 [notice] 1#1: OS: Linux 6.8.0-31-generic
web-web-1  | 2024/07/20 09:49:57 [notice] 1#1: getrlimit(RLIMIT_NOFILE): 1048576:1048576
web-web-1  | 2024/07/20 09:49:57 [notice] 1#1: start worker processes
web-web-1  | 2024/07/20 09:49:57 [notice] 1#1: start worker process 24
web-web-1  | 2024/07/20 09:49:57 [notice] 1#1: start worker process 25

10. 总结 

        通过Ubuntu 24.04 LTS完成Docker 和Docker-Compose安装,以及实现docker的简单入门。需要注意Docker和Docker之间的版本兼容性。

相关文章:

Docker简单快速入门

1. 安装Docker 基于 Ubuntu 24.04 LTS 安装Docker 。 # 更新包索引并安装依赖包 sudo apt-get update sudo apt-get install -y apt-transport-https ca-certificates curl software-properties-common# 添加Docker的官方GPG密钥并存储在正确的位置 curl -fsSL https://mirror…...

【2024最新华为OD-C/D卷试题汇总】[支持在线评测] 图像物体的边界(200分) - 三语言AC题解(Python/Java/Cpp)

🍭 大家好这里是清隆学长 ,一枚热爱算法的程序员 ✨ 本系列打算持续跟新华为OD-C/D卷的三语言AC题解 💻 ACM银牌🥈| 多次AK大厂笔试 | 编程一对一辅导 👏 感谢大家的订阅➕ 和 喜欢💗 🍿 最新华为OD机试D卷目录,全、新、准,题目覆盖率达 95% 以上,支持题目在线…...

【无人机】低空经济中5G RedCap芯片的技术分析报告

1. 引言 图一. 新基建&#xff1a;低空经济 低空经济作为一种新兴的经济形态&#xff0c;涵盖了无人机、电动垂直起降飞行器&#xff08;eVTOL&#xff09;、低空物流、空中交通管理等多个领域。随着5G网络的普及和演进&#xff0c;5G RedCap&#xff08;Reduced Capability&a…...

MongoDB教程(二十一):MongoDB大文件存储GridFS

&#x1f49d;&#x1f49d;&#x1f49d;首先&#xff0c;欢迎各位来到我的博客&#xff0c;很高兴能够在这里和您见面&#xff01;希望您在这里不仅可以有所收获&#xff0c;同时也能感受到一份轻松欢乐的氛围&#xff0c;祝你生活愉快&#xff01; 文章目录 引言一、GridFS…...

vue 搜索框

效果 创建搜索组件&#xff1a; 在Vue项目中&#xff0c;首先需要创建一个搜索组件。这个组件通常包含一个输入框和一个搜索按钮。使用v-model指令将输入框与组件的数据属性&#xff08;如searchKeyword&#xff09;进行双向绑定&#xff0c;以便获取用户输入的关键词。处理搜索…...

国科大作业考试资料-人工智能原理与算法-2024新编-第五次作业整理

1、本题以井字棋(圈与十字游戏)为例练习博弈中的基本概念。定义X_n为恰好有n个X而没有O 的行、列或者对角线的数目。同样O_n为正好有n 个O的行、列或者对角线的数目。效用函数给 X_3=1的棋局+1, 给O_3=1的棋局-1。所有其他终止状态效用值为0。对于非终止状态,使用线性的 …...

C++五子棋(未做完,但能玩,而且还不错)

代码放下面了&#xff0c;关于步骤介绍的我以后再完善一下。 #include<bits/stdc.h> #include<cstdio> #include<cstdlib> #include<ctime> #include<windows.h> #include<stdlib.h> #include<time.h> #define random(x) (rand()%x…...

二分查找代码详解

二分查找代码实现 以下是完整的代码和解释&#xff1a; #include <stdio.h>int binarySearch(int arr[], int length, int target) {int left 0;int right length - 1;while (left < right) {int mid left (right - left) / 2; // 防止溢出if (arr[mid] target…...

uniapp的h5,读取本地txt带标签的文件

效果图 使用的回显的标签是u-parse&#xff0c;下面的网址讲了这个标签的相关 https://www.cnblogs.com/huihuihero/p/12978903.html 导入此插件 https://ext.dcloud.net.cn/plugin?id364 使用 uni.request({// 本地文件url: "/static/互联网医院医师端用户协议.txt…...

韦东山嵌入式linux系列-具体单板的按键驱动程序(查询方式)

1 GPIO 操作回顾 &#xff08;1&#xff09;使能模块&#xff1b; &#xff08;2&#xff09;设置引脚的模式&#xff08;工作于GPIO模式&#xff09;&#xff1b; &#xff08;3&#xff09;设置GPIO本身&#xff08;输入/输出&#xff09;&#xff1b; &#xff08;4&…...

如何使用 API list 极狐GitLab 群组中的镜像仓库?

GitLab 是一个全球知名的一体化 DevOps 平台&#xff0c;很多人都通过私有化部署 GitLab 来进行源代码托管。极狐GitLab &#xff1a;https://gitlab.cn/install?channelcontent&utm_sourcecsdn 是 GitLab 在中国的发行版&#xff0c;专门为中国程序员服务。可以一键式部署…...

PHP设计模式-简单工厂模式

核心&#xff1a; 一、定义一个接口类里面写规定好的方法。 interface Message{public function send(array $params);public function getMessage(array $params);public function getCode(array $params);} 二、定义产品类 、产品类继承接口类 class AlliYunSms implements …...

C语言航空售票系统

以下是系统部分页面 以下是部分源码&#xff0c;需要源码的私信 #include<stdio.h> #include<stdlib.h> #include<string.h> #define max_user 100 typedef struct ft {char name[50];//名字char start_place[50];//出发地char end_place[50];//目的地char …...

Oracle 19c打Datapatch数据补丁报错处理

Oracle 19c打Datapatch数据补丁报错处理 错误分析重新编译补丁验证安装完数据库补丁后,在数据补丁的步骤收到以下报错: Connecting to database...OK Gathering database info...done Bootstrapping registry and package to current versions...done Determining current s…...

Linux shell编程学习笔记66:ping命令 超详细的选项说明

0 前言 网络信息是电脑网络信息安全检查中的一块重要内容&#xff0c;Linux和基于Linux的操作系统&#xff0c;提供了很多的网络命令&#xff0c;今天我们研究最常用的ping命令。 1 ping命令 的功能、格式和选项说明 1.1 ping命令 的功能 简单来说&#xff0c; ping 命令 会…...

SSL/TLS和SSL VPN

1、SSL/TLS SSL安全套接字层&#xff1a;是一种加密协议&#xff0c;用于在网络通信中建立安全连接。它在应用层和传输层&#xff08;TCP/IP&#xff09;之间提供数据加密、服务器身份验证以及信息完整性验证 SSL只保护TCP流量&#xff0c;不保护UDP协议 TLS&#xff1a;传输层…...

浅谈WebSerice

一. 什么是WebService Web Service也称为web服务&#xff0c;它是一种跨编程语言和操作系统平台的远程调用技术。Web Service采用标准的SOAP协议传输&#xff08;SOAP&#xff1a;Simple Object Access Protocol简单对象访问协议&#xff0c;soap属于w3c标准。并且soap协议是基…...

linux快速入门-学习笔记

linux快速入门-学习笔记 第一章&#xff1a;Linux系统概念及命令学习Linux系统基本概念命令终端介绍命令格式介绍Linux系统辨别目录与文件的方法通过文件详细属性辨别ls 查看目录/文件命令Linux 系统下的归属关系命令行编辑技巧Linux 基本权限的类别课后练习 第二章&#xff1a…...

科普文:5种Linux下软件部署方式说明

在Linux世界里&#xff0c;高效、灵活地安装和管理软件是每个系统管理员和开发者的基本功。从传统的RPM包管理&#xff0c;到便捷的YUM软件仓库&#xff0c;再到颠覆性的Docker容器技术&#xff0c;Snap&#xff0c;源码安装&#xff0c;每一种方法都有其独到之处&#xff0c;适…...

Redisson中的RBlockingQueue的使用场景及例子

Redisson 的 RBlockingQueue 是一个实现了 Java BlockingQueue 接口的分布式队列&#xff0c;它可以用于在分布式系统中实现生产者-消费者模式。RBlockingQueue 提供了线程安全的阻塞队列操作&#xff0c;允许生产者在队列满时阻塞&#xff0c;消费者在队列空时阻塞&#xff0c…...

【办公软件】Office 2019以上版本PPT 做平滑切换

Office2019以上版本可以在切页面时做平滑切换&#xff0c;做到一些简单的动画效果。如下在快捷菜单栏中的切换里选择平滑。 比如&#xff0c;在两页PPT中&#xff0c;使用同一个形状对象&#xff0c;修改了大小和颜色。 选择切换为平滑后&#xff0c;可以完成如下的动画显示。 …...

connect-multiparty中间件用法以及实例--文件上传中间件(保姆级别教学)

connect-multiparty中间件的用法包括安装和引入、基本设置、路由应用、文件处理以及安全和优化等步骤。 connect-multiparty是一个专为Connect和Express框架设计的文件上传中间件&#xff0c;它基于multiparty库&#xff0c;用于处理多部分表单数据&#xff0c;尤其针对文件上传…...

0503触发器的电路结构和工作原理

触发器的电路结构和工作原理 如何区分锁存器还是触发器&#xff0c; 看有没有这个三角符号&#xff0c;告诉是上升沿触发还是下降沿触发&#xff0c;没有三角符号就是电平触发。低电平触发就画个小圈。高电平触发就不画小圈。有小圈的三角就是下降沿触发 setup建立时间 hold 保…...

LeetCode:二叉树的中序遍历(C语言)

1、前序遍历&#xff1a;根左右 2、中序遍历&#xff1a;左根右 3、后序遍历&#xff1a;左右根 1、问题概述&#xff1a;二叉树中序遍历 2、示例 示例 1&#xff1a; 输入&#xff1a;root [1,null,2,3] 输出&#xff1a;[1,3,2] 示例 2&#xff1a; 输入&#xff1a;root […...

MySQL数据库基本安装与部署

目录 概念 数据库的基本概念 关系型数据库 非关系型数据库 MySQL 商业版与社区版 示例 初始化MySQL 添加系统服务 概念 数据库的基本概念 数据&#xff08;Data&#xff09; 描述事物的符号记录包括数字、文字、图形、图像、声音、档案记录等以“记录”形式按统一的…...

paraFoam 运行 报错 usr/lib/x86_64-linux-gnu/libQt5Core.so 已解决

在日常项目开发中。使用ubuntu 视图开发的时候。报错 缺少 libQt5Core 核心组件&#xff01; whereis libQt5Core.so.5sudo strip --remove-section.note.ABI-tag /usr/lib/x86_64-linux-gnu/libQt5Core.so.5 完美解决&#xff0c;并且能正常打开&#xff0c;前提是&#xff0c…...

科技前沿:Llama 3.1的突破与革新

在科技的长河中&#xff0c;每一次模型的更新都是对人类智慧的致敬。今天&#xff0c;我们将聚焦于Meta公司最新发布的Llama 3.1系列模型&#xff0c;探索其在AI领域的前沿突破。 新模型的诞生 自去年以来&#xff0c;Meta公司不断推进人工智能技术的发展&#xff0c;终于在近…...

每天一个数据分析题(四百四十七)- 业务系统

业务系统往往因为系统故障、设备故障、人为失误等原因导致数据中存在异常数据&#xff0c;下列哪一项方法对于发现异常值有帮助&#xff08; &#xff09; A. 计算均值加减三倍标准差的范围 B. 梯度下降法 C. 相关性分析 D. 计算四分位距 数据分析认证考试介绍&#xff1a…...

如何保护你的网络安全?

在2024年4月&#xff0c;一次创纪录的DDoS&#xff08;分布式拒绝服务&#xff09;攻击震惊了网络世界&#xff0c;这次攻击达到每秒840百万数据包&#xff08;Mpps&#xff09;。你可能会问&#xff0c;DDoS攻击到底是什么&#xff1f;为什么它这么重要呢&#xff1f; 什么是…...

Nginx 怎样处理请求的重试机制?

&#x1f345;关注博主&#x1f397;️ 带你畅游技术世界&#xff0c;不错过每一次成长机会&#xff01; 文章目录 Nginx 怎样处理请求的重试机制&#xff1f;一、为何需要重试机制&#xff1f;二、Nginx 中的重试机制原理三、Nginx 重试机制的配置参数四、Nginx 重试机制的实际…...

自己开发软件实现网站抓取m3u8链接

几天前一个同学说想下载一个网站的视频找不到连接&#xff0c;问我有没有什么办法,网站抓取m3u8链接 网页抓取m3u8链接。当时一听觉得应该简单&#xff0c;于是说我抽空看看。然后就分析目标网页&#xff0c;试图从网页源码里找出连接&#xff0c;有的源代码直接有,但是有的没有…...

[Python3] 多模式字符串搜索 `Aho-Corasick`

ahocorasick.Automaton 是 Python 中 pyahocorasick 库提供的一个类&#xff0c;用于实现 Aho-Corasick 自动机。Aho-Corasick 算法是一种用于精确或近似多模式字符串搜索的高效算法。 通过 pip install pyahocorasick 安装 pyahocorasick 库。 并且&#xff0c;该模块是用 C 编…...

4 Types of Kaggle Competitions

1---Featured Competitions&#x1f911;&#x1f911; These are comprehensive Machine Learning challenges posed by difficult, often business-oriented predictive problems. For example, 1⃣️Using customers history of buying insurance to predict the price t…...

【STM32】stm32中GPIO_ReadInputDataBit()是什么意思

GPIO_ReadInputDataBit()函数用于读取指定GPIO端口的某一引脚上的电平状态&#xff0c;并返回该引脚的电平是高电平&#xff08;1&#xff09;还是低电平&#xff08;0&#xff09;。 在STM32单片机中&#xff0c;GPIO&#xff08;General-Purpose Input/Output&#xff09;端…...

Study--Oracle-07-ASM相关参数(三)

一、ASM初始化参数 1、ASM全量参数,见附件 2、ASM重要参数 无需求不需要调整 3、ASM权限 ASM的三大系统权限包括SYSDBA、‌SYSOPER和SYSASM。‌ SYSDBA(‌系统管理员)‌:‌这是最高级别的权限,‌允许用户执行所有的数据库管理任务,‌包括启动和关闭数据库,‌以及执行…...

【STM32嵌入式系统设计与开发拓展】——12_Timer(定时器中断实验)

目录 1、什么是定时器&#xff1f;定时器用于测量时间间隔&#xff0c;而计数器用于计数外部事件的次数 2、定时器的主要功能和用途&#xff1f;3、定时器类型&#xff1f;4、定时器的编写过程5、代码分析定时器计算&#xff1f;计算过程周期&#xff08;arr&#xff09;&#…...

iPhone 17系列取消17 Plus版本?新一代苹果手机迎来新变革

随着科技的飞速发展&#xff0c;苹果公司再次准备刷新我们的期待&#xff0c;即将推出的iPhone 17系列携带着一系列令人兴奋的升级。今年&#xff0c;苹果打破了常规&#xff0c;将四款新机型带入市场——iPhone 17、17 Pro、17 Pro Max&#xff0c;以及一款全新的成员&#xf…...

Bootstrap实现dialog上一步下一步多个弹窗交互

Bootstrap实现dialog上一步下一步多个弹窗交互 版本介绍&#xff1a; Bootstrap v3.3.7jQuery v3.5.1 一、功能介绍 重新设置bootstrap主题色内容区以card形式展示&#xff0c;纯js实现分页功能共两步骤&#xff0c;第一步选择模板&#xff0c;第二步进行其他操作步骤一内的按…...

iOS实际开发中使用数据驱动页面布局

引言 在实际的APP开发中&#xff0c;我们通常会首先根据设计团队提供的视觉设计UI来构建我们的应用页面。这些设计通常是最全面和理想化的状态&#xff0c;因为设计师并不需要考虑用户的实际操作和交互。然而&#xff0c;如果我们仅仅根据这些设计进行硬编码&#xff0c;会在应…...

后端开发刷题 | 笔试

Linux 中&#xff0c;下面哪个选项不是 inode 中记录的数据&#xff08;&#xff09; A 最后一次读取时间 B 最近修改的时间 C 该文件的实际内容 D 该文件的容量 正确答案&#xff1a;C 解析&#xff1a;储存文件的元信息&#xff0c;比如文件的创建者、文件的创建日期、文件的…...

ROS2入门到精通—— 2-8 ROS2实战:机器人安全通过狭窄区域的方案

0 前言 室内机器人需要具备适应性和灵活性&#xff0c;以便在狭窄的空间中进行安全、高效的导航。本文提供一些让机器人在狭窄区域安全通过的思路&#xff0c;希望帮助读者根据实际开发适当调整和扩展 1 Voronoi图 Voronoi图&#xff1a;根据给定的一组“种子点”&#xff0…...

STM32自己从零开始实操10:PCB全过程

一、PCB总体分布 分布主要参考有&#xff1a; 方便供电布线。方便布信号线。方便接口。人体工学。 以下只能让大家看到各个模块大致分布在板子的哪一块&#xff0c;只能说每个人画都有自己的理由&#xff0c;我的理由如下。 还有很多没有表达出来的东西&#xff0c;我也不知…...

折线图时间统计

1、查询本月的数据 2、查询最近一个月数据 1、查询本月数据 Date startTime DateUtil.getStartDayOfMonth();Date endTime DateUtil.getEndDayOfMonth();//获取日期//[2024-07-01, 2024-07-02, 2024-07-03, 2024-07-04, 2024-07-05, 2024-07-06, 2024-07-07, 2024-07-08, 20…...

Prompt工程:与AI聊天机器人更好地交流

Prompt工程:与AI聊天机器人更好地交流 1. 清楚地说明你想要什么2. 告诉AI它现在是谁3. 一步一步来4. 给AI一些例子5. 让AI检查自己的回答6. 把AI当作你的小助手7. 让AI帮你想主意8. 让AI告诉你它需要知道什么9. 教AI一步一步思考结语 大家好!今天我们来聊聊如何跟AI聊天机器人更…...

BGP之选路MED

原理概述 当一台BGP路由器中存在多条去往同一目标网络的BGP路由时&#xff0c;BGP协议会对这些BGP路由的属性进行比较&#xff0c;以确定去往该目标网络的最优BGP路由。BGP路由属性的比较顺序为Preferred Value属性、Local Preference属性、路由生成方式、AS_Path属性、Origin属…...

KunDB4.0:安全能力与Oracle兼容性提升,支持跨系统多租户部署

KunDB是星环科技自主研发的分布式交易型数据库&#xff0c;高度兼容Oracle和MySQL&#xff0c;提供数据强一致、高可用、高性能、高扩展、应用透明等能力&#xff0c;可在云上和物理机上容器化部署运行&#xff0c;一站式解决企业数据存储、管理、计算与安全性问题。 过去半年…...

JVM的 6 种垃圾回收算法

JVM的垃圾回收&#xff08;Garbage Collection, GC&#xff09;算法&#xff0c;在面试八股文时偶尔会被问到&#xff0c;了解一些常见的垃圾回收算法有利于面试时吊打面试官。 以下是JVM常见的几种垃圾回收算法的介绍&#xff1a; 1. 标记-清除算法&#xff08;Mark-Sweep&a…...

【SOC 芯片设计 DFT 学习专栏 -- DFT OCC 与 ATPG的介绍】

请阅读【嵌入式及芯片开发学必备专栏】 请阅读【芯片设计 DFT 学习系列 】 如有侵权&#xff0c;请联系删除 转自&#xff1a; 简矽芯学堂 简矽芯学堂 2024年01月18日 09:00 陕西 文章目录 OCC 介绍Fast ScanFull chip ATPGPartition ATPGHierarchical ATPG OCC 介绍 OCC&am…...

自动驾驶-机器人-slam-定位面经和面试知识系列03之C++STL面试题(01)

这两天有点忙耽搁了&#xff0c;抱歉&#xff01;&#xff01;&#xff01; 这个博客系列会分为C STL-面经、常考公式推导和SLAM面经面试题等三个系列进行更新&#xff0c;基本涵盖了自己秋招历程被问过的面试内容&#xff08;除了实习和学校项目相关的具体细节&#xff09;。…...

红狮金业解读:分析高价位黄金的后续投资吸引力

在全球经济格局不断变化的背景下&#xff0c;黄金作为传统的避险资产一直备受投资者关注。近期&#xff0c;金价持续走高&#xff0c;引发了市场对黄金是否仍然是优质资产配置的讨论。本文红狮启富将从长期需求、价格驱动因素的变化以及汇率影响三个角度&#xff0c;深入分析黄…...