docker 部署项目的操作文档,安装nginx

news2025/1/11 13:56:42

目录

  • 1 部署环境检查
  • 2 相关知识点
    • 2.1 docker默认镜像存放地址
    • 2.2 docker 的镜像都是tar 包?
    • 2.3 Docker-compose 是直接使用镜像创建容器?
    • 2.4 Docker Compose down 就是将容器删除?
    • 2.5 删除,会删除挂载嘛
    • 2.6 DockerFile 和 docker compose 区别
  • 3 部署nginx

1 部署环境检查

1  是否安装docker 
2  是否安装docker-compose
3  docker默认镜像存放地址在/var/lib/docker 目录下,查看此目录下是否有足够的空间
		df -h 目录名   查看所在目录 挂载目录及使用情况
4  查看机器,生成数据的存储空间
		dh -h 
5  检查是否系统是否为x86系统内核,( 部署包内的 java8镜像,smb软件 只支持x86系统)
		uname -a		

2 相关知识点

2.1 docker默认镜像存放地址

在Linux系统上,Docker默认将镜像存储在/var/lib/docker目录下。这个目录包含了Docker的运行时数据,包括镜像、容器、卷等。

/var/lib/docker目录下,镜像的具体存放位置如下:

  • 镜像层(Image Layers):/var/lib/docker/image/overlay2目录下存放了镜像的各个层。
  • 镜像元数据(Image Metadata):/var/lib/docker/image/overlay2/repositories.json文件包含了镜像的元数据信息,如镜像的名称、标签等。

请注意,/var/lib/docker目录下的文件和目录属于Docker的运行时数据,对其进行修改或删除可能会导致Docker的不稳定或数据丢失。如果你需要备份或迁移Docker的镜像数据,建议使用Docker提供的相关命令或工具来操作。

此外,值得一提的是,Docker的存储驱动可以根据不同的配置进行更改,因此实际的镜像存放位置可能会因配置而异。但对于大多数默认安装的Docker环境来说,/var/lib/docker是默认的镜像存放地址。

2.2 docker 的镜像都是tar 包?

是的,Docker的镜像实际上是以tar包的形式存储的。每个Docker镜像都由多个层(layers)组成,这些层以文件系统的形式存储在Docker宿主机上。

每个镜像层都是一个只读的文件系统,它包含了文件和目录的快照。当你使用Docker构建镜像时,每一条指令都会创建一个新的镜像层。这种分层的结构使得镜像的构建和共享变得高效,因为多个镜像可以共享相同的层。

当你从Docker Hub或其他镜像仓库拉取镜像时,实际上是将这些镜像层以tar包的形式下载到本地。这些tar包会被Docker存储在宿主机的文件系统中,供后续的容器创建和运行使用。

你可以使用docker save命令将镜像保存为tar包,使用docker load命令将tar包加载为镜像。这些命令可以让你在不同的Docker环境之间备份、迁移和共享镜像。

总结起来,Docker镜像实际上是由多个层组成的,以tar包的形式存储在宿主机上。这种分层结构和使用tar包的方式使得Docker镜像的构建、共享和管理变得更加灵活和高效。

2.3 Docker-compose 是直接使用镜像创建容器?

是的,Docker Compose是一个用于定义和运行多容器Docker应用程序的工具。使用Docker Compose,你可以使用一个单独的YAML文件来定义多个容器、它们之间的关联关系以及其他配置选项。然后,通过运行docker-compose up命令,Docker Compose将根据定义的配置创建并启动所有的容器。

在Docker Compose配置文件中,你可以指定要使用的镜像名称、容器的名称、端口映射、环境变量、卷挂载等等。当你运行docker-compose up命令时,Docker Compose会自动下载所需的镜像(如果本地不存在)并创建相应的容器。

下面是一个简单的Docker Compose配置文件示例,用于创建一个包含PostgreSQL和Redis两个容器的应用程序:

version: '3'
services:
  db:
    image: postgres
    environment:
      POSTGRES_PASSWORD: mysecretpassword
  redis:
    image: redis

