docker 常用命令实践DEMO

1.1 docker run -d -p 8080:80 --name web_server nginx 命令的详细解读

  • docker run: 这是 Docker 的一个基本命令,用于从指定的镜像启动一个新的容器。

  • -d: 这个参数是 --detach 的简写,意味着容器将在后台运行。也就是说,命令会立即返回,并且容器会在后台作为一个独立的进程运行。

  • -p 8080:80: 这个参数用于端口映射。它将容器内部的 80 端口映射到宿主机的 8080 端口上。这意味着,当你访问宿主机的 8080 端口时,实际上是在访问容器内部的 80 端口。这对于暴露 Web 服务非常有用,因为你可以通过宿主机的 IP 地址和端口号来访问运行在容器内的 Web 应用。

  • --name web_server: 这个参数用于为容器指定一个名称,这里的名称是 web_server。通过指定名称,你可以更方便地引用和管理容器,而不是使用容器的 ID。

  • nginx: 这是要运行的镜像名称。在这个例子中,Docker 会从 Docker Hub(或你配置的其他镜像仓库)拉取 nginx 镜像(如果本地没有的话),并使用这个镜像来启动一个新的容器。

综上所述,这条命令的作用是在后台启动一个名为 web_server 的容器,该容器运行 nginx 镜像,并将容器内部的 80 端口映射到宿主机的 8080 端口上。这样,你就可以通过访问宿主机的 http://<宿主机IP>:8080 来访问运行在容器内的 nginx 服务了。

1.2 docker run -d --name ubuntu_container ubuntu 命令的详细解读

  • docker run: 这是 Docker 的核心命令之一,用于从指定的镜像启动一个新的容器实例。

  • -d: 这是 --detach 的简写形式,意味着容器将在后台运行,即作为守护进程运行。当你执行这个命令时,它不会阻塞你的终端,而是立即返回,让你能够继续在同一个终端中执行其他命令。容器会在后台运行,直到你手动停止它或它因为某种原因(如崩溃或达到重启策略的限制)而停止。

  • --name ubuntu_container: 这个参数用于为即将启动的容器指定一个名称。在这个例子中,容器的名称被设置为 ubuntu_container。指定容器名称的好处是,你可以通过名称而不是容器 ID 来引用和管理容器,这在处理多个容器时特别有用。

  • ubuntu: 这是要从中创建容器的 Docker 镜像的名称。在这个例子中,Docker 会从 Docker Hub(或你配置的其他镜像仓库)上拉取 ubuntu 镜像(如果本地没有的话),并使用这个镜像来启动一个新的容器。ubuntu 镜像通常包含了一个基本的 Ubuntu 操作系统环境。

综上所述,这条命令的作用是在后台启动一个名为 ubuntu_container 的容器,该容器运行 ubuntu 镜像。容器启动后,你可以在后台运行各种命令和应用程序,但由于没有指定要运行的特定命令(如 -it 参数和 /bin/bash),容器可能会立即进入“已退出”状态,因为它没有要执行的前台进程。如果你希望容器保持运行状态,你需要在 docker run 命令的末尾指定一个前台进程,比如 /bin/bash(用于交互式 shell)或任何你想要容器持续运行的服务。但在这个例子中,由于使用了 -d 参数,即使没有前台进程,容器也会在后台启动。如果你想要检查容器的状态或与之交互,你可以使用 docker ps 来列出所有正在运行的容器,或使用 docker exec 来在已运行的容器中执行命令。

1.3 docker run -it --name ubuntu_bash ubuntu /bin/bash 命令的详细解读

  • docker run: 这是 Docker 的一个基本命令,用于从指定的镜像启动一个新的容器实例。

  • -i, --interactive: 这个参数保持容器的标准输入(STDIN)开放。即使没有附加到容器,也可以通过这种方式与容器进行交互。这在你想要与运行在容器内的程序进行交互时非常有用。

  • -t, --tty: 这个参数分配一个伪终端(pseudo-TTY)或终端。这通常与 -i 参数一起使用,以提供一个交互式 shell。当你想要以命令行界面与容器交互时,这是必需的。

  • --name ubuntu_bash: 这个参数为即将启动的容器指定了一个名称,即 ubuntu_bash。通过指定名称,你可以更容易地引用和管理容器,而不是使用容器的唯一标识符(ID)。

  • ubuntu: 这是要从中创建容器的 Docker 镜像的名称。Docker 会从 Docker Hub(或你配置的其他镜像仓库)上拉取这个镜像(如果本地没有的话),并使用它来启动一个新的容器。

  • /bin/bash: 这是容器启动后要运行的命令。在这个例子中,它启动了一个 Bash shell。由于使用了 -it 参数,这个 shell 会是交互式的,并且你会被带到容器的命令行界面中。

