docker简易入门(极简,纯干货)

简介

Docker是一种容器化平台,它可以用来轻松地创建、部署和运行应用程序和服务。Docker使用容器技术来管理应用程序的运行环境,它将应用程序和服务打包到一个易于移植的容器中,然后在任何地方运行这个容器,无需担心不同环境之间的差异。使用Docker,您可以轻松地构建、测试、部署和扩展应用程序,从而大大提高了开发和部署的效率。Docker的核心是Docker引擎,它是一个轻量级的运行时环境,可以在任何操作系统上运行。Docker还提供了一系列命令行工具和API,使开发人员和系统管理员可以轻松地管理Docker容器和镜像。

核心

Docker的核心是Docker引擎(Docker Engine),它是一个开源的容器化技术,能够简化应用程序的开发、部署和管理。

Docker Engine包括以下几个核心组件:

1. Docker守护进程(Docker daemon):Docker守护进程是运行在主机上的长期运行的进程,用于管理Docker容器、镜像、网络、数据卷等资源。

2. Docker客户端(Docker client): Docker客户端是Docker命令行工具,用于与Docker守护进程进行通信,同时也是用户与Docker交互的主要方式。

3. Docker镜像(Docker image): Docker镜像是一个只读的模板,它包含了用于创建Docker容器的文件系统和应用程序。

4. Docker容器(Docker container): Docker容器是由Docker镜像创建的运行实例,可以运行应用程序及其依赖项,同时具有隔离和可移植性。

5. Docker仓库(Docker registry): Docker仓库是用于存储Docker镜像的中央存储库,可以是公共的或私有的,用户可以从中拉取Docker镜像来创建和运行容器。

以上组件结合在一起就形成了Docker的整体架构,帮助用户快速、高效地构建、发布和管理软件应用程序。

实战

docker安装

linux自动安装

curl -fsSL https://get.docker.com | bash -s docker --mirror Aliyun

或者

curl -sSL https://get.daocloud.io/docker | sh

或者通过宝塔控制面板

......

linux离线安装

离线安装包下载

Index of linux/static/stable/x86_64/

你可以先找一个顺眼些的包下载(结合实际情况,不建议使用最新版本,相对不稳定)

可以直接下载到你本地电脑再上传到测试机,也可以直接在你的测试机上下载

wget https://download.docker.com/linux/static/stable/x86_64/docker-17.12.1-ce.tgz  

解压