在这个示例中,我们定义了两个服务(即容器):dbredisdb服务使用了postgres镜像,并设置了PostgreSQL的密码为mysecretpasswordredis服务使用了redis镜像。

要运行这个配置文件,你可以在包含该文件的目录中打开终端或命令提示符,并运行以下命令:

docker-compose up

Docker Compose将会根据配置文件创建并启动dbredis两个容器。你可以通过docker-compose ps命令来查看容器的状态。

总结来说,Docker Compose是通过配置文件来创建和管理多个容器的工具,它简化了多容器应用程序的部署和管理过程。

2.4 Docker Compose down 就是将容器删除?

是的,docker-compose down命令用于停止并删除由Docker Compose启动的容器。当你运行docker-compose down命令时,Docker Compose将会停止并删除在配置文件中定义的所有服务(容器),同时还会删除相关的网络和卷(如果有定义)。这个命令可以用来清理整个应用程序的运行环境。

需要注意的是,docker-compose down命令会删除容器及其相关资源,包括数据卷中的数据。如果你希望保留数据,可以使用docker-compose stop命令来停止容器,而不是使用docker-compose down命令。

确保在运行docker-compose down命令之前,你已经进入到包含docker-compose.yml文件的目录,并且已经安装并正确配置了Docker Compose。

2.5 删除,会删除挂载嘛

是的,当你使用docker-compose down命令删除容器时,它会删除与容器相关联的挂载卷(如果有定义)。挂载卷是将容器内的路径与宿主机上的路径进行关联,以便在容器重启或删除后保留数据。

如果你希望保留挂载卷中的数据,可以使用docker-compose down -v命令。这个命令会在删除容器的同时,也删除挂载卷。如果你想要保留挂载卷中的数据,可以备份或迁移挂载卷的数据到其他位置,然后再运行docker-compose down -v命令来删除容器和挂载卷。

需要注意的是,删除挂载卷会永久删除其中的数据,因此在执行删除操作之前,请确保备份了重要的数据。

yml  里面写了    volumes:
      - /home/docker/nginx/data:/web/   之后down  之后,宿主机里面的数据会删除嘛

如果你在docker-compose.yml文件中使用了以下的挂载卷定义:

volumes:
  - /home/docker/nginx/data:/web/

然后执行docker-compose down命令来删除容器,那么默认情况下,这个挂载卷/home/docker/nginx/data上的数据将会被保留在宿主机上。

docker-compose down命令默认会删除容器实例,但不会删除挂载卷。只有在使用docker-compose down -v命令时,才会删除与容器关联的挂载卷。

因此,如果你只执行了docker-compose down命令,宿主机上的数据将会保留在/home/docker/nginx/data目录中。如果你想要删除挂载卷以及宿主机上的数据,可以使用docker-compose down -v命令。在执行删除操作之前,请确保备份了重要的数据。

2.6 DockerFile 和 docker compose 区别

Dockerfile 和 Docker Compose 是 Docker 中两个不同的概念和工具,它们用于不同的目的。

Dockerfile 是一个文本文件,用于定义和构建 Docker 镜像。它包含了一系列的指令,用于描述如何构建一个 Docker 镜像的步骤,包括基础镜像选择、安装软件包、复制文件、设置环境变量等。通过 Dockerfile,你可以自定义和管理你的镜像构建过程,以满足你的应用程序的需求。

Docker Compose 是一个工具,用于定义和管理多个 Docker 容器的应用程序。它使用一个 YAML 文件(通常称为 docker-compose.yml)来描述应用程序的不同服务、网络设置、卷挂载等配置。通过 Docker Compose,你可以定义一个多容器的应用程序,并使用一个命令来启动、停止、重启整个应用程序。它简化了多容器应用程序的部署和管理。

总结一下:

  • Dockerfile 用于构建 Docker 镜像,描述了如何构建一个镜像的步骤。
  • Docker Compose 用于定义和管理多个 Docker 容器的应用程序,描述了应用程序的不同服务和配置。