综上所述,这条命令的作用是以交互模式启动一个名为 ubuntu_bash 的容器,该容器运行 ubuntu 镜像,并在容器内启动一个 Bash shell。一旦命令执行,你就会看到一个 Bash 提示符,可以在其中运行命令,就像在一个真实的 Ubuntu 环境中一样。这个环境是隔离的,意味着你在容器内所做的任何更改都不会影响你的宿主机系统。当你完成工作后,可以通过输入 exit 命令来退出 Bash shell,并停止容器(除非你在后台启动了其他进程)。

1.4 docker run -d -e MY_VAR=myvalue --name env_example ubuntu 命令的详细解读

  • docker run: 这是 Docker 的一个基本命令,用于从指定的镜像启动一个新的容器实例。

  • -d, --detach: 这个参数告诉 Docker 在后台运行容器,并打印容器 ID。这意味着容器会在后台运行,你不会直接看到容器的输出或提示符。

  • -e, --env: 这个参数用于设置环境变量。在这个例子中,MY_VAR=myvalue 设置了一个名为 MY_VAR 的环境变量,其值为 myvalue。环境变量可以在容器内运行的程序中使用。

  • --name env_example: 这个参数为即将启动的容器指定了一个名称,即 env_example。通过指定名称,你可以更容易地引用和管理容器,而不是使用容器的唯一标识符(ID)。

  • ubuntu: 这是要从中创建容器的 Docker 镜像的名称。Docker 会从 Docker Hub(或你配置的其他镜像仓库)上拉取这个镜像(如果本地没有的话),并使用它来启动一个新的容器。

由于在这个命令中没有指定要运行的命令(如 /bin/bash),容器会按照镜像的默认命令来运行。对于 ubuntu 镜像,默认命令通常是启动一个 Bash shell,但由于使用了 -d 参数,这个 shell 会在后台运行,并且由于没有附加到容器,所以你不会看到任何输出。

然而,需要注意的是,对于 ubuntu 镜像的默认行为,仅仅启动一个后台的 Bash shell 并没有太多实际意义,因为 Bash shell 在没有输入的情况下不会执行任何操作。在实际应用中,你可能会在 -d 模式下运行一个服务,如 Web 服务器或数据库,这些服务会在后台持续运行并监听特定的端口。

在这个特定的例子中,如果你想要验证环境变量 MY_VAR 是否已设置,你可能需要附加到容器并检查,或者运行一个能够显示环境变量的命令,如 envprintenv。但由于容器是在后台运行的,你需要先找到容器的 ID 或名称,然后使用 docker exec 命令来附加或运行命令。

例如,要查看环境变量,你可以这样做:

docker exec env_example env | grep MY_VAR

或者,如果你想要以交互方式附加到容器并手动检查环境变量,你可以这样做:

docker exec -it env_example /bin/bash

然后在 Bash 提示符下输入 echo $MY_VAR 来查看环境变量的值。不过,请注意,由于 ubuntu 镜像的默认行为,如果容器没有运行任何持续的服务,它可能会在你附加后不久就停止运行(因为 Bash shell 退出了)。在这种情况下,你可能需要修改容器的启动命令或运行一个持续的服务来保持容器运行。

