隔离
,通过隔离机制,既可以保障每个集装箱里面的东西是互不影响的,也可以将服务器的资源压榨到最大程度。下图展示了没有docker的部署上线和有docker之后的部署上线差异:
VM与docker的区别:
官方安装步骤: https://docs.docker.com/get-started/overview/
sudo yum remove docker \
docker-client \
docker-client-latest \
docker-common \
docker-latest \
docker-latest-logrotate \
docker-logrotate \
docker-engine
sudo yum install -y yum-utilssudo yum-config-manager \
--add-repo \
https://download.docker.com/linux/centos/docker-ce.repo
sudo yum install docker-ce docker-ce-cli containerd.io
sudo systemctl start docker
sh sudo docker run hello-world
docker命令大全可以参考如下图所示:
# 查看下载的镜像列表
docker images
# 重新加载docker
sudo systemctl daemon-reload
# 重启docker
sudo systemctl restart docker
# 配置docker国内镜像地址(加快镜像下载速度)
sudo mkdir -p /etc/docker
sudo tee /etc/docker/daemon.json <<-'EOF'
{"registry-mirrors":["https://aa25jngun.mirror.aliyuncs.com"]
}
EOF
sudo systemctl daemon-reload
sudo systemctl restart docker
java入门与实战,官网文档链接:https://docs.docker.com/reference/
# 查看版本
docker version
# 显示docker的信息
docker info
# 帮助命令
docker [命令] --help
## 查看运行中的容器
docker ps
# 查看容器的top信息
docker top [容器id]
# 查看容器元数据信息
docker inspect [容器id]
# 进入容器
docker attach [容器id]
# 将主机重的文件拷贝到容器
docker cp SRC_PATH [容器id]:DEST_PATH
# 将容器中的文件拷贝到主机中
docker cp [容器id]:SRC_PATH DEST_PATH
# 查看容器状态
docker status
# 列出本机所有镜像
docker images
# 搜索镜像(可以在docker hub上进行搜索 <https://hub.docker.com/>)
docker search rabbitmq
# 下载最新镜像
docker pull rabbitmq
# 下载指定版本镜像
docker pull rabbitmq:3.8.11
# 删除镜像
docker rmi -f [IMAGE ID]
docker rmi -f [IMAGE ID] [IMAGE ID] [IMAGE ID]
docker rmi -f ${docker images -aq}
# 运行容器
docker run [可选参数] image
# 查询容器列表
docker ps [OPSTIONS]
# 退出容器
exit、CTRL+D、CTRL+P+Q
# 删除容器
docker rm [OPTIONS] CONTAINER [CONTAINER...]
# 启动&重启容器
docker start [容器id]
docker restart [容器id]
# 停止正在运行的容器
docker stop [容器id]
# 强制停止当前容器
docker kill [容器id]
镜像是一种轻量级、可执行的独立软件包。保护代码、运行时、库、环境变量和配置文件。所有应用直接打包docker镜像就可以直接跑起来。
提交容器,成为一个新的副本
docker commit [OPTIONS] CONTAINER [REPOSITORY[:TAG]]
如前面介绍的,docker是将应用和环境统一进行了打包。如果删除容器的话,数据也会被同时删除,那么,如果我们有数据持久化需求,或者容器之间数据共享的需求,则就需要用到容器数据卷
我们发现, 删除了museCentOS03之后, museCentOS02里的muse01目录下依然有a.txt文件, 这就表明了,museCentOS01~museCentOS03 这三个容器中a.txt文件是互相同步复制备份的。 而并不是同享了某个目录, 大家都去查看一个备份。
执行挂载(把本机路径/home/muse/test, 挂在到centos容器的/bin/bash目录下)
docker run -it -v /home/muse/test:/home centos /bin/bash
# 查看挂载内容(上面run的容器id就是da6268d8ac0a)
docker inspect da6268d8ac0a
从入门到?匿名挂载:
通过-v 指定容器内路径
docker run -d -P --name nginx1 -v :/etc/nginx nginx
具名挂载(常用方式):
通过-v 卷名:容器内路径, 指定具名挂载
docker run -d -P --name nginx2 -v nginx2:/etc/nginx nginx
查看挂载列表
docker volume ls
查看挂载信息
docker volume inspect [VOLUME]
FROM centos
VOLUME ["muse01","muse02"]
CMD echo "------finish------"
CMD /bin/bash
docker build -f /home/{项目根目录}/dockerfile -t muse/centos:1.0
docker run -it eb78333356a6 /bin/bash
版权声明:本站所有资料均为网友推荐收集整理而来,仅供学习和研究交流使用。
工作时间:8:00-18:00
客服电话
电子邮件
admin@qq.com
扫码二维码
获取最新动态