docker学习基本使用教程

docker是一款用于开发部署和运行容器化平台,能将应用及其依赖打包成轻量级、可移植的容器,实现一次构建,随处运行。docker是cs架构程序(客户端和服务端),docker客户端向docker守护进程发送请求,docker守护进程返回请求结果 。docker守护进程管理着docker里面的容器,docker客户端可以是本地也可以是远程,通过docker客户端访问docker守护进程管理着docker容器。镜像是 docker生命周期中的构建或打包阶段,而容器则是启动或者执行阶段,容器基于镜像启动,一旦容器启动完成后,我们就可以登录到容器中安装自己需的软件或服务。

注册中心

docker用Registry(注册中心)来保存用户构建的镜像。Registry分为公共和私有两种,docker公司运营公共的Registry叫做docker hub 。用户可以在docker hub注册账号,分享并保存自己镜像(说明  在docker hub下载镜像 非常慢,可以自己构建 私有的registry),网址是https:hub.docker.com

docker 官方建议在ubuntu中安装,因为docker是基于ubuntu发布的,一般docker出现的问题ubuntu 中是最新更新或打补丁的,很多版本的centos中是不支持更新最新的一些补丁 包的。如果要在centos中使用,建议在centos7.x以上的版本中使用。低于这个版本需要安装其他很的环境并且docker很多的补丁不支持更新。

1 、docker安装

安装前先更新系统所有的包索引sudo apt-get update   和sudo apt-get update -y

1、安装必要依赖

安装允许apt通过 HTTPS 使用仓库的包:

sudo apt install -y apt-transport-https ca-certificates curl software-properties-common

2、卸载旧版本

若系统中已存在 Docker 的旧版本,需先将其卸载

sudo apt remove docker docker-engine docker.io containerd runc

测试过上面的命令删除不全,改成如下删除全部docker

sudo apt-get purge docker-ce docker-ce-cli containerd.io docker-compose-plugin

 这条命令会卸载 Docker 及其相关组件,并清除配置文件等信息。卸载完成后,可通过再次执行 docker - v 确认是否卸载成功。如果还存在残留文件,可手动检查并删除 /var/lib/docker/ 目录(该目录存储 Docker 的镜像、容器等数据 ):

sudo rm -rf /var/lib/docker/

3、添加 Docker 官方 GPG 密钥

curl -fsSL https://download.docker.com/linux/ubuntu/gpg | sudo gpg --dearmor -o /usr/share/keyrings/docker-archive-keyring.gpg

4、添加 Docker 官方仓库

echo "deb [arch=$(dpkg --print-architecture) signed-by=/usr/share/keyrings/docker-archive-keyring.gpg] https://download.docker.com/linux/ubuntu $(lsb_release -cs) stable" | sudo tee /etc/apt/sources.list.d/docker.list > /dev/null

 5、安装 Docker 引擎(安装docker)

更新apt包索引,然后安装最新版本的 Docker 引擎、containerd 和 Docker Compose:

sudo apt update
sudo apt install -y docker-ce docker-ce-cli containerd.io docker-compose-plugin

 安装操作和查看docker版本号

6、设置ustc的镜像 

 默认从国外下载的,比较慢或下载失败,现在设置为国内下载,设置ustc的镜像,加快下载速度。 如果没有目录就创建,有就打开并创建daemon.json文件并写入下面内容

mkdir -p /etc/docker

vi /etc/docker/daemon.json

daemon.json内容如下:

{         "registry-mirrors":["https://docker.mirrors.ustc.edu.cn"] }

7、权限问题造成无法使用docker错误提示及解决方法如下:

错误提示

Server:
permission denied while trying to connect to the Docker daemon socket at unix:///var/run/docker.sock: Get "http://%2Fvar%2Frun%2Fdocker.sock/v1.49/info": dial unix /var/run/docker.sock: connect: permission denied

解决方法:

提示 “permission denied” 表明权限不足 。docker info 命令用于获取 Docker 系统信息,执行时需与 Docker 守护进程通信,而 /var/run/docker.sock 是通信的套接字文件。当前用户没有该文件的访问权限,所以报错。解决方法如下:

  • 添加用户到 docker 组:执行sudo usermod -aG docker $USER ,将当前用户添加到docker组。添加后需重新登录或执行newgrp docker 使权限生效。
  • 修改文件权限(不推荐):使用sudo chmod 666 /var/run/docker.sock 赋予所有用户读写权限,但会降低安全性,仅适用于测试环境。