1.5 docker run -d -v /path/on/host:/path/in/container --name volume_example ubuntu 命令的详细解读:

  • docker run: Docker 的基本命令,用于从指定的镜像启动一个新的容器实例。

  • -d, --detach: 这个参数告诉 Docker 在后台运行容器,并打印容器 ID。容器会在后台运行,你不会直接看到容器的输出或提示符。

  • -v, --volume: 这个参数用于挂载一个卷(volume)或绑定挂载(bind mount)一个主机目录到容器内的一个路径。在这个例子中,/path/on/host:/path/in/container 表示将主机上的 /path/on/host 目录挂载到容器内的 /path/in/container 路径。这样,容器内对该路径的读写操作实际上会作用于主机上的对应目录。

    • /path/on/host:这是主机上的目录路径,你希望将其内容共享给容器。
    • /path/in/container:这是容器内的路径,你将能够访问主机上 /path/on/host 目录的内容。
  • --name volume_example: 这个参数为即将启动的容器指定了一个名称,即 volume_example。通过指定名称,你可以更容易地引用和管理容器。

  • ubuntu: 这是要从中创建容器的 Docker 镜像的名称。Docker 会从 Docker Hub(或你配置的其他镜像仓库)上拉取这个镜像(如果本地没有的话),并使用它来启动一个新的容器。

当改变主机卷的内容时,容器内的相应挂载点会立即发生变化。这是因为 Docker 的卷挂载机制允许主机和容器之间共享文件系统的一部分。当你将主机的目录挂载到容器内的一个路径时,容器对该路径的访问实际上是对主机目录的访问。

具体来说,当你使用 -v--volume 参数将主机的目录挂载到容器内时,Docker 会在容器启动时创建一个到主机目录的绑定。这意味着,容器内对该挂载点的任何读写操作都会直接反映在主机目录上,反之亦然。

因此,如果你在主机上修改了挂载目录的内容(如添加、删除或修改文件),这些变化会立即在容器内的对应挂载点上可见。同样地,如果你在容器内对挂载点进行了修改,这些变化也会立即反映在主机目录上。

这种机制使得 Docker 卷成为在容器和主机之间共享数据的一种非常有效的方式。它允许你在容器外部管理和备份数据,同时仍然能够在容器内部访问和使用这些数据。

需要注意的是,虽然卷挂载提供了主机和容器之间的数据共享,但它并不影响容器的镜像。镜像中的文件和数据是静态的,而卷挂载允许你在运行时动态地修改数据。因此,卷挂载是 Docker 中管理容器数据的一种非常灵活和强大的方式。

1.6 docker ps 命令的解释

  • 基本功能:列出当前正在运行的容器。
选项
  • -a, --all

    • 功能:列出所有容器(包括正在运行的和已经停止的)。
    • 解释:这个选项会扩展输出,以包括所有容器,而不仅仅是当前正在运行的那些。
  • -n=<number>, --last=<number>

    • 功能:显示最近创建的指定数量的容器。
    • 解释? 应该被替换为具体的数字,表示你想要显示的最近创建的容器数量。例如,docker ps -n=5 会显示最近创建的5个容器。
  • -q, --quiet

    • 功能:只显示容器的编号(ID)。
    • 解释:这个选项会抑制其他所有输出,只显示每个容器的唯一标识符(通常是一个长字符串)。
示例
  • docker ps:列出当前正在运行的容器。
  • docker ps -a:列出所有容器,包括已经停止的。
  • docker ps -n=3:显示最近创建的3个容器。
  • docker ps -q:只显示所有正在运行的容器的编号。
  • docker ps -aq:结合使用 -a-q,列出所有容器的编号(无论是否正在运行)。

1.7 docker rm <容器ID>

  • 功能:删除指定的容器。
  • 限制:该命令只能删除已经停止运行的容器。如果尝试删除一个正在运行的容器,Docker 会报错。
  • 强制删除:如果确实需要删除一个正在运行的容器,可以使用 -f--force 选项来强制删除。但请注意,强制删除容器可能会导致数据丢失,因为容器内的进程将不会得到正常终止的机会。
docker rm -f <容器ID>docker rm --force <容器ID>
  • 功能:强制删除指定的容器,无论它是否正在运行。
docker rm -f $(docker ps -aq)
  • 功能:删除所有容器。
  • 解释
    • docker ps -aq:列出所有容器的ID,无论它们是否正在运行。
    • $(...):命令替换,将括号内的命令输出作为外部命令的参数。
    • docker rm -f:强制删除指定的容器。
  • 组合效果:这个命令会删除所有列出的容器ID,即删除所有容器。