在实际使用中,你可以使用 Dockerfile 构建一个镜像,然后使用 Docker Compose 来定义和管理多个使用这个镜像的容器。这样可以方便地管理容器之间的关系、网络设置等,并实现整个应用程序的部署和管理。

3 部署nginx

将nginx 的 tar 包上传到服务器
在这里插入图片描述
在这里插入图片描述
输入docker images,发现目前是没有镜像的,现在将tar 包变成镜像

docker load -i   nginx.tar

在这里插入图片描述
以上就将tar 包变成镜像了

在这里插入图片描述
因为需要容器里面目录和宿主机目录要一一挂载,容器卷,所以我们在宿主机上面创建要和容器一一对应的目录

在这里插入图片描述
以上是ngixn 的目录,以后修改这个宿主机目录下的东西,nginx 容器里面就会修改。
这个conf 目录文件夹下,有一个nginx 配置

在这里插入图片描述
这个就是ngixn 的配置文件,以后我们就是修改这个配置文件

因为我们要使用 Docker-compose 去管理容器,所以要使用Docker-compose 的东西;

我们需要找一个位置,专门放各个yml 文件

在这里插入图片描述

现在有一个关于nginx 的yml 编排文件,就是使用他去管理

里面内容是:

version: "2"
services:
  nginx:
    image: nginx
    hostname: nginx
    container_name: nginx
    ports:
      - "18080:8080"
      - "18082:8081"
      - "18088:8087"
    volumes:
      - /home/docker/nginx/data:/web/
      - /home/docker/nginx/html:/usr/share/nginx/html
      - /home/docker/nginx/conf/nginx.conf:/etc/nginx/nginx.conf
      - /home/docker/nginx/logs:/var/log/nginx
      - /home/metefont/hongt-data-center/hkdata:/HKONG/hkdata
      - /home/metefont/mapdata:/home/metefont/mapdata
    environment:
      - TZ=Asia/Shanghai

这个文件是一个Docker Compose的配置文件,用于创建和管理一个Nginx容器。

让我逐行解释每一行代码的意思:

version: "2"

这是Docker Compose配置文件的版本号。在这个示例中,使用的是版本号为2的配置文件格式。

version: "2"
services:
  nginx:
    image: nginx
    hostname: nginx
    container_name: nginx
    ports:
      - "18080:8080"
      - "18082:8081"
      - "18088:8087"
    volumes:
      - /home/softinstall/docker/nginx/data:/web/
      - /home/softinstall/docker/nginx/html:/usr/share/nginx/html
      - /home/softinstall/docker/nginx/conf/nginx.conf:/etc/nginx/nginx.conf
      - /home/softinstall/docker/nginx/logs:/var/log/nginx
      - /home/metefont/hongt-data-center/hkdata:/HKONG/hkdata
      - /home/metefont/mapdata:/home/metefont/mapdata
    environment:
      - TZ=Asia/Shanghai

这部分定义了一个名为nginx的服务(即Nginx容器)。以下是每个配置项的含义:

  • image: nginx:指定使用的镜像为nginx,这将从Docker Hub上下载Nginx镜像。

  • hostname: nginx:设置容器的主机名为nginx

  • container_name: nginx:指定容器的名称为nginx

  • ports:定义端口映射,将主机的端口与容器的端口进行绑定。在这个示例中,将主机的18080端口映射到容器的8080端口,将主机的18082端口映射到容器的8081端口,将主机的18088端口映射到容器的8087端口。

  • volumes:定义卷挂载,将主机的目录与容器的目录进行映射。在这个示例中,将主机的/home/docker/nginx/data目录映射到容器的/web/目录,将主机的/home/docker/nginx/html目录映射到容器的/usr/share/nginx/html目录,将主机的/home/docker/nginx/conf/nginx.conf文件映射到容器的/etc/nginx/nginx.conf文件,将主机的/home/docker/nginx/logs目录映射到容器的/var/log/nginx目录,将主机的/home/metefont/hongt-data-center/hkdata目录映射到容器的/HKONG/hkdata目录,将主机的/home/metefont/mapdata目录映射到容器的/home/metefont/mapdata目录。

  • environment:设置环境变量。在这个示例中,设置时区为Asia/Shanghai

