从0到1入门Docker

ops/2025/3/16 17:14:15/

一、快速入门

Docker run命令中的常见参数

  • -d:让容器后台运行
  • --name:给容器命名(唯一)
  • -e:环境变量
  • -p:宿主机端口映射到容器内端口
  • 镜像名称结构:Repository :TAG(镜像名:版本号)

二、Docker基础

1.常见命令

Docker最常见的命令就是操作镜像,容器的命令

2.数据卷

(1)介绍

数据卷(volume)是一个虚拟目录,是容器内目录宿主机目录之间映射的桥梁,方便我们操作容器内文件,或者方便迁移容器产生的数据

(2)数据卷常见命令

(3)如何挂载数据卷

创建容器时,使用

docker run -v 数据卷名:容器内目录

完成挂载,在容器创建时,如果发现挂载的数据卷不存在时,会自动创建

(4)本地目录挂载

docker run -v 本地目录:容器内目录

可以完成本地目录挂载,本地目录必须以“ ”或“ ./ ”开头,如果直接以名称开头,会被识别为数据卷而非本地目录

3.自定义镜像

镜像就是包含了应用程序,程序运行的系统函数库,运行配置等文件的文件包。构建镜像的过程其实就是把上述文件分层打包的过程。

(1)镜像结构

(Layer)

添加安装包,依赖,配置等,每次操作都形成新的一层

基础镜像(BaseImage)

应用依赖的系统函数库,环境,配置,文件等

入口(Entrypoint)

镜像运行入口,一般是程序启动的脚本和参数

(2)Dockerfile

Dockerfile就是一个文本文件,其中包含一个个的指令(Instruction),用指令来描述要执行什么操作来构建镜像。将来Docker可以根据Dockerfile帮我们构建镜像,常见指令如下:

示例:

当编写好了Dockerfile,可以利用下面命令来构建镜像:

docker build -t 镜像名 Dockerfile目录  .

其中:

  • -t:是给镜像起名,格式依然是repository:tag,不指定tag时,默认为latest
  • :是指定Dockerfile所在目录,如果就在当前目录,则指定为“.”

4.容器网络互连

默认情况下,所有容器都是以bridge方式连接到Docker的一个虚拟网桥上:

加入自定义网络的容器才可以通过容器互相访问,Docker的网络操作命令如下:

三、项目部署

1.Docker Compose

Docker Compose通过一个单独的docker-compose.yml模板文件(YAML文件)来定义一组相关联的应用容器,帮助我们实现多个相互关联的Docker容器的快速部署

示例:

version: "3.8"services:mysql:image: mysqlcontainer_name: mysqlports:- "3306:3306"environment:TZ: Asia/ShanghaiMYSQL_ROOT_PASSWORD: 123volumes:- "./mysql/conf:/etc/mysql/conf.d"- "./mysql/data:/var/lib/mysql"- "./mysql/init:/docker-entrypoint-initdb.d"networks:- hm-nethmall:build: context: .dockerfile: Dockerfilecontainer_name: hmallports:- "8080:8080"networks:- hm-netdepends_on:- mysqlnginx:image: nginxcontainer_name: nginxports:- "18080:18080"- "18081:18081"volumes:- "./nginx/nginx.conf:/etc/nginx/nginx.conf"- "./nginx/html:/usr/share/nginx/html"depends_on:- hmallnetworks:- hm-net
networks:hm-net:name: hmall

2.命令格式


http://www.ppmy.cn/ops/166254.html

相关文章

【eNSP实战】配置端口映射(NAT Server)

拓图 要求: 将AR1上的GE 0/0/1接口的地址从TCP协议的80端口映射到内网 Web服务器80端口 AR1接口配置 interface GigabitEthernet0/0/0ip address 192.168.0.1 255.255.255.0 # interface GigabitEthernet0/0/1ip address 11.0.1.1 255.255.255.0 # ip route-s…

设计模式-观察者模式、状态模式

目录 观察者模式 定义 类图 角色 优缺点 使用场景 状态模式 定义 类图 角色 优缺点 使用场景 观察者模式 定义 定义对象间的一种一对多的依赖关系,当一个对象的状态发生改变时,所有依赖于它的对象都得到通知并被自动更新 又被称为发布-订阅…

DC-6靶机详解

一、主机发现 arp-scan -l靶机ip为192.168.55.159 二、端口扫描、目录枚举、指纹识别、 2.1端口扫描 nmap 192.168.55.159发现没有开放特殊端口 看来信息收集的重点要放在网页中了 2.2目录枚举 dirb http://192.168.55.1592.3指纹识别 nmap 192.168.55.159 -sV -sC -O …

【PyCharm2024】一些好用的小功能

目录 一、全局查找及替换关键字 方法一: 方法二: 二、调整字体大小 三、调整Terminal的字体大小 四、改变行注释的斜体以及颜色 一、全局查找及替换关键字 编写程序时,通常想要在所有文件中查找或者替换某个词。 方法一: …

【linux驱动开发】创建proc文件系统中的目录和文件实现

1. proc_mkdir_data 说明: 用于在 /proc 文件系统中创建一个目录 函数原型: struct proc_dir_entry *proc_mkdir_data(const char *name, umode_t mode, struct proc_dir_entry *parent, void *data); 参数: const char *name: 要创建的目录…

C 语言进【进阶篇】之动态内存管理:从底层机制到实战优化

目录 🚀前言🌟动态内存分配的必要性🤔动态内存分配函数深度剖析💯malloc函数:内存申请的主力军💯free函数:释放内存的“清道夫”💯calloc函数:初始化内存的利器&#x1f…

Ceph(1):分布式存储技术简介

1 分布式存储技术简介 1.1 分布式存储系统的特性 (1)可扩展 分布式存储系统可以扩展到几百台甚至几千台的集群规模,而且随着集群规模的增长,系统整体性能表现为线性增长。分布式存储的水平扩展有以下几个特性: 节点…

Centos固定IP配置

虚拟机安装 安装vmware 网盘链接 安装centos7.5 网盘链接 安装教程自行查找 固定IP配置 对安装好的VMware进行网络配置,方便虚拟机连接网络,本次设置建议选择NAT模式,需要宿主机的Windows和虚拟机的Linux能够进行网络连接,…