docker ps -aq | xargs docker rm
  • 功能:也是删除所有容器。
  • 解释
    • docker ps -aq:同样列出所有容器的ID。
    • |:管道符号,将前一个命令的输出作为后一个命令的输入。
    • xargs:构建并执行命令行,将输入数据(这里是容器ID列表)作为参数传递给 docker rm 命令。
  • 组合效果:与上一个命令相同,这个命令也会删除所有容器。
注意事项
  • 在执行删除所有容器的命令之前,请确保您真的想要删除它们,因为这会永久移除容器及其数据(除非数据被挂载在外部卷上)。
  • 如果您的 Docker 环境中包含重要数据或正在运行的服务,请谨慎使用这些命令。

1.8 启动、重启、停止和强制停止容器的详细解释

docker start <容器ID>
  • 功能:启动一个已经创建但当前未运行的容器。
  • 使用场景:当您想要运行一个之前已经停止或从未运行过的容器时,可以使用此命令。
docker restart <容器ID>
  • 功能:先停止再启动指定的容器。
  • 使用场景:当容器出现问题或您需要刷新其状态时,可以使用此命令。它相当于先执行 docker stop <容器ID>,然后立即执行 docker start <容器ID>
docker stop <容器ID>
  • 功能:优雅地停止一个正在运行的容器。
  • 解释:Docker 会向容器发送一个 SIGTERM 信号,允许容器内的进程有机会进行清理操作并正常退出。如果进程在一定时间内没有响应,Docker 将强制停止容器。
  • 使用场景:当您想要停止一个正在运行的容器时,可以使用此命令。
docker kill <容器ID>
  • 功能:强制停止一个正在运行的容器。
  • 解释:与 docker stop 不同,docker kill 会立即向容器发送一个 SIGKILL 信号,强制终止容器内的所有进程,而不给它们任何清理的机会。
  • 使用场景:当 docker stop 命令无法停止容器,或者您需要立即终止容器时,可以使用此命令。

请注意,在使用 docker kill 命令之前,最好先尝试使用 docker stop 命令,因为它允许容器内的进程进行正常的清理操作。只有在必要的情况下才应使用 docker kill 命令。

1.9 要从 Docker 容器内部拷贝文件到主机上,你可以使用 docker cp 命令。这个命令允许你在容器和主机之间复制文件和目录。

以下是 docker cp 命令的基本语法和用法示例:

语法
docker cp [OPTIONS] CONTAINER:SRC_PATH DEST_PATH
docker cp [OPTIONS] SRC_PATH CONTAINER:DEST_PATH
  • CONTAINER 是容器的名称或 ID。
  • SRC_PATH 是源路径,可以是容器内的路径或主机上的路径。
  • DEST_PATH 是目标路径,可以是主机上的路径或容器内的路径。
从容器内拷贝到主机上

要将文件或目录从容器内拷贝到主机上,你需要指定容器内的源路径和主机上的目标路径。例如:

docker cp 容器ID或名称:/容器内/路径/到/文件或目录 /主机上/的目标/路径
示例

假设你有一个名为 my_container 的容器,并且你想要将容器内的 /app/data.txt 文件拷贝到主机的 /home/user/data.txt 路径下,你可以使用以下命令:

docker cp my_container:/app/data.txt /home/user/data.txt

如果你想要拷贝整个目录,比如将容器内的 /app 目录拷贝到主机的 /home/user/app_backup 目录下,你可以这样做:

docker cp my_container:/app /home/user/app_backup

请注意,目标路径在主机上必须存在,或者你有权限创建它。如果目标路径已经存在并且是一个文件,而你想要拷贝的是一个目录,那么操作会失败。同样地,如果目标路径是一个目录,但你想要拷贝的是一个文件,并且该目录下已经存在一个同名文件,那么该文件将被覆盖。

使用 docker cp 命令时,请确保容器正在运行,因为你需要访问容器内的文件系统。如果容器已经停止,你可能需要先启动它,或者从容器的卷或备份中恢复数据。

1.10 docker run -it -v /home/ceshi:/home centos /bin/bash 包含了一些特定的选项和参数,下面是对这些组件的详细解读

