【应用】Docker

news2025/1/12 16:18:04

Docker

  • Docker 的安装
    • 基本安装流程
    • 配置镜像加速
  • Docker 常用命令
    • 镜像相关命令
    • 容器相关命令
  • Dockerfile
    • Dockerfile 常用指令
    • Dockerfile 简单使用案例
    • Dockerfile 构建 java 项目镜像
  • Docker Compose
    • Docker compose 基本参数
    • services 配置参数

Docker 的安装

基本安装流程

使用虚拟机系统版本为 centOS 7,使用下列命令查看内核版本,官方建议内核版本应在 3.10 以上

uname -r

内核版本验证满足后,安装 yum 的工具包,,yum-util 提供 yum-config-manager 功能,另两个是 devicemapper 驱动依赖

yum install -y yum-utils device-mapper-persistent-data lvm2

设置 yum 源(阿里仓库)

yum-config-manager --add-repo http://mirrors.aliyun.com/docker-ce/linux/centos/docker-ce.repo

查看 docker 版本

yum list docker-ce --showduplicates | sort -r

选择相应版本进行安装

yum install docker-ce-18.03.1.ce-1.el7.centos

启动 docker 并设置开机自启

systemctl start docker
systemctl enable docker

查看 docker 版本,验证安装

[root@localhost ~]# docker version
Client:
 Version:      18.03.1-ce
 API version:  1.37
 Go version:   go1.9.5
 Git commit:   9ee9f40
 Built:        Thu Apr 26 07:20:16 2018
 OS/Arch:      linux/amd64
 Experimental: false
 Orchestrator: swarm

Server:
 Engine:
  Version:      18.03.1-ce
  API version:  1.37 (minimum version 1.12)
  Go version:   go1.9.5
  Git commit:   9ee9f40
  Built:        Thu Apr 26 07:23:58 2018
  OS/Arch:      linux/amd64
  Experimental: false

至此 docker 安装完成!

配置镜像加速

针对 Docker 客户端版本大于 1.10.0 的用户,可以通过修改 daemon 配置文件/etc/docker/daemon.json来使用加速器

sudo mkdir -p /etc/docker
sudo tee /etc/docker/daemon.json <<-'EOF'
{
  "registry-mirrors": ["https://xxxxxx.mirror.aliyuncs.com"]
}
EOF
sudo systemctl daemon-reload
sudo systemctl restart docker

Docker 常用命令

镜像相关命令

搜索镜像

Usage:  docker search [OPTIONS] TERM

Search the Docker Hub for images

Options:
  -f, --filter filter   Filter output based on conditions provided
      --format string   Pretty-print search using a Go template
      --limit int       Max number of search results (default 25)
      --no-trunc        Don't truncate output

下载镜像

Usage:  docker pull [OPTIONS] NAME[:TAG|@DIGEST]

Pull an image or a repository from a registry

Options:
  -a, --all-tags                Download all tagged images in the repository
      --disable-content-trust   Skip image verification (default true)

查看镜像

Usage:  docker images [OPTIONS] [REPOSITORY[:TAG]]

List images

Options:
  -a, --all             Show all images (default hides intermediate images)
      --digests         Show digests
  -f, --filter filter   Filter output based on conditions provided
      --format string   Pretty-print images using a Go template
      --no-trunc        Don't truncate output
  -q, --quiet           Only show numeric IDs

删除本地镜像

Usage:  docker rmi [OPTIONS] IMAGE [IMAGE...]

Remove one or more images

Options:
  -f, --force      Force removal of the image
      --no-prune   Do not delete untagged parents

保存镜像

Usage:  docker save [OPTIONS] IMAGE [IMAGE...]

Save one or more images to a tar archive (streamed to STDOUT by default)

Options:
  -o, --output string   Write to a file, instead of STDOUT

加载镜像

Usage:  docker load [OPTIONS]

Load an image from a tar archive or STDIN

Options:
  -i, --input string   Read from tar archive file, instead of STDIN
  -q, --quiet          Suppress the load output

容器相关命令

查看容器

Usage:  docker ps [OPTIONS]

List containers