这个配置文件的作用是创建一个名为nginx的Nginx容器,并指定了端口映射、卷挂载和环境变量等配置。通过运行docker-compose up命令,Docker Compose将会根据这个配置文件创建并启动该容器。

在这个nginx.yml  文件夹下,执行下面就启动了
docker-compose -f nginx.yml up -d

查看日志
docker logs -f nginx

确保nginx.conf   没问题,才可以启动成功

关闭容器
docker-compose -f nginx.yml down

如果第一次启动失败,要修改完配置文件之后,关闭之后重新启动
先执行
docker-compose -f nginx.yml down
后执行
docker-compose -f nginx.yml up -d

在这里插入图片描述
进入容器内部:

docker  exec -it 容器id    /bin/bash

放一个图片,浏览器访问

在这里插入图片描述

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

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

相关文章

远程求职:有什么不同吗?

外面的世界很大,你渴望探索它,但面对现实吧,你必须吃饭。远程工作可能就是答案。下面的博客详细介绍了您需要了解的有关找到工作的细节,同时也可以让您在需要时收拾行李继续前进。 申请任何工作,无论是远程工作还是办…

服务容错-熔断策略之断路器hystrix-go

文章目录 概要一、服务熔断二、断路器模式三、hystrix-go3.1、使用3.2、源码 四、参考 概要 微服务先行者Martin Fowler与James Lewis在文章microservices中指出了微服务的九大特征,其中一个便是容错性设计(Design for failure)。正如文章中提到的,微服…

宋仕强论道之华强北精神和文化(二十一)

华强北的精神会内化再提炼和升华成为华强北文化,在外部会流传下去和传播开来。在事实上的行动层面,就是华强北人的思维方式和行为习惯,即见到机会就奋不顾身敢闯敢赌,在看似没有机会的时候拼出机会,和经济学家哈耶克企…

【OSG案例详细分析与讲解】之四:【3D动画场景】

文章目录 一、【3D动画场景】前言 二、【3D动画场景】实现效果 三、【3D动画场景】创建动画路径 1、实现目的 2、创建动画路径步骤 3、核心代码 4、知识要点 5、AnimationPath详讲 四、【3D动画场景】创建基础模型 1、实现目的 2、创建基础模型步骤 3、核心代码 4、知识要点 5、…

openssl3.2 - 官方dmeo学习 - server-arg.c

文章目录 openssl3.2 - 官方dmeo学习 - server-arg.c概述笔记备注END openssl3.2 - 官方dmeo学习 - server-arg.c 概述 TLS服务器, 等客户端来连接; 如果客户端断开了, 通过释放bio来释放客户端socket, 然后继续通过bio读来aceept. 笔记 对于开源工程, 不可能有作者那么熟悉…

uniapp 字母索引列表插件(组件版) Ba-SortList

简介(下载地址) Ba-SortList 是一款字母索引列表组件版插件,可自定义样式,支持首字母字母检索、首字检索、搜索等等;支持点击事件。 支持首字母字母检索支持首字检索支持搜索支持点击事件支持长按事件支持在uniapp界…

VMware vSphere运维管理手册