docker run
  • 功能:创建并启动一个新的容器。
-it
  • 这是两个选项的组合:-i-t
  • -i--interactive:保持容器的标准输入(STDIN)开放,即使没有附加到容器。
  • -t--tty:分配一个伪终端(pseudo-TTY)或终端,这通常与 -i 一起使用,以便与容器进行交互。
-v /home/ceshi:/home
  • -v--volume:创建一个卷挂载点。
  • /home/ceshi:/home:指定了源路径和目标路径。这里,主机的 /home/ceshi 目录被挂载到容器的 /home 目录。
    • /home/ceshi 是主机上的路径。
    • /home 是容器内的路径。
  • 这意味着,对容器内 /home 目录的任何读写操作都会反映到主机的 /home/ceshi 目录上,反之亦然。
centos
  • 功能:指定要运行的镜像名称。在这个例子中,它指的是 Docker Hub 上的官方 CentOS 镜像。
/bin/bash
  • 功能:容器启动后要执行的命令。
  • 在这个例子中,容器启动后将运行 Bash shell,允许用户与容器进行交互。
综合解读

综上所述,docker run -it -v /home/ceshi:/home centos /bin/bash 命令的功能是:

  1. 使用 CentOS 镜像创建一个新容器。
  2. 分配一个伪终端,并保持标准输入开放,以便与容器进行交互。
  3. 将主机的 /home/ceshi 目录挂载到容器的 /home 目录。
  4. 在容器内启动 Bash shell。

执行此命令后,用户将能够在一个交互式的 Bash 会话中操作容器,同时容器的 /home 目录将与主机的 /home/ceshi 目录同步。

1.11 启动了一个名为mysql01的MySQL 5.7容器,该容器的MySQL服务可以通过宿主机的3310端口访问,root用户的密码设置为123456,并且容器的配置文件和数据分别被挂载到了宿主机的/home/mysql/conf和/home/mysql/data目录下

docker run -d -p 3310:3306 -v /home/mysql/conf:/etc/mysql/conf.d -v /home/mysql/data:/var/lib/mysql -e MYSQL_ROOT_PASSWORD=123456 --name mysql01 mysql:5.7

这条命令是用于在Docker中运行一个MySQL 5.7容器的。下面是对这个命令的详细解释:

  • docker run: 这是Docker的一个命令,用于运行一个新的容器实例。

  • -d: 这个参数指定容器在后台运行(detached mode)。这意味着命令会立即返回,而容器会在后台继续运行。

  • -p 3310:3306: 这个参数将容器内部的3306端口映射到宿主机的3310端口。MySQL的默认端口是3306,这里通过端口映射,使得你可以通过宿主机的3310端口访问容器内的MySQL服务。

  • -v /home/mysql/conf:/etc/mysql/conf.d: 这个参数挂载了一个卷(volume),将宿主机的/home/mysql/conf目录映射到容器内的/etc/mysql/conf.d目录。这通常用于放置自定义的MySQL配置文件。

  • -v /home/mysql/data:/var/lib/mysql: 类似于上面的参数,这个参数将宿主机的/home/mysql/data目录映射到容器内的/var/lib/mysql目录。MySQL的数据(如数据库和表)存储在这个目录下,因此通过挂载这个目录,可以持久化MySQL的数据,即使容器被删除,数据也不会丢失。

  • -e MYSQL_ROOT_PASSWORD=123456: 这个参数设置了环境变量MYSQL_ROOT_PASSWORD的值为123456。在MySQL容器中,这个环境变量用于设置root用户的密码。

  • --name mysql01: 这个参数为容器指定了一个名字mysql01,方便以后通过名字来引用或管理容器,而不是使用容器的ID。

  • mysql:5.7: 这指定了要运行的镜像的名称和标签。这里使用的是mysql镜像的5.7版本。Docker会从Docker Hub(一个镜像仓库)下载这个镜像(如果本地没有的话),并使用它来启动容器。

综上所述,这条命令启动了一个名为mysql01的MySQL 5.7容器,该容器的MySQL服务可以通过宿主机的3310端口访问,root用户的密码设置为123456,并且容器的配置文件和数据分别被挂载到了宿主机的/home/mysql/conf/home/mysql/data目录下。