Options:
  -a, --all             Show all containers (default shows just running)
  -f, --filter filter   Filter output based on conditions provided
      --format string   Pretty-print containers using a Go template
  -n, --last int        Show n last created containers (includes all states) (default -1)
  -l, --latest          Show the latest created container (includes all states)
      --no-trunc        Don't truncate output
  -q, --quiet           Only display numeric IDs
  -s, --size            Display total file sizes

停止容器

Usage:  docker stop [OPTIONS] CONTAINER [CONTAINER...]

Stop one or more running containers

Options:
  -t, --time int   Seconds to wait for stop before killing it (default 10)

启动已经停止的容器

Usage:  docker start [OPTIONS] CONTAINER [CONTAINER...]

Start one or more stopped containers

Options:
  -a, --attach               Attach STDOUT/STDERR and forward signals
      --detach-keys string   Override the key sequence for detaching a container
  -i, --interactive          Attach container's STDIN

重启容器

Usage:  docker restart [OPTIONS] CONTAINER [CONTAINER...]

Restart one or more containers

Options:
  -t, --time int   Seconds to wait for stop before killing the container (default 10)

进入容器

Usage:  docker exec [OPTIONS] CONTAINER COMMAND [ARG...]

Run a command in a running container

Options:
  -d, --detach               Detached mode: run command in the background
      --detach-keys string   Override the key sequence for detaching a container
  -e, --env list             Set environment variables
  -i, --interactive          Keep STDIN open even if not attached
      --privileged           Give extended privileges to the command
  -t, --tty                  Allocate a pseudo-TTY
  -u, --user string          Username or UID (format: <name|uid>[:<group|gid>])
  -w, --workdir string       Working directory inside the container

删除容器

Usage:  docker rm [OPTIONS] CONTAINER [CONTAINER...]

Remove one or more containers

Options:
  -f, --force     Force the removal of a running container (uses SIGKILL)
  -l, --link      Remove the specified link
  -v, --volumes   Remove the volumes associated with the container

导出容器

Usage:  docker export [OPTIONS] CONTAINER

Export a container's filesystem as a tar archive

Options:
  -o, --output string   Write to a file, instead of STDOUT

导入容器

Usage:  docker import [OPTIONS] file|URL|- [REPOSITORY[:TAG]]

Import the contents from a tarball to create a filesystem image

Options:
  -c, --change list      Apply Dockerfile instruction to the created image
  -m, --message string   Set commit message for imported image

查看运行日志

Usage:  docker logs [OPTIONS] CONTAINER

Fetch the logs of a container

Options:
      --details        Show extra details provided to logs
  -f, --follow         Follow log output
      --since string   Show logs since timestamp (e.g. 2013-01-02T13:23:37) or relative (e.g. 42m for 42 minutes)
      --tail string    Number of lines to show from the end of the logs (default "all")
  -t, --timestamps     Show timestamps
      --until string   Show logs before a timestamp (e.g. 2013-01-02T13:23:37) or relative (e.g. 42m for 42 minutes)

Dockerfile

Dockerfile 是用于构建镜像的文本文件,其中包含了构建镜像所需的指令与说明。

Dockerfile 常用指令

FROM 指定基础镜像

FROM centos:7

LABEL 为镜像添加元数据

LABEL maintainer="XXXX

MAINTAINER 指定维护者信息

MAINTAINER zqf<zqf@163.com>

RUN 执行命令

在构建镜像时运行的 Shell 命令

RUN <command>
RUN ["executable", "param1", "param2"]

CMD 容器启动命令

启动容器时执行的 Shell 命令,若存在多个则仅最后一条命令生效,且CMD设置的指令会被docker run命令中指定的运行参数所覆盖

CMD ["executable", "param1", "param2"] (推荐使用)
CMD ["param1", "param2"] (为 ENTRYPOINT 指令提供预设参数)
CMD command param1 param2 (在 Shell 中执行)

ENTRYPOINT 入口点

类似于CMD指令,但是其不会被docker run命令指定的运行参数覆盖,这些运行参数会被当作参数传送给ENTRYPOINT执行。但是, 如果运行docker run时使用了--entrypoint选项,将覆盖 ENTRYPOINT 指令指定的程序

