安装
用的是腾讯云服务器,OS为CentOS8
首先,centos8有默认安装了 Podman,要先把它删除
dnf remove podman
yum erase podman buildah
更新 yum 插件
yum install -y yum-utils device-mapper-persistent-data lvm2
设置稳定的仓库(阿里云,一定要设置,不然很有可能会安装失败)
yum-config-manager --add-repo http://mirrors.aliyun.com/docker-ce/linux/centos/docker-ce.repo
安装
sudo yum install -y docker-ce docker-ce-cli containerd.io
配置加速
sudo mkdir -p /etc/docker
sudo tee /etc/docker/daemon.json <<-'EOF'
{
"registry-mirrors": ["https://82m9ar63.mirror.aliyuncs.com"],
"exec-opts": ["native.cgroupdriver=systemd"],
"log-driver": "json-file",
"log-opts": {
"max-size": "100m"
},
"storage-driver": "overlay2"
}
EOF
sudo systemctl daemon-reload
sudo systemctl restart docker
其中的镜像加速地址可以在自己的阿里云账号中的【容器镜像服务】-【镜像工具】-【镜像加速器】中查看自己的专属加速地址。
启动
sudo systemctl start docker
sudo systemctl enable docker //开机时自动启动docker
镜像基本命令
docker pull nginx #下载最新版
镜像名:版本名(标签)
docker pull nginx:1.20.1
docker pull redis #下载最新
docker pull redis:6.2.4 #指定版本
## 下载来的镜像都在本地
docker images #查看所有镜像
docker rmi 镜像名:版本号/镜像id
启动容器基本命令
docker run [OPTIONS] IMAGE [COMMAND] [ARG...]
【docker run 设置项 镜像名 】 镜像启动运行的命令(镜像里面默认有的,一般不会写)
# -d:后台运行
# --restart=always: 开机自启
docker run --name=mynginx -d --restart=always -p 88:80 nginx
# 查看正在运行的容器
docker ps
# 查看所有
docker ps -a
# 删除停止的容器
docker rm 容器id/名字
docker rm -f mynginx #强制删除正在运行中的
#停止容器
docker stop 容器id/名字
#再次启动
docker start 容器id/名字
#应用开机自启
docker update 容器id/名字 --restart=always
#查看docker容器日志
docker logs 容器名/容器ID
启动redis
docker run -v /data/redis/redis.conf:/etc/redis/redis.conf \
-v /data/redis/data:/data \
-d --name myredis \
-p 6379:6379 \
redis:latest redis-server /etc/redis/redis.conf
# redis-server /etc/redis/redis.conf:启动时执行的命令
- --restart=always
- --name:为容器指定一个名称
- -p:指定端口映射,格式:宿主端口:容器端口
- -v:挂载外部数据,与容器内部目录或文件形成映射,这样我们就不需要进入容器内部修改文件了
如果想配置目录的映射,如 docker run -v /myredis/conf:/etc/redis --name myredis001 redis redis-server /etc/redis/redis.conf
那就要确保本地目录的/myredis/conf有redis.conf文件,不然会启动失败。
- -d:后台运行容器
- redis:镜像名称
进入容器
docker exec -it 容器id /bin/bash
# 或者
docker exec -it 容器ID。/bin/sh
自定义镜像
如果我们对某些容器做了特定的修改,可以用该容器来构建一个镜像,这样我们就不用每次都重新配置容器了。
# docker commit [OPTIONS] CONTAINER [REPOSITORY[:TAG]]
# warson_redis:v1.0就是我们自定义的镜像名称及版本
docker commit -a "warson" -m "改了一些配置文件" 容器ID warson_redis:v1.0
打包镜像(离线安装镜像)
# 将镜像保存成压缩包
docker save -o abc.tar warson_redis:v1.0
# 别的机器加载这个镜像
docker load -i abc.tar
远程仓库
首先,我们要在自己的docker账户上创建仓库(类似GitHub的概念),然后就可以把我们自己镜像推送到自己的镜像仓库了。
在推送自己的镜像到docker仓库前,我们需要登陆自己的docker账号
# 登录到docker hub
docker login
docker logout(推送完成镜像后退出)
在docker网页创建好自己的仓库后,按照创建的仓库名来命名镜像,才能推送
# 这相当于再创建一个镜像new-repo:tagname,new-repo为docker仓库的路径
docker tag localimage:tagname new-repo:tagname
# 推送
docker push new-repo:tagname
example:
# 把旧镜像的名字,改成仓库要求的新版名字
docker tag warson_redis:v1.0 warsonlong/redis-test:v1.0
# 推送
docker push warsonlong/redis-test:v1.0
# 别的机器下载
docker pull docker push warsonlong/redis-test:v1.0
docker cp
example:(这个命令可以让我们不需进入容器内部去查看文件)
#把容器指定位置的东西复制出来 ,5eff66eec7e1为容器ID
docker cp 5eff66eec7e1:/etc/nginx/nginx.conf /data/conf/nginx.conf
#把外面的内容复制到容器里面
docker cp /data/conf/nginx.conf 5eff66eec7e1:/etc/nginx/nginx.conf
ubuntu安装docker
参考:docs.docker.com/engine/inst…
sudo apt-get update
sudo apt-get install ca-certificates curl gnupg
sudo install -m 0755 -d /etc/apt/keyrings
curl -fsSL https://download.docker.com/linux/ubuntu/gpg | sudo gpg --dearmor -o /etc/apt/keyrings/docker.gpg
sudo chmod a+r /etc/apt/keyrings/docker.gpg
echo \
"deb [arch="$(dpkg --print-architecture)" signed-by=/etc/apt/keyrings/docker.gpg] https://download.docker.com/linux/ubuntu \
"$(. /etc/os-release && echo "$VERSION_CODENAME")" stable" | \
sudo tee /etc/apt/sources.list.d/docker.list > /dev/null
sudo apt-get update
sudo apt-get install docker-ce docker-ce-cli containerd.io docker-buildx-plugin docker-compose-plugin
sudo docker run hello-world