适用版本:VMware vSphere 7.0 VMware vSphere 是 VMware 的虚拟化平台,可将数据中心转换为包括 CPU、存储和网络资源的聚合计算基础架构。vSphere 将这些基础架构作为一个统一的运行环境进行管理,并为您提供工具来管理加入该环境的数据中心。 ![[Pasted image 20231212132…

数据库原理与应用期末复习试卷1

数据库原理与应用期末复习试卷1 一.单项选择题 数据库系统是采用了数据库技术的计算机系统,由系统数据库,数据库管理系统,应用系统和(C)组成。 ​ A.系统分析员 B.程序员 C.数据库管理员 D.操作员 数据库系统的体系…

YOLOv5改进 | 检测头篇 | DynamicHead支持检测和分割(不同于网上版本,全网首发)

一、本文介绍 本文给大家带来的改进机制是DynamicHead(Dyhead),这个检测头由微软提出的一种名为“动态头”的新型检测头,用于统一尺度感知、空间感知和任务感知。网络上关于该检测头我查了一些有一些魔改的版本,但是我觉得其已经改变了该检测头的本质,因为往往一些细节上才…

解决STM32F7系列芯片TIM无法触发ADC采样的问题

我在测试STM32F746 ADC DMA TIM 做AD采样时候发现 使用cubeMX 库生成的代码无法进入DMA中断,发现官方勘误手册有做解释,需要打开DAC时钟。如下 如上图,在ADC初始化代码中加入 __HAL_RCC_DAC_CLK_ENABLE();

统一密钥管理在信息安全领域有什么作用

统一密钥管理在信息安全领域中至关重要。它可以确保密钥的安全性、保密性和可用性,同时降低开发、维护和管理的成本。 对于没有KMS(密钥管理服务)管理系统的公司,密钥的本地化管理可能导致密钥分散在代码、配置文件中,缺乏统一管理&#xff0…

999合1超级简易文字菜单组件

引言 超级简易文字菜单组件 大家好,相信大家都玩过那个999合1的游戏,特别是那个菜单。 在游戏开发中,往往会有形式各异的游戏菜单,游戏菜单和菜单一样主要是给玩家选择开始游戏、设置、排行榜等功能的。 本文将分享一下笔者在…

【MMC子系统】四、MMC控制器驱动层

我的圈子: 高级工程师聚集地 我是董哥,高级嵌入式软件开发工程师,从事嵌入式Linux驱动开发和系统开发,曾就职于世界500强企业! 创作理念:专注分享高质量嵌入式文章,让大家读有所得! …

网络服务DHCP与DNS

一 DHCP的工作原理(租约过程) 分类 1)自动分配:分配到一个IP地址后永久使用 (2)手动分配:由DHCP服务器管理员指定IP(打印机、报销系统)把mac地址和ip地址做一个一一对…

猫粮对比:性价比高的主食冻干猫粮推荐

虽然很多铲屎官可能认为给猫咪喂猫粮就足够了,但实际上猫咪对蛋白质的需求很高,并且作为肉食动物,它们更喜欢肉的味道。而冻干猫粮是采用低温和真空干燥处理技术将鲜肉制成,去除水分并保持蛋白质等营养物质不变性,同时…

办公自动应用,HR大屏可视化模板

大家可以进行资料下载。 完整的案例。 AIGC ChatGPT 职场案例 AI 绘画 与 短视频制作 PowerBI 商业智能 68集 数据库Mysql 8.0 54集 数据库Oracle 21C 142集 Office 2021实战应用 Python 数据分析实战, ETL Informatica 数据仓库案例实战 Excel 2021实操 100集&a…

premiere简约大气3D动画logo片头Pr模板Mogrt免费下载

Premiere简约大气3D动画logo片头pr模板mogrt下载,无需插件,高清分辨率,易于自定义,包括教程,不包括音频和图像。免费下载:https://prmuban.com/37065.html

路由黑洞和黑洞路由的区别

路由黑洞: 路由黑洞是一种现象,一般是在网络边界做汇总回程路由的时候产生的一种不太愿意出现的现象,就是汇总的时候有时会有一些不在内网中存在的网段,但是又包含在汇总后的网段中,如果在这个汇总的边界设备上同时还配…

【JVM】本地方法接口 Native Interface

一、JNI简介 JVM本地方法接口(Java Native Interface,JNI)是一种允许Java代码调用本地方法(如C或C编写的方法)的机制。这种技术通常用于实现高性能的计算密集型任务,或者与底层系统库进行交互。 二、JNI组…

西门子S7-1200与S7-300PLC的九大不同点

S7-1200作为新推出的紧凑型控制器,其产品定位在原有的SIMATIC S7-200和S7-300之间,它与S7-300的区别主要体现在硬件、通信、工程、存储器、功能块、计数器、定时器、工艺功能等方面。 一、硬件的区别 在硬件扩展方面,S7-300的主机架多支持八…