ENTRYPOINT ["executable", "param1", "param2"]
ENTRYPOINT command param1 param2

EXPOSE 声明暴露的端口

EXPOSE 80 8080

ENV 设置环境变量

ENV JAVA_HOME /usr/local/jdk1.8.0_45

ADD 复制文件

将文件或者目录拷贝到镜像当中,若添加的目标源为 URL 或者压缩包,则会自动进行下载以及解压

ADD /root/test /var/test

COPY 复制文件

将文件或目录拷贝到镜像当中,用法同ADD,但是不会自动下载和解压

COPY ./start.sh /start.sh

VOLUME 指定挂载点

指定容器挂载点到宿主机自动生成的目录,一般不会在 dockerfile 中指定,而是在docker run中指定

VOLUME ["/var/lib/mysql"]

WORKDIR 切换工作目录

切换工作目录,类似cd

WORKDIR /data

USER 设置用户

RUN\CMD\ENTRYPOINT所设定的命令指定运行的用户

USER root

ARG 设构建参数

使用该指可以定义变量,并在构建镜像时进行指定

ARG <name>[=<default value>]

HEALTHCHECK 指定健康监察参数

  • --interval=DURATION (default: 30s):每隔多长时间探测一次,默认30秒 ;

  • --timeout=DURATION (default: 30s):服务响应超时时长,默认30秒 ;

  • --start-period= DURATION (default: 0s):服务启动多久后开始探测,默认0秒 ;

  • --retries=N (default: 3):认为检测失败几次为宕机,默认3次;

HEALTHCHECK --interval=5m --timeout=3s --retries=31

Dockerfile 简单使用案例

创建 Dockerfile 文件

vim Dockerfile

在文件中使用 Dockerfile 指令对镜像进行简单配置

FROM nginx
RUN echo '<h1>Test Dockerfile, Hello World!<h1>' > /usr/share/nginx/html/index.html

在 Dockerfile 所在文件夹执行命令构建镜像(注:最后的点表示当前路径)

docker build -t nginx:my .

执行下列命令,启动 docker 容器

docker run -d -p 8080:80 nginx:my

访问 ip:8080,即可看到修改后的 Nginx 欢迎页

在这里插入图片描述

Dockerfile 构建 java 项目镜像

首先创建 Dockerfile 文件

vim Dockerfile

在文件中对镜像进行配置(打包好的 jar 包应与 Dockerfile 放在同一路径下)

# 基础镜像
FROM openjdk:11.0.4
# author
MAINTAINER zqf
ENV TZ=Asia/Shanghai
# 挂载目录
VOLUME /tmp
# 指定路径
WORKDIR /data
# 复制jar文件到路径
ADD loginAndAuthDemo-1.0-SNAPSHOT.jar /data
# 容器提供的端口号
EXPOSE 8080
# 启动Jar包
ENTRYPOINT ["java","-jar","/data/loginAndAuthDemo-1.0-SNAPSHOT.jar"]

构建镜像

 docker build -t loginandauth:0.0.1 .
[root@ZQFLinux docker]# docker build -t loginandauth:0.0.1 .
Sending build context to Docker daemon  39.24MB
Step 1/8 : FROM openjdk:11.0.4
 ---> e6ca4006334d
Step 2/8 : MAINTAINER zqf
 ---> Running in 34ba969baa70
Removing intermediate container 34ba969baa70
 ---> 15ed171a1587
Step 3/8 : ENV TZ=Asia/Shanghai
 ---> Running in 79471ebe5815
Removing intermediate container 79471ebe5815
 ---> 9a3ea2277644
Step 4/8 : VOLUME /tmp
 ---> Running in c049ae463b63
Removing intermediate container c049ae463b63
 ---> 5261815b1615
Step 5/8 : WORKDIR /data
Removing intermediate container 289b5c915c77
 ---> 31ae4e733e04
Step 6/8 : ADD loginAndAuthDemo-1.0-SNAPSHOT.jar /data
 ---> 60bcb3ae3760
