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
的结果是一样的,乐。