具体如下: 

以非 root 用户运行 Docker(可选但推荐)

默认情况下,运行 Docker 命令需要sudo权限。你可以创建一个名为docker的用户组,并将当前用户添加到该组中,从而避免每次都输入sudo

sudo groupadd docker
sudo usermod -aG docker $USER
newgrp docker  # 刷新当前会话的用户组

添加用户到docker组后,注销并重新登录,或者重启系统,之后就可以直接运行 Docker 命令了。 

 8、无法启动docker

 正如提示信息所说,执行 journalctl -xe 命令,系统会展示与 Docker 服务启动失败相关的详细日志内容。通过日志能明确具体是哪个依赖任务出问题,比如是某个服务未正常启动、文件加载失败还是权限问题等 ,进而针对性解决。

执行 journalctl -xe 命令,查看到失败相关详细 日志内容

ubuntu@VM-24-17-ubuntu:/etc/docker$ journalctl -xe
May 28 11:51:32 VM-24-17-ubuntu usermod[2061214]: add 'ubuntu' to group 'docker'
May 28 11:51:32 VM-24-17-ubuntu usermod[2061214]: add 'ubuntu' to shadow group 'docker'
May 28 11:51:32 VM-24-17-ubuntu sudo[2061212]: pam_unix(sudo:session): session closed for user root
May 28 11:51:41 VM-24-17-ubuntu newgrp[2061266]: user 'ubuntu' (login 'ubuntu' on pts/1) switched to group 'docker'
May 28 11:51:51 VM-24-17-ubuntu kernel: [UFW BLOCK] IN=eth0 OUT= MAC=52:54:00:6f:a7:68:fe:ee:0e:00:4d:44:08:00 SRC=123.160.221.175 DST=10.1.24>
May 28 11:52:01 VM-24-17-ubuntu CRON[2061397]: pam_unix(cron:session): session opened for user root(uid=0) by (uid=0)
May 28 11:52:01 VM-24-17-ubuntu CRON[2061398]: (root) CMD (flock -xn /tmp/stargate.lock -c '/usr/local/qcloud/stargate/admin/start.sh > /dev/n>
May 28 11:52:01 VM-24-17-ubuntu CRON[2061397]: pam_unix(cron:session): session closed for user root
May 28 11:52:12 VM-24-17-ubuntu kernel: [UFW BLOCK] IN=eth0 OUT= MAC=52:54:00:6f:a7:68:fe:ee:0e:00:4d:44:08:00 SRC=106.75.155.108 DST=10.1.24.>
May 28 11:52:20 VM-24-17-ubuntu sudo[2061503]:   ubuntu : TTY=pts/1 ; PWD=/etc/docker ; USER=root ; COMMAND=/usr/bin/systemctl start docker
May 28 11:52:20 VM-24-17-ubuntu sudo[2061503]: pam_unix(sudo:session): session opened for user root(uid=0) by ubuntu(uid=1000)
May 28 11:52:20 VM-24-17-ubuntu systemd[1]: docker.socket: Socket service docker.service already active, refusing.
May 28 11:52:20 VM-24-17-ubuntu systemd[1]: Failed to listen on Docker Socket for the API.
░░ Subject: A start job for unit docker.socket has failed
░░ Defined-By: systemd
░░ Support: http://www.ubuntu.com/support
░░ 
░░ A start job for unit docker.socket has finished with a failure.
░░ 
░░ The job identifier is 86592 and the job result is failed.
May 28 11:52:20 VM-24-17-ubuntu systemd[1]: Dependency failed for Docker Application Container Engine.
░░ Subject: A start job for unit docker.service has failed
░░ Defined-By: systemd
░░ Support: http://www.ubuntu.com/support
░░ 
░░ A start job for unit docker.service has finished with a failure.
░░ 
░░ The job identifier is 86516 and the job result is dependency.
May 28 11:52:20 VM-24-17-ubuntu systemd[1]: docker.service: Job docker.service/start failed with result 'dependency'.
May 28 11:52:20 VM-24-17-ubuntu sudo[2061503]: pam_unix(sudo:session): session closed for user root
May 28 11:52:29 VM-24-17-ubuntu kernel: [UFW BLOCK] IN=eth0 OUT= MAC=52:54:00:6f:a7:68:fe:ee:0e:00:4d:44:08:00 SRC=185.156.73.159 DST=10.1.24.>
May 28 11:52:49 VM-24-17-ubuntu kernel: [UFW BLOCK] IN=eth0 OUT= MAC=52:54:00:6f:a7:68:fe:ee:0e:00:4d:44:08:00 SRC=117.219.97.227 DST=10.1.24.>
May 28 11:53:01 VM-24-17-ubuntu CRON[2061700]: pam_unix(cron:session): session opened for user root(uid=0) by (uid=0)
May 28 11:53:01 VM-24-17-ubuntu CRON[2061701]: (root) CMD (flock -xn /tmp/stargate.lock -c '/usr/local/qcloud/stargate/admin/start.sh > /dev/n>
May 28 11:53:01 VM-24-17-ubuntu CRON[2061700]: pam_unix(cron:session): session closed for user root
May 28 11:53:13 VM-24-17-ubuntu kernel: [UFW BLOCK] IN=eth0 OUT= MAC=52:54:00:6f:a7:68:fe:ee:0e:00:4d:44:08:00 SRC=83.222.191.46 DST=10.1.24.1>
May 28 11:53:28 VM-24-17-ubuntu kernel: [UFW BLOCK] IN=eth0 OUT= MAC=52:54:00:6f:a7:68:fe:ee:0e:00:4d:44:08:00 SRC=111.7.96.132 DST=10.1.24.17>
May 28 11:53:52 VM-24-17-ubuntu kernel: [UFW BLOCK] IN=eth0 OUT= MAC=52:54:00:6f:a7:68:fe:ee:0e:00:4d:44:08:00 SRC=92.63.197.177 DST=10.1.24.1>
May 28 11:54:01 VM-24-17-ubuntu CRON[2062000]: pam_unix(cron:session): session opened for user root(uid=0) by (uid=0)
May 28 11:54:01 VM-24-17-ubuntu CRON[2062001]: (root) CMD (flock -xn /tmp/stargate.lock -c '/usr/local/qcloud/stargate/admin/start.sh > /dev/n>
May 28 11:54:01 VM-24-17-ubuntu CRON[2062000]: pam_unix(cron:session): session closed for user root
May 28 11:54:09 VM-24-17-ubuntu ke

如上截图信息错误的,解决方法就是删除完 docker,重新安装docker就完美解决了 

9、启动 Docker 服务

sudo systemctl start docker

 设置 Docker 开机自启:

sudo systemctl enable docker

 停止 Docker 服务

sudo systemctl stop docker

 重启 Docker 服务

sudo systemctl restart docker

查看docker运行状态 

sudo systemctl status docker

  • 状态标识:输出中明确显示 Active: active (running) ,这表明 Docker 服务处于活跃且正在运行的状态 。
  • 运行时间:有 since wed 2025-05-28 12:43:49 CST ,说明从该时间点起 Docker 服务就已处于运行状态 。
  • 主进程信息Main PID: 2129132 (dockerd) 表示 Docker 守护进程(dockerd )已正常启动并获取到了主进程 ID 。

检查看开机自启是否设置成功

systemctl list - enabled - units | grep docker 

如果出现 “Unknown command verb” 报错,大概率是你系统上的 systemctl 版本较旧,不支持这些命令用法。你可以尝试下面替代方法来判断 Docker 开机自启状态:

可使用这个查看systemctl list--enabled--units | grep docker 

你执行的命令报错 “Unknown command verb list--enabled--units” ,说明命令未被正确识别,无法据此判断 Docker 开机自启是否设置成功 。可能是系统的 systemctl 版本较老,不支持这种格式。建议按前面提到的替代方法,如查看 /lib/systemd/system/docker.service 文件中 Install 段配置 ,或检查 /etc/systemd/system/ 下是否有指向 docker.service 的软链接来确定。 

打开 vi /lib/systemd/system/docker.service 看到如下截图所示,是添加成功的

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

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

相关文章

万字详解RTR RTSP SDP RTCP

目录 1 RTSP1.1 RTSP基本简介1.2 RSTP架构1.3 重点内容分析 2 RTR2.1 RTR简介2.2 RTP 封装 H.2642.3 RTP 解封装 H.2642.4 RTP封装 AAC2.5 RTP解封装AAC 3 SDP3.1 基础概念3.2 SDP协议示例解析3.3 重点知识 4 RTCP4.1 RTCP基础概念4.2 重点 5 总结 1 RTSP 1.1 RTSP基本简介 一…

唯一原生适配鸿蒙电脑的远程控制应用,向日葵正式上线

近日,华为正式发布鸿蒙电脑新品,标志着HarmonyOS在PC端生态的进一步拓展。作为远程控制领域的先行者,贝锐科技旗下的向日葵远程控制软件也在第一时间完成了对鸿蒙电脑系统的原生适配,并已正式上线华为鸿蒙电脑应用市场&#xff0c…

vue2中,codemirror编辑器的使用

交互说明 在编辑器中输入{时&#xff0c;会自动弹出选项弹窗&#xff0c;然后可以选值插入。 代码 父组件 <variable-editorv-model"content":variables"variables"placeholder"请输入模板内容..."blur"handleBlur" />data…

Kafka自定义分区策略实战避坑指南

文章目录 概要代码示例小结 概要 kafka生产者发送消息默认根据总分区数和设置的key计算哈希取余数&#xff0c;key不变就默认存放在一个分区&#xff0c;没有key则随机数分区&#xff0c;明显默认的是最不好用的&#xff0c;那kafka也提供了一个轮询分区策略&#xff0c;我自己…

WPF 全屏显示实现(无标题栏按钮 + 自定义退出按钮)

WPF 全屏显示实现&#xff08;无标题栏按钮 自定义退出按钮&#xff09; 完整实现代码 MainWindow.xaml <Window x:Class"FullScreenApp.MainWindow"xmlns"http://schemas.microsoft.com/winfx/2006/xaml/presentation"xmlns:x"http://schemas…

sqli_labs第二十九/三十/三十一关——hpp注入

一&#xff1a;HTTP参数污染&#xff1a; hpp&#xff08;http parameter pollution)注入中&#xff0c;可以通过在hppt的请求中注入多个同名参数来绕过安全过滤 原理&#xff1a;php默认只取最后一个同名参数 比如在这一关里&#xff0c;可能对第一个id参数进行消毒处理&a…

【STM32】按键控制LED 光敏传感器控制蜂鸣器

&#x1f50e;【博主简介】&#x1f50e; &#x1f3c5;CSDN博客专家 &#x1f3c5;2021年博客之星物联网与嵌入式开发TOP5 &#x1f3c5;2022年博客之星物联网与嵌入式开发TOP4 &#x1f3c5;2021年2022年C站百大博主 &#x1f3c5;华为云开发…

华为OD机试真题——斗地主之顺子(2025B卷:100分)Java/python/JavaScript/C/C++/GO最佳实现

2025 B卷 100分 题型 本专栏内全部题目均提供Java、python、JavaScript、C、C++、GO六种语言的最佳实现方式; 并且每种语言均涵盖详细的问题分析、解题思路、代码实现、代码详解、3个测试用例以及综合分析; 本文收录于专栏:《2025华为OD真题目录+全流程解析+备考攻略+经验分…

Qt找不到windows API报错:error: LNK2019: 无法解析的外部符号 __imp_OpenClipboard

笔者在开发中出现的bug完整报错如下&#xff1a; spcm_ostools_win.obj:-1: error: LNK2019: 无法解析的外部符号 __imp_OpenClipboard&#xff0c;函数 "void __cdecl spcmdrv::vCopyToClipboard(char const *,unsigned __int64)" (?vCopyToClipboardspcmdrvYAXPE…

4.8.4 利用Spark SQL实现分组排行榜

在本次实战中&#xff0c;我们的目标是利用Spark SQL实现分组排行榜&#xff0c;特别是计算每个学生分数最高的前3个成绩。任务的原始数据由一组学生成绩组成&#xff0c;每个学生可能有多个成绩记录。我们首先将这些数据读入Spark DataFrame&#xff0c;然后按学生姓名分组&am…

[PyMySQL]

掌握pymysql对数据库实现增删改查数据库工具类封装,数据库操作应用场景数据库操作应用场景 校验测试数据 : 删除员工 :构造测试数据 : 测试数据使用一次就失效,不能重复使用 : 添加员工(is_delete)测试数据在展开测试前无法确定是否存在 : 查询,修改,删除员工操作步骤:!~~~~~~~…

cs224w课程学习笔记-第12课

cs224w课程学习笔记-第12课 知识图谱问答 前言一、问答类型分类二、路径查询(Path queries)2.1 直观查询方法2.2 TransE 扩展2.3 TransE 能力分析 三、连词查询(conjunctive queries)3.1 Query2box 原理1)、投影2)、交集查询&#xff08;AND 操作)3)、联合查询&#xff08;OR 操…

AI任务相关解决方案2-基于WOA-CNN-BIGRU-Transformer模型解决光纤通信中的非线性问题

文章目录 1. 项目背景与研究意义1.1 光纤通信中的非线性问题1.2 神经网络在光纤非线性补偿中的应用现状 2. 现有模型 CNN-BIGRU-attention 分析2.1 模型架构与工作原理2.2 模型性能评估与局限性 3. 新模型优化方案3.1 WOA算法原理与优势3.2 WOA-CNN-BIGRU-MHA模型构建3.3 WOA-C…

HTTP Accept简介

一、HTTP Accept是什么 HTTP协议是一个客户端和服务器之间进行通信的标准协议&#xff0c;它定义了发送请求和响应的格式。而HTTP Accept是HTTP协议中的一个HTTP头部&#xff0c;用于告诉服务器请求方所期望的响应格式。这些格式可以是媒体类型、字符集、语言等信息。 HTTP A…

39-居住证管理系统(小程序)

技术栈: springBootVueMysqlUni-app 功能点: 群众端 警方端 管理员端 群众端: 1.首页: 轮播图展示、公告信息列表 2.公告栏: 公告查看及评论 3.我的: 联系我们: 可在线咨询管理员问题 实时回复 居住证登记申请 回执单查看 领证信息查看 4.个人中心: 个人信息查看及修改…

鸿蒙OSUniApp 开发的滑动图片墙组件#三方框架 #Uniapp

UniApp 开发的滑动图片墙组件 前言 在移动应用中&#xff0c;图片墙是一种极具视觉冲击力的内容展示方式&#xff0c;广泛应用于相册、商品展示、社交分享等场景。一个优秀的滑动图片墙组件不仅要支持流畅的滑动浏览&#xff0c;还要兼容不同设备的分辨率和性能&#xff0c;尤…

碰一碰系统源码搭建==saas系统

搭建“碰一碰”系统&#xff08;通常指基于NFC或蓝牙的短距离交互功能&#xff09;的源码实现&#xff0c;需结合具体技术栈和功能需求。以下是关键步骤和示例代码&#xff1a; 技术选型 NFC模式&#xff1a;适用于Android/iOS设备的近场通信&#xff0c;需处理NDEF协议。蓝牙…

自动驾驶决策规划框架详解:从理论到实践

欢迎来到《自动驾驶决策规划框架详解:从理论到实践》的第二章。在本章中,我们将深入探讨自动驾驶系统中至关重要的“大脑”——决策规划模块。我们将从基本概念入手,逐步解析主流的决策规划框架,包括经典的路径速度解耦方法、工业界广泛应用的Apollo Planning框架、应对复杂…

服务器定时任务查看和编辑

在 Ubuntu 系统中&#xff0c;查看当前系统中已开启的定时任务主要有以下几种方式&#xff0c;分别针对不同类型的定时任务管理方式&#xff08;如 crontab、systemd timer 等&#xff09;&#xff1a; 查看服务器定时任务 一、查看用户级别的 Crontab 任务 每个用户都可以配…

小白的进阶之路系列之四----人工智能从初步到精通pytorch自定义数据集下

本篇涵盖的内容 在之前的文章中,我们已经讨论了如何获取数据,转换数据以及如何准备自定义数据集,本篇文章将涵盖更加深入的问题,希望通过详细的代码示例,帮助大家了解PyTorch自定义数据集是如何应对各种复杂实际情况中,数据处理的。 更加详细的,我们将讨论下面一些内容…