Step 7/8 : EXPOSE 8080
 ---> Running in 6b0f285a81d0
Removing intermediate container 6b0f285a81d0
 ---> 2edcbfdbaab7
Step 8/8 : ENTRYPOINT ["java","-jar","/data/loginAndAuthDemo-1.0-SNAPSHOT.jar"]
 ---> Running in 2365c4a17fb4
Removing intermediate container 2365c4a17fb4
 ---> 9921129fb03e
Successfully built 9921129fb03e
Successfully tagged loginandauth:0.0.1

启动容器

docker run -d -p 8080:8080 loginandauth:0.0.1

访问相应的ip:端口号,测试镜像是否正常运行(也可以通过docker logs查看日志)

在这里插入图片描述

Docker Compose

Docker compose 基本参数

composr version

version: '3.7' # 指定 compose 文件的版本

services

services 是定义服务的顶级属性,其下一级的属性就是一个服务

services:
  aaa: # 服务aaa
  bbb: # 服务bbb

networks

networks 是定义网络的顶级属性,其下一级属性就是一个网络

networks:
  aaa: # 网络aaa
    driver: overlay # 网络类型

services 配置参数

build

  build:                       # 与 image 二选一,指定包含构建上下文的路径, 或作为一个对象,该对象具有 context 和指定的 dockerfile 文件以及 args 参数值
      context: .               # context: 指定 Dockerfile 文件所在的路径
      dockerfile: Dockerfile   # dockerfile: 指定 context 指定的目录下面的 Dockerfile 的名称(默认为 Dockerfile)
      args:                    # args: Dockerfile 在 build 过程中需要的参数 (等同于 docker container build --build-arg 的作用)
        JAR_FILE: service.jar
      cache_from:              # v3.2中新增的参数, 指定缓存的镜像列表 (等同于 docker container build --cache_from 的作用)
      labels:                  # v3.3中新增的参数, 设置镜像的元数据 (等同于 docker container build --labels 的作用)
      shm_size:                # v3.5中新增的参数, 设置容器 /dev/shm 分区的大小 (等同于 docker container build --shm-size 的作用)

ports

    ports:             # 建立宿主机与容器间的端口映射关系,上面是短语法写法,下面是长语法写法
      - target: 80     # 容器端口
        published: 80  # 宿主机端口
        protocol: tcp  # 协议类型
        mode: host     # host 在每个节点上发布主机端口,ingress 对于集群模式端口进行负载均衡
      - target: 443
        published: 443
        protocol: tcp
        mode: host

command

    command: # 覆盖容器启动后默认执行的命令, 支持 shell 格式和 [] 格式

cgroup_parent

    cgroup_parent: # 为容器指定父 cgroup 组,意味着将继承该组的资源限制

container_name

    container_name: # 指定容器的名称 (等同于 docker run --name 的作用)

