Docker 从入门到跑路【3】-服务编排Compose_私有仓库_虚拟机
2020-05-07 04:24
113 查看
1 服务编排
微服务架构的应用系统中一般包含若干个微服务,每个微服务一般都会部署多个实例,如果每个微服务都要手动启停,维护的工作量会很大。
- 要从Dockerfile build image 或者去dockerhub拉取image
- 要创建多个container
- 要管理这些container(启动停止删除)
【服务编排】:按照一定的业务规则批量管理容器
1.1 Docker Compose
Docker Compose是一个编排多容器分布式部署的工具,提供命令集管理容器化应用的完整开发周期,包括服务构建,启动和停止。使用步骤:
1.利用 Dockerfile 定义运行环境镜像
2.使用 docker-compose.yml 定义组成应用的各服务
3.运行 docker-compose up 启动应用
1.2 安装Docker Compose
# Compose目前已经完全支持Linux、Mac OS和Windows,在我们安装Compose之前,需要先安装Docker。下面我 们以编译好的二进制包方式安装在Linux系统中。 curl -L https://github.com/docker/compose/releases/download/1.22.0/docker-compose-`uname -s`-`uname -m` -o /usr/local/bin/docker-compose # 设置文件可执行权限 chmod +x /usr/local/bin/docker-compose # 查看版本信息 docker-compose -version
1.3 卸载Docker Compose
# 二进制包方式安装的,删除二进制文件即可 rm /usr/local/bin/docker-compose
1.4 使用docker compose编排nginx+springboot项目
- 创建docker-compose目录
mkdir ~/docker-compose cd ~/docker-compose
- 编写 docker-compose.yml 文件
vim docker-compose.yml
version: '3' services: nginx: image: nginx ports: - 80:80 links: - app volumes: - ./nginx/conf.d:/etc/nginx/conf.d app: image: app expose: - "8080"
- 创建./nginx/conf.d目录
mkdir -p ./nginx/conf.d
- 在./nginx/conf.d目录下 编写itheima.conf文件
server { listen 80; access_log off; location / { proxy_pass http://app:8080; } }
- 在~/docker-compose 目录下 使用docker-compose 启动容器
docker-compose up
- 测试访问
http://192.168.149.135/hello
2 Docker 私有仓库
Docker官方的Docker hub(https://hub.docker.com)是一个用于管理公共镜像的仓库,我们可以从上面拉取镜像 到本地,也可以把我们自己的镜像推送上去。但是,有时候我们的服务器无法访问互联网,或者你不希望将自己的镜 像放到公网当中,那么我们就需要搭建自己的私有仓库来存储和管理自己的镜像。
2.1 私有仓库搭建
私有仓库也是一个镜像(私有仓库服务器与当前使用的服务器不在一块,不然就丧失了价值 =。=)
# 1、拉取私有仓库镜像 docker pull registry # 2、启动私有仓库容器 docker run -id --name=registry -p 5000:5000 registry # 3、打开浏览器 输入地址http://私有仓库服务器ip:5000/v2/_catalog,看到{"repositories":[]} 表示私有仓库 搭建成功 # 4、修改daemon.json vim /etc/docker/daemon.json # 在上述文件中添加一个key,保存退出。此步用于让 docker 信任私有仓库地址;注意将私有仓库服务器ip修改为自己私有仓库服务器真实ip {"insecure-registries":["私有仓库服务器ip:5000"]} # 5、重启docker 服务 systemctl restart docker docker start registry
2.2 将镜像上传至私有仓库
# 1、标记镜像为私有仓库的镜像 docker tag centos:7 私有仓库服务器IP:5000/centos:7 # 2、上传标记的镜像 docker push 私有仓库服务器IP:5000/centos:7
2.3 从私有仓库拉取镜像
#拉取镜像 docker pull 私有仓库服务器ip:5000/centos:7
3 Docker与虚拟机
容器就是将软件打包成标准化单元,以用于开发、交付和部署。
- 容器镜像是轻量的、可执行的独立软件包 ,包含软件运行所需的所有内容:代码、运行时环境、系统工具、系统库和设置。
- 容器化软件在任何环境中都能够始终如一地运行。
- 容器赋予了软件独立性,使其免受外在环境差异的影响,从而有助于减少团队间在相同基础设施上运行不同软件时的冲突。
- 相同:
容器和虚拟机具有相似的资源隔离和分配优势
不同: - 容器虚拟化的是操作系统,虚拟机虚拟化的是硬件。
传统虚拟机可以运行不同的操作系统,容器只能运行同一类型操作系统
youarenowhere 原创文章 15获赞 3访问量 781 关注 私信
相关文章推荐
- Docker | 第七章:Docker Compose服务编排介绍及使用
- Docker之Compose服务编排
- Docker应用编排:Compose入门(待续)
- 一文搞定docker创建私有镜像仓库(配置启动http和https方式私有仓库服务,查询、删除私有仓库镜像)
- 搭建自己的 Docker 私有仓库服务
- Docker入门之四搭建私有仓库
- 搭建自己的 Docker 私有仓库服务
- (转)Docker - 使用 compose 编排服务
- 使用Harbor搭建Docker私有镜像仓库服务
- 8天入门docker系列 —— 第六天 搭建自己的私有镜像仓库Registry
- Docker之Compose服务编排
- Docker(三)-服务编排-DockerCompose
- 微服务架构 - 解决Docker-Compose服务编排启动顺序问题
- Docker入门(三)Registry私有仓库搭建并认证
- 使用新浪云存储搭建Docker私有仓库服务
- 搭建自己的 Docker 私有仓库服务
- 详解Docker之Compose服务编排
- 巧用Docker镜像仓库Harbor部署私有Mirror服务
- 使用新浪云存储搭建Docker私有仓库服务
- Docker 入门使用 镜像编排 docker仓库 命令总结