欢迎来到尧图网

客户服务 关于我们

您的位置:首页 > 文旅 > 八卦 > docker使用笔记

docker使用笔记

2025/2/22 5:02:05 来源:https://blog.csdn.net/ld_long/article/details/145245375  浏览:    关键词:docker使用笔记

安装

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在一个一个尝试,直到找到一个能用的。

sudo vim  /etc/docker/daemon.json
{"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日 这些镜像地址可能会挂。

sudo systemctl daemon-reload		#重启daemon进程
sudo systemctl restart docker		#重启docker

下载镜像

从dockerhub上拉取

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

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

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

docker images  #查看本机的镜像

从镜像中构建容器

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

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

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

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常用命令

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  # 删除容器 

版权声明:

本网仅为发布的内容提供存储空间,不对发表、转载的内容提供任何形式的保证。凡本网注明“来源:XXX网络”的作品,均转载自其它媒体,著作权归作者所有,商业转载请联系作者获得授权,非商业转载请注明出处。

我们尊重并感谢每一位作者,均已注明文章来源和作者。如因作品内容、版权或其它问题,请及时与我们联系,联系邮箱:809451989@qq.com,投稿邮箱:809451989@qq.com

热搜词