deploy

    deploy:               # v3 版本以上, 指定与部署和运行服务相关的配置, deploy 部分是 docker stack 使用的, docker stack 依赖 docker swarm
      endpoint_mode: vip  # v3.3 版本中新增的功能, 指定服务暴露的方式
                          # vip:Docker 为该服务分配了一个虚拟 IP(VIP), 作为客户端的访问服务的地址
                          # dnsrr:DNS 轮询, Docker 为该服务设置 DNS 条目, 使得服务名称的 DNS 查询返回一个 IP 地址列表, 客户端直接访问其中的一个地址
      labels:             # 指定服务的标签,这些标签仅在服务上设置
      mode: replicated    # 指定 deploy 的模式
                          # global:每个集群节点都只有一个容器
                          # replicated:用户可以指定集群中容器的数量(默认)
      placement:
        constraints:
          - node.role==manager # 指定该服务部署的节点,该指令表示将该服务部署到名为 master 的节点
      replicas: 1         # deploy 的 mode 为 replicated 时, 指定容器副本的数量
      resources:          # 资源限制
        limits:           # 设置容器的资源限制
          cpus: "0.5"     # 设置该容器最多只能使用 50% 的 CPU
          memory: 50M     # 设置该容器最多只能使用 50M 的内存空间
        reservations:     # 设置为容器预留的系统资源(随时可用)
          cpus: "0.2"     # 为该容器保留 20% 的 CPU
          memory: 20M     # 为该容器保留 20M 的内存空间
      restart_policy:     # 定义容器重启策略, 用于代替 restart 参数
        condition: on-failure # 定义容器重启策略(接受三个参数)
                              # none:不尝试重启
                              # on-failure:只有当容器内部应用程序出现问题才会重启
                              # any:无论如何都会尝试重启(默认)
        delay: 10s        # 尝试重启的间隔时间(默认为 0s)
        max_attempts: 6   # 尝试重启次数(默认一直尝试重启)
        window: 120s      # 检查重启是否成功之前的等待时间(即如果容器启动了, 隔多少秒之后去检测容器是否正常, 默认 0s)
      update_config:      # 用于配置滚动更新配置
        parallelism: 1    # 一次性更新的容器数量
        delay: 10s        # 更新一组容器之间的间隔时间
        order: stop-first # v3.4 版本中新增的参数, 回滚期间的操作顺序
                          # stop-first:旧任务在启动新任务之前停止(默认)
                          # start-first:首先启动新任务, 并且正在运行的任务暂时重叠
        failure_action: continue # 定义更新失败的策略
                          # continue:继续更新
                          # rollback:回滚更新
                          # pause:暂停更新(默认)
                          # monitor:每次更新后的持续时间以监视更新是否失败(单位: ns|us|ms|s|m|h) (默认为0)
        max_failure_ratio: 0 # 回滚期间容忍的失败率(默认值为0)
      rollback_config:    # v3.7 版本中新增的参数, 用于定义在 update_config 更新失败的回滚策略
        parallelism: 1    # 一次回滚的容器数, 如果设置为0, 则所有容器同时回滚
        delay: 0          # 每个组回滚之间的时间间隔(默认为0)
        failure_action: continue # 定义回滚失败的策略
                                 # continue:继续回滚
                                 # pause:暂停回滚
        monitor: 10s      # 每次回滚任务后的持续时间以监视失败(单位: ns|us|ms|s|m|h) (默认为0)
        max_failure_ratio: 0 # 回滚期间容忍的失败率(默认值0)
        order: stop-first # 回滚期间的操作顺序
                          # stop-first:旧任务在启动新任务之前停止(默认)
                          # start-first:首先启动新任务, 并且正在运行的任务暂时重叠

device

    devices: # 指定设备映射列表(等同于 docker run --device 的作用)

depend_on

    depends_on: # 指定依赖容器
      - aaa # 容器 aaa
      - bbb # 容器 bbb

dns

    dns: # 设置 DNS 地址(等同于 docker run --dns 的作用)
    dns_search: # 设置 DNS 搜索域(等同于 docker run --dns-search 的作用)

temfs

    tmpfs: # v2 版本以上, 挂载目录到容器中, 作为容器的临时文件系统(等同于 docker run --tmpfs 的作用, 在使用 swarm 部署时将忽略该选项)

entrypoint

    entrypoint: # 覆盖容器的默认 entrypoint 指令 (等同于 docker run --entrypoint 的作用)

env_file

    env_file: # 从指定文件中读取变量设置为容器中的环境变量, 可以是单个值或者一个文件列表, 如果多个文件中的变量重名则后面的变量覆盖前面的变量, environment 的值覆盖 env_file 的值
      RACK_ENV=development

volumes

    volumes:        # 定义容器和宿主机的数据卷映射关系
      - "/u01:/u01" # 映射容器内的 /u01 到宿主机的 /u01目录

environment

    environment: # 设置环境变量, environment 的值可以覆盖 env_file 的值 (等同于 docker run --env 的作用)
      - TZ=Asia/Shanghai
      - PORT_TO_EXPOSE=80
      - LOG_PATH=/opt/proj/logs
      - PROFILES_ACTIVE=prod

expose

    expose: # 暴露端口, 但是不能和宿主机建立映射关系, 类似于 Dockerfile 的 EXPOSE 指令

