docker使用笔记

安装

bash 复制代码
sudo apt update  #更新apt的软件列表
sudo apt-get install ca-certificates curl gnupg lsb-release software-properties-common #安装 安装docker时需要的工具,如果没有这些工具,下面的一些命令会执行失败
curl -fsSL https://download.docker.com/linux/ubuntu/gpg | sudo apt-key add -  # 添加Docker官方GPG密钥 这个是供apt用来验证docker的安装包没有被篡改的。
sudo add-apt-repository "deb [arch=amd64] https://download.docker.com/linux/ubuntu $(lsb_release -cs) stable"  #指定apt从哪里获取docker的安装包
sudo apt update  #再次更新apt的软件列表,因为上两条命令需要更新软件列表才会生效
sudo apt-get install docker-ce #这一行才是安装docker,前面都是铺垫
sudo usermod -aG docker $USER #把当前用户添加为docker用户组,这样当前用户使用docker时就不需要sudo了
sudo systemctl enable docker #设置启动项
sudo systemctl start docker #启动docker

使用

设置镜像源

在没有科学上网的情况下,我们是不能访问不了dockerhub的。这时候就需要国内镜像源。下面是设置国内镜像 源的方式 。

注意,下面列的镜像源不一定是每个 都能用的,有些可能已经挂了。设置好镜像源后,pull 可能要等好久好久,因为docker在一个一个尝试,直到找到一个能用的。

bash 复制代码
sudo vim  /etc/docker/daemon.json
bash 复制代码
{
    "registry-mirrors": [
	    "https://docker.registry.cyou",
	    "https://docker-cf.registry.cyou",
	    "https://dockercf.jsdelivr.fyi",
	    "https://docker.jsdelivr.fyi",
	    "https://dockertest.jsdelivr.fyi",
	    "https://mirror.aliyuncs.com",
	    "https://dockerproxy.com",
	    "https://mirror.baidubce.com",
	    "https://docker.m.daocloud.io",
	    "https://docker.nju.edu.cn",
	    "https://docker.mirrors.sjtug.sjtu.edu.cn",
	    "https://docker.mirrors.ustc.edu.cn",
	    "https://mirror.iscas.ac.cn",
	    "https://docker.rainbond.cc"
	  ]
}

更新至2025年1月19日 这些镜像地址可能会挂。

bash 复制代码
sudo systemctl daemon-reload		#重启daemon进程
sudo systemctl restart docker		#重启docker

下载镜像

从dockerhub上拉取

从dockerhub上拉取公开镜像不需要登录。如果从其他docker镜像提供商下载,需要先docker login xxx才能下载。

bash 复制代码
docker pull ubuntu:22.04   #从dockerhub或者镜像源中拉取标签为22.04的ubuntu镜像。

这里可能需要等很长一段时间才有反应,原因是它要依次访问镜像源,直到找到一个可用的镜像源。

bash 复制代码
docker images  #查看本机的镜像

从镜像中构建容器

镜像是只读的,可以根据这个镜像构建一个容器,容器才是一个可以运行的环境。

bash 复制代码
docker run [选项] 镜像名[:标签] [创建后执行的第一个命令]

例如

#以ubuntu:22.04为镜像创建一个名为ubuntu2204的容器,这个容器的/app目录与宿主当前目录相关联。创建后在容器内启动一个终端(-t的效果)并在这个终端上运行/bin/bash。并进入交互模式(-i的效果),使得宿主可以控制容器内。将容器内的80端口映射到宿主的8080端口

bash 复制代码
docker run --name ubuntu2204 -it -v  .:/app ubuntu:22.04 -p 8080:80 /bin/bash 

常用的选项还有

-d: 指定容器应该在后台运行。

-it: 让容器能够与终端进行交互。

--name: 指定容器的名称。

-p: 将容器端口映射到主机上的端口。 -p host_port:container_port

-v: 指定卷并将其挂载到容器中。 -v host_path:container_path

-u, --user string

docker常用命令

bash 复制代码
docker search 镜像名   #联网搜索镜像是否存在
docker images  #查看本机镜像
docker rmi 镜像名/镜像id  #删除镜像
docker ps -a    # 查看本机所有容器
docker run --name ubuntu2204 -it ubuntu:22.04 /bin/bash #以ubuntu:22.04为镜像创建一个名为ubuntu2204的容器,创建后在容器内启动一个终端(-t的效果)并在这个终端上运行/bin/bash。并进入交互模式(-i的效果)。 
docker start 容器名/容器id  #启动容器
docker attach 容器名/容器id #附加到容器上。注意,所有附加到同一个容器内的终端互相影响。大家控制的是容器内同一个终端(pts)。
docker exec -it ubuntu2204 /bin/bash #在容器内创建一个新终端。和其他终端互不影响。
ctrl + p + q   #离开容器,但是容器不会停止。但是,如果当前的终端不是主终端(第一个终端)使用这种方式离开后,是无法回到这个终端的(或者说我目前没找到回去的方法)。然而,这个终端是一直在运行的,这就是一个泄露,需要手动ps -aux 找到这个终端然后kill掉。
docker remove 容器名/容器id  # 删除容器 
相关推荐
猹叉叉(学习版)16 小时前
【系统分析师_知识点整理】 3.数据库系统
数据库·笔记·软考·系统分析师
李子琪。16 小时前
攀山的人
经验分享·笔记·百度·新浪微博
2501_9269783317 小时前
物理学原理和人工智能领域的底层一致性
人工智能·经验分享·笔记·ai写作
努力的lpp17 小时前
2024小迪安全课程第三节复习笔记
笔记·安全
江畔何人初17 小时前
Docker、containerd、CRI、shim 之间的关系
运维·docker·云原生·容器·kubernetes
冥王丁B17 小时前
第31章 Prompt 与聊天模型笔记
笔记·python·prompt
左左右右左右摇晃17 小时前
Java笔记——包装类(自动拆装箱)
java·笔记·python
杨浦老苏17 小时前
在线视频播放器YT-DLP Web Player
docker·工具·群晖·下载·多媒体
Yeh20205817 小时前
MySQL笔记二
笔记
ALex_zry18 小时前
Docker Compose 配置文件完全指南:从基础到生产级安全实践
服务器·安全·docker