1.12 docker build -f /home/docker-test-volume/dockerfile1 -t kuangshen/centos:1.0 .

这条命令是在使用 Docker 来构建一个新的镜像。下面是对这个命令各部分的解释:

  • docker build:这是 Docker CLI 中用于构建 Docker 镜像的命令。

  • -f /home/docker-test-volume/dockerfile1-f--file 选项后面跟的是 Dockerfile 的路径。在这个例子中,Dockerfile 位于 /home/docker-test-volume/ 目录下,文件名为 dockerfile1。Dockerfile 是一个文本文件,包含了一系列指令,这些指令定义了镜像的内容。

  • -t kuangshen/centos:1.0-t--tag 选项用于给构建的镜像指定一个标签(tag),格式通常是 <仓库名>/<镜像名>:<标签>。在这个例子中,仓库名是 kuangshen,镜像名是 centos,标签是 1.0。这意味着构建完成后,镜像将被命名为 kuangshen/centos:1.0

  • .:这个点表示 Dockerfile 所在的上下文路径。在构建镜像时,Docker 会将上下文路径下的所有文件和目录发送到 Docker daemon。虽然在这个命令中直接指定了 Dockerfile 的路径,但上下文路径仍然需要指定,用于可能包含在 Dockerfile 中的 COPYADD 指令所需的文件。在这个例子中,. 表示当前目录是上下文路径,但因为已经通过 -f 选项明确指定了 Dockerfile 的路径,所以上下文路径主要用于查找 Dockerfile 中引用的其他文件。

综上所述,这条命令的意思是:使用位于 /home/docker-test-volume/dockerfile1 的 Dockerfile 来构建一个名为 kuangshen/centos:1.0 的 Docker 镜像,其中 . 表示当前目录作为构建上下文。

1.13 docker run -d -p 3307:3306 -e MYSQL_ROOT_PASSWORD=123456 --name mysql02 --volumes-from mysql01 mysql:5.7

这条 docker run 命令用于在 Docker 中启动一个新的 MySQL 5.7 容器实例,同时配置了一些特定的参数。下面是对这条命令的详细解释:

  • docker run: Docker CLI 的一个命令,用于运行一个新的容器实例。

  • -d: 指定容器在后台运行(detached mode)。

  • -p 3307:3306: 将容器内部的 3306 端口映射到宿主机的 3307 端口。这意味着你可以通过宿主机的 3307 端口来访问容器内的 MySQL 服务。

  • -e MYSQL_ROOT_PASSWORD=123456: 设置环境变量 MYSQL_ROOT_PASSWORD 的值为 123456。在 MySQL 容器中,这个环境变量用于设置 root 用户的密码。

  • --name mysql02: 为容器指定一个名字 mysql02,方便以后通过名字来引用或管理容器。

  • --volumes-from mysql01: 这个参数指定新启动的容器 mysql02 将从已经存在的容器 mysql01 那里挂载所有的卷(volumes)。这意味着 mysql02 可以访问 mysql01 容器中定义的所有卷的数据。这通常用于数据共享或数据迁移的场景。

  • mysql:5.7: 指定要运行的镜像的名称和标签。这里使用的是 mysql 镜像的 5.7 版本。

综上所述,这条命令的作用是:在后台启动一个名为 mysql02 的 MySQL 5.7 容器,将其内部的 3306 端口映射到宿主机的 3307 端口,设置 root 用户的密码为 123456,并从名为 mysql01 的容器中挂载所有卷。

需要注意的是,--volumes-from 参数依赖于 mysql01 容器的存在,并且 mysql01 容器中应该已经定义了一些卷(虽然在您提供的命令中并没有显示 mysql01 容器的创建过程,但我们假设它之前已经被创建并定义了一些卷)。此外,由于 MySQL 数据通常存储在 /var/lib/mysql 目录下,如果 mysql01 容器也是 MySQL 容器,并且您希望 mysql02 容器能够访问相同的数据集,那么您应该确保 mysql01 容器的 /var/lib/mysql 目录被定义为一个卷。

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

如若内容造成侵权/违法违规/事实不符,请联系我们进行投诉反馈qq邮箱809451989@qq.com,一经查实,立即删除!