external_links

    external_links: # 连接不在 docker-compose.yml 中定义的容器或者不在 compose 管理的容器(docker run 启动的容器, 在 v3 版本中使用 swarm 部署时将忽略该选项)

extra_hosts

    extra_hosts: # 添加 host 记录到容器中的 /etc/hosts 中 (等同于 docker run --add-host 的作用)

healthcheck

    healthcheck: # v2.1 以上版本, 定义容器健康状态检查, 类似于 Dockerfile 的 HEALTHCHECK 指令
      test: NONE # 检查容器检查状态的命令, 该选项必须是一个字符串或者列表, 第一项必须是 NONE, CMD 或 CMD-SHELL, 如果其是一个字符串则相当于 CMD-SHELL 加该字符串
                 # NONE:禁用容器的健康状态检测
                 # CMD:test: ["CMD", "curl", "-f", "http://localhost"]
                 # CMD-SHELL:test: ["CMD-SHELL", "curl -f http://localhost || exit 1"] 或者 test: curl -f https://localhost || exit 1
      interval: 1m30s   # 每次检查之间的间隔时间
      timeout: 10s      # 运行命令的超时时间
      retries: 3        # 重试次数
      start_period: 40s # v3.4 以上新增的选项, 定义容器启动时间间隔
      disable: true     # true 或 false, 表示是否禁用健康状态检测和 test: NONE 相同

image

    image: # 指定 docker 镜像, 可以是远程仓库镜像、本地镜像

init

    init: # v3.7 中新增的参数, true 或 false 表示是否在容器中运行一个 init, 它接收信号并传递给进程

isolation

    isolation: # 隔离容器技术, 在 Linux 中仅支持 default 值

labels

    labels: # 使用 Docker 标签将元数据添加到容器, 与 Dockerfile 中的 LABELS 类似

links

    links: # 链接到其它服务中的容器, 该选项是 docker 历史遗留的选项, 目前已被用户自定义网络名称空间取代, 最终有可能被废弃(在使用 swarm 部署时将忽略该选项)

logging

    logging:       # 设置容器日志服务
      driver:      # 指定日志记录驱动程序, 默认 json-file (等同于 docker run --log-driver 的作用)
      options:     # 指定日志的相关参数 (等同于 docker run --log-opt 的作用)
        max-size:  # 设置单个日志文件的大小, 当到达这个值后会进行日志滚动操作
        max-file:  # 日志文件保留的数量

network_mode

    network_mode: # 指定网络模式 (等同于 docker run --net 的作用, 在使用 swarm 部署时将忽略该选项)

init

    init: # v3.7 中新增的参数, true 或 false 表示是否在容器中运行一个 init, 它接收信号并传递给进程

isolation

    isolation: # 隔离容器技术, 在 Linux 中仅支持 default 值

labels

    labels: # 使用 Docker 标签将元数据添加到容器, 与 Dockerfile 中的 LABELS 类似

links

    links: # 链接到其它服务中的容器, 该选项是 docker 历史遗留的选项, 目前已被用户自定义网络名称空间取代, 最终有可能被废弃(在使用 swarm 部署时将忽略该选项)

logging

    logging:       # 设置容器日志服务
      driver:      # 指定日志记录驱动程序, 默认 json-file (等同于 docker run --log-driver 的作用)
      options:     # 指定日志的相关参数 (等同于 docker run --log-opt 的作用)
        max-size:  # 设置单个日志文件的大小, 当到达这个值后会进行日志滚动操作
        max-file:  # 日志文件保留的数量

network_mode

    network_mode: # 指定网络模式 (等同于 docker run --net 的作用, 在使用 swarm 部署时将忽略该选项)

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.coloradmin.cn/o/60255.html

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈,一经查实,立即删除!

相关文章

Linux JDK8下载安装

JDK安装 整体步骤介绍 操作步骤: 1 查看自己linux版本位 getconf LONG_BIT(64位) 2. 下载jdk的安装包 这里提供三种方法下载: (以jdk-8u171-linux-x64.tar.gz为例) 2.1 官网下载jdk: 官网: https://www.oracle.com/downloads/ jdk最新版本下载: https://www.oracle.com…

