程序员背锅救星-docker
wptr33 2024-11-22 22:00 24 浏览
程序员背锅救星-docker
一、前言
本篇内容带大家走进docker的世界,从基础到实战,从头到尾讲述docker的概念和使用docker进行环境部署等等一系列“骚”操作~
二、docker概念
Docker 是一个开源的应用容器引擎,让开发者可以打包他们的应用以及依赖包到一个可移植的容器中,然后发布到任何流行的Linux机器或Windows 机器上,也可以实现虚拟化,容器是完全使用沙箱机制,相互之间不会有任何接口。
就如上述你看到的图片一样,容器的设计理念由码头上的集装箱而来,通过集装箱的标准化、相互隔离实现软件系统依赖的打包与运行隔离。
三、docker的作用
说到这个作用,我先引入一个话题,就是大家在工作中应该遇到过类似的现象,我们在开发环境中测试自己的代码好好的,但是一到测试人员手里,就是自己的孩子认生一样,立马哇哇大哭,搞得我们开发成了背锅侠,而测试最长说的一句话就是:“你这代码有问题呀~”,估计大家的心情都一样,一万只caoni马奔腾而过;
最后检查,竟是环境出现了问题~~~
“他来了他来了”~~docker作为一款解救开发人员的神器出现了,我们可以把开发环境部署好,直接放在容器中,然后测试拿到这个容器就可以直接使用了,真的是“你好,我好,大家好!”
所以,容器的作用可以分为这么几部分:
- 提供一次性的环境。就比如我们上述描述的场景;
- 提供弹性的云服务。因为 Docker 容器可以随开随关,很适合动态扩容和缩容;
- 组建微服务架构。通过多个容器,一台机器可以跑多个服务,因此在本机就可以模拟出微服务架构。
四、docker中最重要的三要素
这里我们可以使用虚拟机的方式解释这三要素;
Docker镜像就好比我们要安装linux虚拟机,我们需要centos镜像,VM软件等等;
镜像
Docker镜像(Image)类似于虚拟机的镜像,可以将他理解为一个面向Docker引擎的只读模板,包含了文件系统。
这里我们可以看到的是,安装linux虚拟机,需要centos的镜像,这里的镜像和我们虚拟机中的镜像可以想象成一种东西;
当我们装了redis,这个就是redis镜像;
镜像是创建Docker容器的基础,通过版本管理和增量的文件系统,我们可以从仓库中下载一个已经做好的镜像,并通过命令直接使用。
仓库
Docker仓库(Repository)是Docker集中存放镜像文件的场所。
这种很类似阿里云镜像库,存放着各种镜像,也很类似于github,存放着各种各样的代码,我们需要就可以去取;
每个仓库集中存放某一类镜像,往往包括多个镜像文件,通过不同的标签(tag)来进行区分。例如存放centos操作系统镜像的仓库,称为centos仓库,其中可能包括centos6和centos7等不同版本的镜像。
Docker仓库分为公开仓库(Public)和私有仓库(Private)两种形式,最大的公开仓库是Docker Hub,存放了数量庞大的镜像;
一般我们自己部署设置的镜像库,会存放在私有仓库进行内存共享,更改和下载以及发布操作;
容器
容器是用镜像创建的运行实例。
每个容器都可以被启动,开始,停止,删除,同时容器之间相互隔离,保证应用运行期间的安全。
这就好比我们在VM中安装的虚拟机,我们可以使用一个镜像创建不同的实例,比如centos1、centos2等等,每个虚拟机互不影响,单独运行;
五、基本命令
镜像相关
关于镜像相关的命令,用得最多的就是拉、删、查、找、传镜像
- 拉取镜像docker pull <image>
指定标签下载某镜像
docker pull [:TAG]
比如我们拉取centos7的镜像docker pull centos7 - 查看镜像列出本地主机上的镜像
docker images
REPOSITORY:表示镜像的仓库源 TAG:镜像的标签 IMAGE ID:镜像ID CREATED:镜像创建时间 SIZE:镜像大小 - 搜索镜像docker search <image>
NAME: 镜像仓库源的名称 DESCRIPTION: 镜像的描述 OFFICIAL: 是否 docker 官方发布 stars: 类似 Github 里面的 star,表示点赞、喜欢的意思。AUTOMATED: 自动构建。 - 删除镜像docker rmi <image ID>
- 上传镜像docker push NAME[:TAG]
容器相关
- 创建容器docker start <container_name | container_id>
- 创建并启动容器docker run -it <container_name | container_id> /bin/bash
一般我们会使用:docker run -itd --name centos-test centos:centos7
说明: - -it 会进入容器的终端
- -d后台运行
- centos-test 容器名以centos-test命令,不指定会随机去一个字符串;
- centos:centos7镜像名
- 守护(后台)运行docker run -d <container_name | container_id>
- 查看容器信息docker ps [-a -q]
- 终止容器docker stop <container_name | container_id>
- 启动容器docker start <container_name | container_id>
- 重启容器docker restart <container_name | container_id>
- 进入容器docker exec -it <container_name | container_id> /bin/bash
- 删除容器docker rm [-f] <container_name | container_id>
六、实践
接下来来,我们一步一步操作docker运行centos7:
拉取centos7镜像
命令:docker pull centos:centos7
创建并启动centos容器
命令:docker run -itd --name centos-test centos:centos7
查看容器运行情况
命令:docker ps
进入容器操作
七、总结
以上就是我们操作容器全部的基础知识和操作过程,掌握上面的基础,我们可以初步拉取镜像,创建容器并且使用,后面我将为大家介绍容器的制作,制作我们自己的容器,这样才达到开发人员学习容器最终的目的,我们下期见 -《镜像制作大法》。
往期推荐
相关推荐
- 高性能并发队列Disruptor使用详解
-
基本概念Disruptor是一个高性能的异步处理框架,是一个轻量的Java消息服务JMS,能够在无锁的情况下实现队列的并发操作Disruptor使用环形数组实现了类似队列的功能,并且是一个有界队列....
- Disruptor一个高性能队列_java高性能队列
-
Disruptor一个高性能队列前言说到队列比较熟悉的可能是ArrayBlockingQueue、LinkedBlockingQueue这两个有界队列,大多应用在线程池中使用能保证线程安全,但其安全性...
- 谈谈防御性编程_防御性策略
-
防御性编程对于程序员来说是一种良好的代码习惯,是为了保护自己的程序在不可未知的异常下,避免带来更大的破坏性崩溃,使得程序在错误发生时,依然能够云淡风轻的处理,但很多程序员入行很多年,写出的代码依然都是...
- 有人敲门,开水开了,电话响了,孩子哭了,你先顾谁?
-
前言哎呀,这种情况你肯定遇到过吧!正在家里忙活着,突然——咚咚咚有人敲门,咕噜咕噜开水开了,铃铃铃电话响了,哇哇哇孩子又哭了...我去,四件事一起来,人都懵了!你说先搞哪个?其实这跟我们写Java多线...
- 面试官:线程池如何按照core、max、queue的执行顺序去执行?
-
前言这是一个真实的面试题。前几天一个朋友在群里分享了他刚刚面试候选者时问的问题:"线程池如何按照core、max、queue的执行循序去执行?"。我们都知道线程池中代码执行顺序是:co...
- 深入剖析 Java 中线程池的多种实现方式
-
在当今高度并发的互联网软件开发领域,高效地管理和利用线程资源是提升程序性能的关键。Java作为一种广泛应用于后端开发的编程语言,为我们提供了丰富的线程池实现方式。今天,就让我们深入探讨Java中...
- 并发编程之《彻底搞懂Java线程》_java多线程并发解决方案详解
-
目录引言一、核心概念:线程是什么?...
- Redis怎么实现延时消息_redis实现延时任务
-
一句话总结Redis可通过有序集合(ZSET)实现延时消息:将消息作为value,到期时间戳作为score存入ZSET。消费者轮询用ZRANGEBYSCORE获取到期消息,配合Lua脚本保证原子性获取...
- CompletableFuture真的用对了吗?盘点它最容易被误用的5个场景
-
在Java并发编程中,CompletableFuture是处理异步任务的利器,但不少开发者在使用时踩过这些坑——线上服务突然雪崩、异常悄无声息消失、接口响应时间翻倍……本文结合真实案例,拆解5个最容易...
- 接口性能优化技巧,有点硬_接口性能瓶颈
-
背景我负责的系统到2021年初完成了功能上的建设,开始进入到推广阶段。随着推广的逐步深入,收到了很多好评的同时也收到了很多对性能的吐槽。刚刚收到吐槽的时候,我们的心情是这样的:...
- 禁止使用这5个Java类,每一个背后都有一段"血泪史"
-
某电商平台的支付系统突然报警:大量订单状态异常。排查日志发现,同一笔订单被重复支付了三次。事后复盘显示,罪魁祸首竟是一行看似无害的SimpleDateFormat代码。在Java开发中,这类因使用不安...
- 无锁队列Disruptor原理解析_无锁队列实现原理
-
队列比较队列...
- Java并发队列与容器_java 并发队列
-
【前言:无论是大数据从业人员还是Java从业人员,掌握Java高并发和多线程是必备技能之一。本文主要阐述Java并发包下的阻塞队列和并发容器,其实研读过大数据相关技术如Spark、Storm等源码的,...
- 线程池工具及拒绝策略的使用_线程池处理策略
-
线程池的拒绝策略若线程池中的核心线程数被用完且阻塞队列已排满,则此时线程池的资源已耗尽,线程池将没有足够的线程资源执行新的任务。为了保证操作系统的安全,线程池将通过拒绝策略处理新添加的线程任务。...
- 【面试题精讲】ArrayBlockingQueue 和 LinkedBlockingQueue 区别?
-
有的时候博客内容会有变动,首发博客是最新的,其他博客地址可能会未同步,认准...
- 一周热门
-
-
C# 13 和 .NET 9 全知道 :13 使用 ASP.NET Core 构建网站 (1)
-
程序员的开源月刊《HelloGitHub》第 71 期
-
详细介绍一下Redis的Watch机制,可以利用Watch机制来做什么?
-
假如有100W个用户抢一张票,除了负载均衡办法,怎么支持高并发?
-
如何将AI助手接入微信(打开ai手机助手)
-
Java面试必考问题:什么是乐观锁与悲观锁
-
SparkSQL——DataFrame的创建与使用
-
redission YYDS spring boot redission 使用
-
一文带你了解Redis与Memcached? redis与memcached的区别
-
如何利用Redis进行事务处理呢? 如何利用redis进行事务处理呢英文
-
- 最近发表
- 标签列表
-
- git pull (33)
- git fetch (35)
- mysql insert (35)
- mysql distinct (37)
- concat_ws (36)
- java continue (36)
- jenkins官网 (37)
- mysql 子查询 (37)
- python元组 (33)
- mybatis 分页 (35)
- vba split (37)
- redis watch (34)
- python list sort (37)
- nvarchar2 (34)
- mysql not null (36)
- hmset (35)
- python telnet (35)
- python readlines() 方法 (36)
- munmap (35)
- docker network create (35)
- redis 集合 (37)
- python sftp (37)
- setpriority (34)
- c语言 switch (34)
- git commit (34)