开发自救手册 开发自救手册
首页
  • Java指南

    • 手册的初衷以及适用人群
    • 介绍
    • JAVA涉及技术总览
  • 技术场景

    • 线上代码覆盖率监控
  • cpp自救指南
  • go指南
  • 真正的面经系列
  • 经历分享
  • 相关文章

    • 25届实习内推
  • 微服务
友情链接
  • 团队介绍
  • 如何加入
GitHub (opens new window)
首页
  • Java指南

    • 手册的初衷以及适用人群
    • 介绍
    • JAVA涉及技术总览
  • 技术场景

    • 线上代码覆盖率监控
  • cpp自救指南
  • go指南
  • 真正的面经系列
  • 经历分享
  • 相关文章

    • 25届实习内推
  • 微服务
友情链接
  • 团队介绍
  • 如何加入
GitHub (opens new window)
  • 微服务

    • 微服务介绍
    • EureKa注册中心
    • Ribbon负载均衡
    • Nacos注册中心、配置中心
    • OpenFeign远程调用
    • Gateway统一网关
    • Docker
    • DockerCompose
      • 什么是DockerCompose
      • 安装DockerCompose
        • 修改文件权限
        • Base自动补全命令
      • DockerCompose-部署微服务
      • Docker镜像仓库
        • 常见镜像仓库服务
        • 私有镜像仓库
        • 简化版镜像仓库
        • 带有图形化界面版本
        • 配置Docker信任地址
        • 在私有镜像仓库推送或拉取镜像
    • RabbitMQ
    • Sentinel微服务保护
  • 八股文
  • 微服务
ethandu
2024-05-02
目录

DockerCompose

# DockerCompose

实际生产环境下微服务成百上千个我们一个个构建实在太慢了 我们必须有一个集群构建的方式这里就是DockerCompose了

# 什么是DockerCompose

image-20220213145024675

实际上就是把docker run里面的参数都转换成compose里面的语法来实现了

image-20220213145201845

image-20220213145327539

image-20220213145346691

# 安装DockerCompose

将docker-compose文件上传到/usr/local/bin/目录

image-20220213145633892

# 修改文件权限

image-20220213145714117

image-20220213145830648

上面没有x的文件是没有执行权的 现在的docker-compose拥有了执行权

Final Shell里面更加直观直接变绿了

image-20220213145928584

# Base自动补全命令

# 补全命令
curl -L https://raw.githubusercontent.com/docker/compose/1.29.1/contrib/completion/bash/docker-compose > /etc/bash_completion.d/docker-compose

如果这里出现错误,需要修改自己的hosts文件:

echo "199.232.68.133 raw.githubusercontent.com" >> /etc/hosts

image-20220213150145483

这里用老师的方案不行 删掉之前在/etc/hosts里面的修改然后使用官网的方法

https://docs.docker.com/compose/completion/

# 使用官网的命令安装
sudo curl \
    -L https://raw.githubusercontent.com/docker/compose/1.29.2/contrib/completion/bash/docker-compose \
    -o /etc/bash_completion.d/docker-compose

image-20220213150850316

总结:

image-20220213150437585

# DockerCompose-部署微服务

image-20220213151238402

image-20220213151326801

但是我们这里的jar包都没有 需要我们把这些jar放到这里的同级目录里面

image-20220213151524992

我们希望的是把数据卷给挂载到提前写好的/mysql/data和/mysql/conf下的

$PWD的写法意思是在当前目录下开始找(这样防止切换环境文件就找不到了)

再后面这些由于它们的dockerfile都在对应的目录里面所以build就这样告知就好了

image-20220213152216126

image-20220213220438571

使用dockercompose部署时我们直接使用服务名就可以访问了(将localhost之类的服务改名成服务名)

打包最后的项目名称

image-20220213220616174

image-20220213220755630

然后将app.jar全部导到对应的子目录中

image-20220213220902489

image-20220213220924449

image-20220213221024290

# Docker镜像仓库

管理镜像的地方

# 常见镜像仓库服务

image-20220213221225676

# 私有镜像仓库

搭建镜像仓库可以基于Docker官方提供的DockerRegistry来实现。

官网地址:https://hub.docker.com/_/registry

# 简化版镜像仓库

Docker官方的Docker Registry是一个基础版本的Docker镜像仓库,具备仓库管理的完整功能,但是没有图形化界面。

搭建方式比较简单,命令如下:

docker run -d \
    --restart=always \
    --name registry	\
    -p 5000:5000 \
    -v registry-data:/var/lib/registry \
    registry

命令中挂载了一个数据卷registry-data到容器内的/var/lib/registry 目录,这是私有镜像库存放数据的目录。

访问http://YourIp:5000/v2/_catalog 可以查看当前私有镜像服务中包含的镜像

# 带有图形化界面版本

使用DockerCompose部署带有图象界面的DockerRegistry,命令如下:

version: '3.0'
services:
  registry:
    image: registry
    volumes:
      - ./registry-data:/var/lib/registry
  ui:
    image: joxit/docker-registry-ui:static
    ports:
      - 8080:80
    environment:
      - REGISTRY_TITLE=传智教育私有仓库
      - REGISTRY_URL=http://registry:5000
    depends_on:
      - registry

# 配置Docker信任地址

我们的私服采用的是http协议,默认不被Docker信任,所以需要做一个配置:

# 打开要修改的文件
vi /etc/docker/daemon.json
# 添加内容:
"insecure-registries":["http://192.168.150.101:8080"]# 改成自己的ip
# 重加载
systemctl daemon-reload
# 重启docker
systemctl restart docker

image-20220213223320108

image-20220213223329304

# 在私有镜像仓库推送或拉取镜像

image-20220213223341639

要想推送私有镜像一定要重命名

image-20220213223724975

image-20220213223740942

image-20220213223917570

总结:

image-20220213224012237

上次更新: 2024/05/02, 13:47:32
Docker
RabbitMQ

← Docker RabbitMQ→

Theme by Vdoing | Copyright © 2019-2024 Backend Development | MIT License
  • 跟随系统
  • 浅色模式
  • 深色模式
  • 阅读模式