带你玩转序列模型之seq2seq模型定向(集束)搜索

目录 一.基础模型 二.选择最可能的句子 三.定向搜索 四.改进定向搜索 五.定向搜索的误差分析 一.基础模型 在这一周&#xff0c;你将会学习seq2seq&#xff08;sequence to sequence&#xff09;模型&#xff0c;从机器翻译到语音识别&#xff0c;它们都能起到很大的作用…

【数据结构1】数据结构的基本概念

数据结构的基本概念 数据&#xff1a;数据是信息的载体&#xff0c;是描述客观事物属性的数、字符及所有能输入到计算机中并被计算机程序识别和处理的符号的集合。数据是计算机程序加工的原料。 数据元素、数据项&#xff1a;数据元素是数据的基本单位&#xff0c;通常作为一…

以太网 TCP协议(TCP交互过程中出现丢包时的解决机制-列举部分)

2.7.3 以太网 TCP协议&#xff08;TCP交互过程中出现丢包时的解决机制-列举部分&#xff09; 参考&#xff1a;CSDN_TCP的重传机制_博主.Pr Young&#xff0c;对描述进行了整理与结合个人的理解进行编写。 一、超时重传机制 在发送数据时&#xff0c;设定一个定时器&#xff0c…

Ubuntu下cmake使用入门

CMake是一个跨平台的安装&#xff08;编译&#xff09;工具&#xff0c;可以用简单的语句来描述所有平台的安装(编译过程)。他能够输出各种各样的makefile或者project文件。其包含自己的语法结构&#xff0c;只要按照其语法编写成CMakeLists.txt&#xff0c;然后camke程序就能对…

MAML:User Diverse Preference Modeling by Multimodal AttentiveMetric Learning

一、摘要 大多数现有的推荐系统用特征向量表示用户的偏好&#xff0c;当预测该用户对不同项目的偏好时&#xff0c;假设该特征向量是固定的。然而&#xff0c;同一个向量不能准确地捕捉用户对所有项目的不同偏好&#xff0c;特别是在考虑各种项目的不同特征时。为了解决这个问…

【应用】Kubernetes

Kubernetesk8s 安装流程安装前配置安装 docker 以及 k8s 组件初始化 k8s 集群测试使用&#xff1a;安装 kubernetes-dashboardk8s 基础概念k8s 核心技术概念k8s 内部组件k8s 中的 IP 地址K8S 服务暴露的三种方式k8s 安装流程 k8s-masterk8s-node01k8s-node02192.168.86.140192…

【编程题】【Scratch四级】2022.09 三个数排序

三个数排序 输入三个数&#xff0c;比较三个数的大小&#xff0c;并将这三个数按照从小到大的顺序说出。 1. 准备工作 &#xff08;1&#xff09;保留小猫角色&#xff0c;默认位置&#xff1b; &#xff08;2&#xff09;白色背景。 2. 功能实现 &#xff08;1&#xff…

Java基于SSM框架的教室预约申请管理系统 毕业设计

本教室管理系统主要包括系统用户管理模块、楼层信息管理模块、校内新闻管理、教室信息管理、登录模块、和退出模块等多个模块。它帮助教室管理实现了信息化、网络化,通过测试,实现了系统设计目标,相比传统的管理模式,本系统合理的利用了教室管理数据资源,有效的减少了教室管理的…

四旋翼无人机学习第13节--Padstack Editor的简单使用

文章目录0 前言1 绘制MP2120 QFN10封装焊盘(初步学习)1.1 数据手册确定焊盘种类1.2 软件设置焊盘11.3 软件设置焊盘22 绘制DM9000A LQFP48L封装焊盘(初步学习)2.1 数据手册确定焊盘种类2.2 软件设置焊盘3 绘制STC89C51 PDIP-40封装通孔焊盘(初步学习)3.1 数据手册确定焊盘种类3…

【Spring源码系列】Bean生命周期-Bean销毁