相关文章

Eclipse配置Tomcat服务器(最全图文详解)

前言&#xff1a; 本章使用图文讲解如何在Eclipse开发工具中配置Tomcat服务器、如何创建和启动JavaWeb工程&#xff0c;欢迎童鞋们互相交流。觉得不错可以三连订阅喔。 目标&#xff1a; 一、配置Tomcat服务器 1. 切换Eclipse视图 2. 打开菜单 3. 找到服务选项 4. 选择…

汽车供应链关键节点:物流采购成本管理全解析

在汽车行业&#xff0c;供应链管理是一项至关重要的任务。汽车制造从零部件的生产到整车的交付&#xff0c;涉及多个环节&#xff0c;其中物流、采购与成本管理是核心节点。本文将深入分析这些关键环节&#xff0c;探讨如何通过供应商管理系统及相关工具优化供应链管理。 一、…

软件工程期末整理(二)

快速原型开发模型是&#xff08;适用于客户需求难以清楚定义、规模较小的系统&#xff09;。(编写系统实施计划)不是系统设计阶段的主要活动 解释&#xff1a;系统实施计划”更侧重于后续的实施与部署阶段&#xff0c;属于项目管理层面的内容 协作性不属于构件的特性在类图中…

STM32-笔记35-DMA(直接存储器访问)

一、什么叫DMA&#xff1f; DMA&#xff08;Direct Memory Access&#xff0c;直接存储器访问&#xff09;提供在外设与内存、存储器和存储器之间的高速数据传输使用。它允许不同速度的硬件装置来沟通&#xff0c;而不需要依赖于CPU&#xff0c;在这个时间中&#xff0c;CPU对于…

代码管理助手-Git

前言 Git 是一个版本控制系统&#xff0c;可以帮助你记录文件的每一次修改。这样&#xff0c;如果你在编程时不小心把代码写错了&#xff0c;可以很容易地回退到之前的版本。最重要的是&#xff0c;Git 是完全免费的&#xff0c;用户可以在自己的计算机上安装和使用 Git&#x…

蓝耘:GPU算力云服务的技术探索与AIGC应用支持

&#x1f3ac; 江城开朗的豌豆&#xff1a;个人主页 &#x1f525; 个人专栏 :《 VUE 》 《 javaScript 》 &#x1f4dd; 个人网站 :《 江城开朗的豌豆&#x1fadb; 》 ⛺️ 生活的理想&#xff0c;就是为了理想的生活 ! 目录 一、蓝耘的核心优势 1. 行业领先的基础设施 …

Kubernetes Gateway API-4-TCPRoute和GRPCRoute

1 TCPRoute 目前 TCP routing 还处于实验阶段。 Gateway API 被设计为与多个协议一起工作&#xff0c;TCPRoute 就是这样一个允许管理TCP流量的路由。 在这个例子中&#xff0c;我们有一个 Gateway 资源和两个 TCPRoute 资源&#xff0c;它们按照以下规则分配流量&#xff1…

在不到 5 分钟的时间内将威胁情报 PDF 添加为 AI 助手的自定义知识

作者&#xff1a;来自 Elastic jamesspi 安全运营团队通常会维护威胁情报报告的存储库&#xff0c;这些报告包含由报告提供商生成的大量知识。然而&#xff0c;挑战在于&#xff0c;这些报告的内容通常以 PDF 格式存在&#xff0c;使得在处理安全事件或调查时难以检索和引用相关…

Unity学习之UGUI进阶

一、事件监听接口 1、作用 用于实现类型长按、双击、拖拽等基础控件无法实现的功能 所有控件都能够添加更多的事件监听来处理对应的逻辑 2、事件监听接口类型 &#xff08;1&#xff09;常用事件接口 &#xff08;2&#xff09;不常用事件接口 3、使用事件监听接口 &#…

Redis为 List/Set/Hash 的元素设置单独的过期时间

一.业务简介 我们知道&#xff0c;Redis 里面暂时没有接口给 List、Set 或者 Hash 的 field 单独设置过期时间&#xff0c;只能给整个列表、集合或者 Hash 设置过期时间。 这样&#xff0c;当 List/Set/Hash 过期时&#xff0c;里面的所有 field 元素就全部过期了。但这样并不…

