记录下Linux
下docker
的安装与使用
Centos 7 + Docker 23.0.1
https://docs.docker.com/engine/install/centos
sudo yum remove docker \
docker-client \
docker-client-latest \
docker-common \
docker-latest \
docker-latest-logrotate \
docker-logrotate \
docker-engine
utils
工具包sudo yum install -y yum-utils
docker
远程库sudo yum-config-manager \
--add-repo \
https://download.docker.com/linux/centos/docker-ce.repo
docker
sudo yum install docker-ce docker-ce-cli containerd.io docker-buildx-plugin docker-compose-plugin
docker
sudo systemctl start docker
docker
版本docker -v
docker images
docker
自启动systemctl enable docker
docker
systemctl restart docker
阿里云 -》 容器镜像服务 -》 镜像工具 -》 镜像加速器
https://cr.console.aliyun.com/cn-zhangjiakou/instances/mirrors
配置镜像加速器
sudo mkdir -p /etc/docker
sudo tee /etc/docker/daemon.json <<-'EOF'
{
"registry-mirrors": ["https://kc83wno8.mirror.aliyuncs.com"]
}
EOF
sudo systemctl daemon-reload
sudo systemctl restart docker
Docker
仓库地址https://hub.docker.com/
docker diff redis
A
: 添加的文件或目录(ADD
)D
:删除的文件或目录(DELETE
)C
:更改的文件或目录(CHANGE
)redis
docker stop redis
docker commit -a coisini -m "init new another redis" redis redis:myRedis
// 释义
-a: 作者信息
-c: 可以使用dockerfile提交
-m: 提交的备注信息
-p: 提交的时候暂停容器
commit
操作,当前的提交会覆盖上一个镜像,上一个提交的commit
会变成none
(无用镜像)docker image prune
tag
标签(两个镜像的id
是一样的,只是对镜像做了标记处理不占硬盘空间)docker tag redis:myRedis redis:myRedis-1.0
docker run -p 8379:6379 --name redis-1.0 -d redis:myRedis-1.0
tar
文件docker export -o myRedis.tar myRedis
scp /home/redis6/myRedis.tar [email protected]:/home/redis6/
tar
文件为镜像docker import myRedis.tar redis:myRedis
command
参数command
参数, docker ps
查看到的是缩略的,通过下面的命令查看查看完整的command
docker ps --no-trunc
docker run -p 6379:6379 --name redis -d redis:myRedis docker-entrypoint.sh redis-server /etc/redis/redis.conf
tar
文件docker save -o myRedis.tar redis[:tag]
scp /home/redis6/myRedis.tar [email protected]:/home/redis6/
docker load -i myRedis.tar
docker run -p 6379:6379 --name myRedis -d redis:myRedis
docker hub
docker login
tag
和远程仓库的保持一致docker tag redis:myRedis maggieq/redis:myRedis
Docker
镜像到云仓库docker push maggieq/redis:myRedis
docker hub
docker logout
save/load 适用于离线的生产模式
push 适用于线上环境、云模式
Portainer
是一个轻量级的管理UI
,它由一个可以在任何Docker
引擎上运行的单一容器组成(可以部署为Linux
容器或Windows
本地容器,也支持其他平台),Portainer
可以管理所有的Docker
资源(容器、镜像、卷、网络等等),它与独立的Docker
引擎和Docker Swarm
模式兼容portainer
镜像docker pull portainer/portainer-ce
docker volume create portainer_data
docker run -p 8000:8000 -p 9000:9000 \
--name=portainer \
--restart=always \
-v /var/run/docker.sock:/var/run/docker.sock \
-v portainer_data:/data \
-d portainer/portainer-ce
http://[docker所在服务ip]:9000