tar -zxvf docker-17.12.1-ce.tgzcp docker/* /usr/bin/cd /etc/systemd/system/vi docker.service
[Unit]
Description=Docker Application Container Engine
Documentation=https://docs.docker.com
After=network-online.target firewalld.service
Wants=network-online.target[Service]
Type=notify
ExecStart=/usr/bin/dockerd --selinux-enabled=false --insecure-registry=127.0.0.1
ExecReload=/bin/kill -s HUP $MAINPID
LimitNOFILE=infinity
LimitNPROC=infinity
LimitCORE=infinityTimeoutStartSec=0
Delegate=yes
KillMode=process
Restart=on-failure
StartLimitBurst=3
StartLimitInterval=60s[Install]
WantedBy=multi-user.target

保存并退出:wq

然后授权

chmod +x /etc/systemd/system/docker.service
# 重新加载配置文件(每次有修改docker.service文件时都要重新加载下)
systemctl daemon-reload
# 启动
systemctl start docker
# 设置开机启动
systemctl enable docker.service

 如果出现意外情况,请自行百度吧,很多情况就不说了哈,这里只讲成功的情况

控制面板

当然有很多这个控制面板,我这里就直接选择了SimpleDocker,当然你也可以忽略直接使用命令

 docker pull registry.cn-hangzhou.aliyuncs.com/seven-tao/simple-docker:0.0.7.1

创建一个进入某个文件夹创建docker-compose.yaml

然后编辑

version: '3'
services:redis:image: redis:latestrestart: alwaysweb:image: registry.cn-hangzhou.aliyuncs.com/seven-tao/simple-docker:0.0.7.1restart: alwaysports:- "9091:4050"volumes:- /tmp/simple-docker/back:/tmp/back- /var/run/docker.sock:/var/run/docker.sockdepends_on:- redis

然后在该文件所在文件夹执行

docker compose up -d

 我这里有很多,你们先忽略哈哈,你们应该只有最后两条

docker常见命令

pull拉取镜像
push推送镜像

search查询镜像

run创建并运行
start/stop/restart启动已被停止的容器/停止容器/重启
kill杀死运行中的某个进程
rm删除一个或多个容器
rmi删除一个或多个镜像
pause暂停容器中的所有进程
unpause恢复所有进程
create创建一个信容器但不启动
exec容器中执行
images镜像
ps列出运行中的容器
stop停止
inspect查看容器或镜像的详细信息。
build使用Dockerfile文件构建一个新的Docker镜像。
docker-compose使用docker-compose.yml文件管理多个容器的运行和停止

 以上就是比较常见的命令了,相对不常见我就不列出来了

配置加速器

linux

/etc/docker/daemon.json

{"registry-mirrors" : ["https://hub-mirror.c.163.com"]
}
windows

找到你的docker安装目录进入\.docker,我这里装的是docker desktop

它不让选择地址,默认就是我的C:\Users\Administrator\.docker这个位置

编辑它就对了

我这里地址不一样哈

例子

安装软件

docker ps

可以看到我现在没有运行中的容易,好的

那我加一个容器

就拿redis来做例子吧

可以看到仓库中存在这些redis镜像

你可以选择某一个镜像进行下载,可以拉取

docker pull ~~~~~~~

我这里就直接一点直接运行

docker run -d -p 6379:6379 --name redis redis:latest

 可以看到redis直接给跑起来了,实际上你直接用docker run  它会检测你本地存不存在这个镜像,不存在它会pull拉取到你所指定的版本,存在就直接创建容器运行

目录挂载
volume挂载数据卷

我创建了一个为redis的数据卷

然后查询了这个数据卷的信息

docker run -d -p 6379:6379 --name redis-2 -v redis:/data redis:latest --appendonly yes --requirepass zkb.com

然后用可视化工具连接这个redis试试

可以看到连接成功,但是没有什么数据,数据卷里面肯定也是空的,那我们造点数据

docker exec -it redis-2 bashredis-cliauth zkb.comset zxs 123456get zxs

bind mount挂载主机目录

可以看到我们的宿主机是window操作系统

我在宿主机里面创建了  conf与data两个文件夹

conf里面创建了redis.conf配置文件

这个配置你们可以使用默认的也可以根据自己的实际情况配置

docker run -p 6379:6379 --name redis -v /E/docker/redis/conf:/etc/redis/redis.conf  -v /E/docker/redis/data:/data -d redis redis-server /etc/redis/redis.conf --appendonly yes

这样我们的宿主机挂载就成功了

这里主要说明一下,如果宿主机挂载的宿主机为window则需要把 你的盘符修改为   /你的盘名/~~

例如我挂载的目录在E盘   那么我的挂载路径应为

/E/docker/redis/conf:/etc/redis/redis.conf  -v /E/docker/redis/data:/data

 我们经常download别人工程是不是总是看到别人带了一个Dockerfile文件,是不是不明白它是干嘛的,别着急我来说说

 我这边就随便写个访问计数吧

然后我这个demo需要发布到docker里面,怎么搞

创建Dockerfile
# 设置基础镜像
FROM adoptopenjdk/openjdk11# 将JAR文件添加到镜像中
ADD target/demo1-0.0.1-SNAPSHOT.jar demo.jar# 定义容器启动命令
ENTRYPOINT ["java", "-jar", "/demo.jar"]

这边我就在本地pack了,那怎么执行这个Dockerfile呢

创建镜像
docker build -t demo-image .

 注意最后面的 “ .”  这个是不能忽略的

 

 已经做成镜像放到docker里面了哈

执行
docker run -d -p 6333:6333 demo-image

测试

已经ok了,当然我这里写的是最简单的Dockerfile

Docker-compose

当我们有多个服务,依赖又非常多,那么我们需要把这些服务聚合到一起,就需要写一个

docker-compose.yml

就如之前我们的控制面板,依赖了redis。。。。,那我们要把它集合到一起,就写了一个docker-compose.yml,当然也可以分开,你得提前做好容器直接的通讯,我这里只做例子

制作docker-compose.yml
version: '3'
services:redis:image: redis:latestrestart: alwaysweb:image: registry.cn-hangzhou.aliyuncs.com/seven-tao/simple-docker:0.0.7.1restart: alwaysports:- "9091:4050"volumes:- /tmp/simple-docker/back:/tmp/back- /var/run/docker.sock:/var/run/docker.sockdepends_on:- redis
执行docker-compose.yml
docker compose up -d

容器间通讯

都知道docker容器直接都是互相隔离的,应此容器之间无法ping信息,那么这些容器之间维护一套网络模式,是不是可以通讯呢

创建网络

docker network create zxs-net
docker run -d --name redis --network zxs-net --network-alias redis redis:latest

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

如若内容造成侵权/违法违规/事实不符,请联系编程知识网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

机器视觉系统的组成

图像获取 光学系统采集图像,图像转换成模拟格式并传入计算机存储器。 图像处理和分析 处理器运用不同的算法来提高对结论有重要影响的图像要素并形成数据作为判决依据。 判决和输出 处理器的控制程序根据收到的数据做出结论并输出信息作反馈控制等应用。

Java版本+企业电子招投标系统源代码+支持二开+招投标系统+中小型企业采购供应商招投标平台

功能模块: 待办消息,招标公告,中标公告,信息发布 描述: 全过程数字化采购管理,打造从供应商管理到采购招投标、采购合同、采购执行的全过程数字化管理。通供应商门户具备内外协同的能力,为外部供…

深度学习 大数据 股票预测系统 - python lstm 计算机竞赛

文章目录 0 前言1 课题意义1.1 股票预测主流方法 2 什么是LSTM2.1 循环神经网络2.1 LSTM诞生 2 如何用LSTM做股票预测2.1 算法构建流程2.2 部分代码 3 实现效果3.1 数据3.2 预测结果项目运行展示开发环境数据获取 最后 0 前言 🔥 优质竞赛项目系列,今天…

高防CDN节点部署:流量攻击抵御的专业解决方案

随着网络攻击日益复杂和频繁,对于网站安全的需求也变得愈发迫切。高防CDN(Content Delivery Network)作为一种专业的网络安全解决方案,通过节点部署在全球范围内,能够有效抵御各种流量攻击,为网站提供可靠的…

适配器模式 rust和java的实现

文章目录 适配器模式介绍何时使用应用实例优点缺点使用场景 实现java实现rust 实现 rust代码仓库 适配器模式 适配器模式(Adapter Pattern)是作为两个不兼容的接口之间的桥梁。这种类型的设计模式属于结构型模式,它结合了两个独立接口的功能…

【工程实践】Docker使用记录

前言 服务上线经常需要将服务搬到指定的服务器上,经常需要用到docker,记录工作中使用过dcoker指令。 1.写Dockerfile 1.1 全新镜像 FROM nvidia/cuda:11.7.1-devel-ubuntu22.04ENV WORKDIR/data/Qwen-14B-Chat WORKDIR $WORKDIR ADD . $WORKDIR/RUN ap…

计算机视觉(CV)技术的优势和挑战

计算机视觉技术在很多领域具有很大的优势,例如: 自动化:计算机视觉技术可以帮助实现自动化生产和检测,省去了人力成本和时间成本。 准确性:计算机视觉技术可以提高生产和检测的准确性,降低了人工操作产生的误差。 速度:计算机视觉技术可以实现高速速度的生产和检测,提高…

Python实战 | 使用 Python 和 TensorFlow 构建卷积神经网络(CNN)进行人脸识别

专栏集锦,大佬们可以收藏以备不时之需 Spring Cloud实战专栏:https://blog.csdn.net/superdangbo/category_9270827.html Python 实战专栏:https://blog.csdn.net/superdangbo/category_9271194.html Logback 详解专栏:https:/…

前端工具nvm实现node自由

node的自由之路 前言 大家使用vue框架开发的朋友可能会遇到首次运行公司项目环境的时候,会出现使用npm install命令安装依赖包的时候出现各种各样的问题,其中很重要的一个错误原因就是因为你的nodejs版本和当时搭建环境的版本不一致造成的。今天就来给…

file2Udp增量日志转出Udp简介

https://gitee.com/tianjingle/file2udp 很多时候服务产生的日志需要进行汇总,这种统一日志处理的方式有elb,而且很多日志组件也支持日志转出的能力。但是从广义上来说是定制化的,我们需要一个小工具实现tail -f的能力,将增量日志…

跨国企业如何选择安全靠谱的跨国传输文件软件?

随着全球化的不断发展,跨国企业之间的合作变得越来越频繁。而在这种合作中,如何安全、可靠地将文件传输给合作伙伴或客户,成为了跨国企业必须面对的问题。 然而,跨国文件传输并不是一件容易的事情,由于网络物理条件的…

万宾科技智能传感器EN100-C2有什么作用?

在日常生活中井盖是一种常见的城市设施,但井盖出现问题可能会对人们的生活造成什么影响呢?移位或老化的井盖可能会威胁人们的安全,同时也会影响城市生命线的正常运行。然而智能井盖的出现为解决这些问题提供了有效的应对方案。 WITBEE万宾智能…