【Notepad++】Notepad++如何删除包含某个字符串所在的行

Notepad如何删除包含某个字符串所在的行 一&#xff0c;简介二&#xff0c;操作方法三&#xff0c;总结 一&#xff0c;简介 在使用beyoundcompare软件进行对比的时候&#xff0c;常常会出现一些无关紧要的地方&#xff0c;且所在行的内容是变化的&#xff0c;不方便进行比较&…

APP上架之Android 证书 MD5 指纹

Android 证书 MD5 指纹 1. 什么是 Android 证书 MD5 指纹&#xff1f; Android 证书 MD5 指纹是对证书数据进行 MD5 哈希运算后得到的 128 位字符串。在 Android 开发中&#xff0c;每个证书在理论上都有一个唯一的 MD5 指纹&#xff0c;用于识别和验证证书的有效性。证书指纹…

软件安全性测试有哪些测试方法?

随着数字化进程的加速&#xff0c;软件在各个领域扮演着越来越重要的角色。软件的安全性测试作为保证软件质量和安全的重要环节&#xff0c;逐渐成为企业在开发和部署过程中不可或缺的一部分。 一、软件安全性测试的测试方法   1、静态分析法&#xff1a;通过分析源代码或二…

LabVIEW轴承性能测试系统

本文介绍了基于LabVIEW的高效轴承性能测试系统的设计与开发。系统通过双端驱动技术实现高精度同步控制&#xff0c;针对轴承性能进行全面的测试与分析&#xff0c;以提高轴承的可靠性和寿命。 项目背景 随着工业自动化程度的提高&#xff0c;对轴承的性能要求越来越高。传统的…

57. Three.js案例-创建一个带有聚光灯和旋转立方体的3D场景

57. Three.js案例-创建一个带有聚光灯和旋转立方体的3D场景 实现效果 该案例实现了使用Three.js创建一个带有聚光灯和旋转立方体的3D场景。 知识点 WebGLRenderer&#xff08;WebGL渲染器&#xff09; THREE.WebGLRenderer 是 Three.js 中用于将场景渲染为 WebGL 内容的核…

如何使用vue引入three.js

在 Vue.js 项目中引入和使用 Three.js 是一个常见的需求&#xff0c;Three.js 是一个用于在浏览器中创建和显示动画 3D 计算机图形的 JavaScript 库。以下是一个基本的示例&#xff0c;展示如何在 Vue 项目中引入和使用 Three.js。 1. 创建 Vue 项目 如果你还没有一个 Vue 项…

9.4 visualStudio 2022 配置 cuda 和 torch (c++)

一、配置torch 1.Libtorch下载 该内容看了【Libtorch 一】libtorchwin10环境配置_vsixtorch-CSDN博客的博客&#xff0c;作为笔记用。我自己搭建后可以正常运行。 下载地址为windows系统下各种LibTorch下载地址_libtorch 百度云-CSDN博客 下载解压后的目录为&#xff1a; 2.vs…

【JavaEE进阶】获取Cookie/Session

&#x1f340;Cookie简介 HTTP协议自身是属于 "⽆状态"协议. "⽆状态"的含义指的是: 默认情况下 HTTP 协议的客⼾端和服务器之间的这次通信,和下次通信之间没有直接的联系.但是实际开发中,我们很多时候是需要知道请求之间的关联关系的. 例如登陆⽹站成…

oscp备考 oscp系列——Kioptix Level 1靶场 古老的 Apache Vuln

目录 前言 1. 主机发现 2. 端口扫描 3. 指纹识别 4. 目录扫描 5. 漏洞搜索和利用 前言 oscp备考&#xff0c;oscp系列——Kioptix Level 1靶场 Kioptix Level 1难度为简单靶场&#xff0c;主要考察 nmap的使用已经是否会看输出&#xff0c;以及是否会通过应用查找对应漏…

CSS——2.书写格式一

<!DOCTYPE html> <html><head><meta charset"UTF-8"><title></title></head><body><!--css书写中&#xff1a;--><!--1.css 由属性名:属性值构成--><!--style"color: red;font-size: 20px;&quo…