docker


linux上面docke安装:

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

自动化一件安装

docker --version

un使用这个指令进行验证是否成功安装docker,也可以使用pull helloworld来验证

docker pull hello-world
docker run hello-world

有的时候可能pull不成功,需要换一下国内源

编辑/etc/docker/daemon.json,可能没有这个文件,就直接vim创建就行

{
    "registry-mirrors": ["https://registry.docker-cn.com","http://hub-mirror.c.163.com"],
    "live-restore": true
}

然后重启docker

systemctl restart docker

添加用户至docker用户组,这样就可以不用每次都sudo了,docker的使用是需要docker权限的

# 添加docker用户组,一般已存在,不需要执行
sudo groupadd docker
# 将登陆用户加入到docker用户组中
sudo gpasswd -a $USER docker
# 添加读写权限
chmod o+rw /var/run/docker.sock
# 更新用户组
newgrp docker
# 测试docker命令是否可以使用sudo正常使用
docker version

也可以直接

usermod -aG docker hj

docker 拉取ubuntu镜像

首先去官网找对应的版本

https://hub.docker.com/_/ubuntu/tags

然后运行pull

docker pull ubuntu:jammy

运行镜像

docker run -itd --name ubuntu-test ubuntu:jammy

进入一个容器

docker exec -it 容器名或容器id /bin/bash

删除已经运行的容器

docker container rm 容器名或容器id

创建容器

docker run [option] 镜像吗 [向容器中传入的命令]

常用参数

-i 表示以“交互模式”运行容器
-t 表示容器启动后会进入其命令行。加入这两个参数后,容器创建就能登录进去。即 分配一个伪终端。
--name 为创建的容器命名
-v 表示目录映射关系(前者是宿主机目录,后者是映射到宿主机上的目录,即 宿主机目录:容器中目录),可以使 用多个-v 做多个目录或文件映射。注意:最好做目录映射,在宿主机上做修改,然后 共享到容器上。
-d 在run后面加上-d参数,则会创建一个守护式容器在后台运行(这样创建容器后不 会自动登录容器,如果只加-i -t 两个参数,创建后就会自动进去容器)-p 表示端口映射,前者是宿主机端口,后者是容器内的映射端口。可以使用多个-p 做多个端口映射
-e 为容器设置环境变量
--network=host 表示将主机的网络环境映射到容器中,容器的网络与主机相同

创建一个交互式容器,并命名为myUbuntu

docker run -it --name=myUbuntu /bin/bash

在容器中可以随意执行linux命令,就是一个ubuntu的环境,当执行exit命令退出时,该容器也随之停止。

创建一个守护式容器

docker run -itd --name=myUbuntu /bin/bash

创建一个守护式容器:如果对于一个需要长期运行的容器来说,我们可以创建一个守护式容器。在容器内部exit退出时,容器也不会停止。

进入已经运行的容器

docker run -it --name=myUbuntu /bin/bash

查看容器

列出本机正在运行的容器

docker container ls

列出本机所有容器,包括已经终止运行的

docker container ls --all

停止容器

docker container stop 容器名或容器id

启动一个已经停止的容器

docker container start 容器名或容器id

kill掉一个已经在运行的容器

docker container kill 容器名或容器y

删除容器

docker container rm 容器名或容器id

将容器保存为镜像

docker commit 容器名 镜像名

镜像备份与迁移

docker save -o 保存的文件名 镜像名

对方拿到镜像文件后,将镜像文件加载到bendi

docker load -i ./centos.tar

删除镜像:

docker rmi 镜像名或者镜像id
docker image rm 

所有容器都会和宿主机共享同一个内核,但它们在操作系统层面相互隔离,相当于在同一个内核上运行多个隔离的用户空间。

所以uname -r的结果是一样的,乐。


文章作者: hugo
版权声明: 本博客所有文章除特別声明外,均采用 CC BY 4.0 许可协议。转载请注明来源 hugo !
  目录