前言 Spring给我们提供了一种当bean销毁时调用某个方法的方式。那么&#xff0c;Spring底层到底是如何实现的呢&#xff1f;接下来&#xff0c;我们将从源码案例的方式来解析&#xff1a;spring如何实现当bean销毁时调用某个方法的。 一、Bean销毁介绍 bean销毁的时机 当sp…

[附源码]计算机毕业设计springboot智能衣橱APP

项目运行 环境配置&#xff1a; Jdk1.8 Tomcat7.0 Mysql HBuilderX&#xff08;Webstorm也行&#xff09; Eclispe&#xff08;IntelliJ IDEA,Eclispe,MyEclispe,Sts都支持&#xff09;。 项目技术&#xff1a; SSM mybatis Maven Vue 等等组成&#xff0c;B/S模式 M…

数据增强 - 当数据有限时如何使用深度学习(一)

本文是对图像的深度学习数据增强技术的全面综述前言我们都遇到过这种情况&#xff1a;您有一个可以使用机器学习模型实现的机会&#xff0c;但当您打开网络浏览器并搜索相关数据&#xff0c;很有可能&#xff0c;您会发现一个只有几百张图像的数据集。您记得最受欢迎的数据集的…

【项目_03】日历的回显、搭建热门精选、下拉加载更多、搜索框搭建 | 基于Vue3全家桶

&#x1f4ad;&#x1f4ad; ✨: 日历的回显、搭建热门精选、下拉加载更多、搜索框搭建 | 旅途拾景   &#x1f49f;&#xff1a;东非不开森的主页   &#x1f49c;: 心若有所向往&#xff0c;何惧道阻且长&#x1f49c;&#x1f49c;   &#x1f338;: 如有错误或不足之处&…

Android入门第38天-使用随鼠标移动的圆点来熟悉onTouchEvent

简介 平时包括之前的例子大量是基于TouchListener如&#xff1a;onClick这种一类的事件。 今天给大家带来的是TouchListener与OnTouchEvent的比较&#xff0c;以及多点触碰的知识点&#xff01; TouchListener是基于监听的&#xff0c;而OnTouchEvent则是基于回调的&#xff…

SNMP协议——网络管理概述

作者简介&#xff1a;一名在校云计算网络运维学生、每天分享网络运维的学习经验、和学习笔记。 座右铭&#xff1a;低头赶路&#xff0c;敬事如仪 个人主页&#xff1a;网络豆的主页​​​​​​ 目录 前言 一.网络管理概述 1.网络管理概念 2.网络管理功能 1.配置管理 …

Xshell连接如何记住用户秘钥文件

场景描述 服务器ssh登录有2种常用的方式&#xff1a; 方式1&#xff1a;用户密码认证&#xff0c;登录时输入用户名和密码。方式2&#xff1a;公钥认证(Public Key User Authentication)&#xff0c;登录时提供用户名私钥。公钥需要存储一份在服务器上该用户的~/.ssh/authori…

是德科技DSOX2002A型号示波器的使用

文章目录图使用自检电路单次触发按键恢复出厂设置水平调整区水平位移调整按钮水平时机调整旋钮垂直调整区通道启用按钮垂直档位调节旋钮垂直位移调整旋钮测量区图 使用 自检 黑色鳄鱼夹接地&#xff0c;伸缩探钩挂到左侧。 按下auto按键 使用测量按键可以调出波形的峰峰值与频…

Redis (持续更新…)

提到这个词&#xff0c;脑海里一连串&#xff1a;它是什么&#xff0c;能干什么&#xff0c;怎么干的&#xff0c;不用它行不行&#xff0c;有没有同类…… 其实就是5W2H&#xff0c;或者说凡事多问个为什么 先放官网&#xff1a; ​​​​​​Redis CRUG网站 它是开源存储…

非零基础自学Golang 2 开发环境 2.5 第一个Go 程序

非零基础自学Golang 学习文档地址&#xff1a;https://www.topgoer.cn/ 本文仅用于学习记录&#xff0c;不存在任何商业用途&#xff0c;如侵删【已联系过文档作者】 文章目录非零基础自学Golang2 开发环境2.5 第一个Go 程序2.5.1 Hello World2 开发环境 2.5 第一个Go 程序 2…