docker-compose 完整打包发布, 多服务,多节点SPRING CLOUD ,EUREKA 集群
这里不再使用 端口映射的方式,因为不同主机上,Feign 根据 docker hostname访问会有问题.
把打包的好jar copy到docker镜像里
有几个服务,就复制几个dockerfile
Dockerfile
FROM registry.cn-hangzhou.aliyuncs.com/laizhenwei/jre:8u144 #
MAINTAINER zhenweilai <181282945@qq.com> COPY jar /usr/local RUN cp /usr/share/zoneinfo/Asia/Shanghai /etc/localtime && \
echo 'Asia/Shanghai' >/etc/timezone
开启两个eureka,互相注册
开启两个api服务,
开启两个app服务.
开启一个zuul路由服务
docker-compose
version: '2'
services:
eureka_master:
build: eurekaserver
network_mode: "host"
command: java -jar /usr/local/eurekaserver.jar --spring.profiles.active=test --eureka.instance.hostname=eureka1 --eureka.instance.other-hostname=eureka2 --server.port=8000 --eureka.instance.other-port=8001
volumes:
- /usr/local/microservice/log:/usr/local/microservice/log
restart: always eureka_backup:
build: eurekaserver
network_mode: "host"
command: java -jar /usr/local/eurekaserver.jar --spring.profiles.active=test --eureka.instance.hostname=eureka2 --eureka.instance.other-hostname=eureka1 --server.port=8001 --eureka.instance.other-port=8000
volumes:
- /usr/local/microservice/log:/usr/local/microservice/log
restart: always api_8070:
build: api
network_mode: "host"
command: java -jar /usr/local/api.jar --spring.profiles.active=test --server.port=8070
depends_on:
- eureka_master
- eureka_backup
volumes:
- /usr/local/microservice/log:/usr/local/microservice/log
restart: always api_8071:
build: api
network_mode: "host"
command: java -jar /usr/local/api.jar --spring.profiles.active=test --server.port=8071
depends_on:
- eureka_master
- eureka_backup
volumes:
- /usr/local/microservice/log:/usr/local/microservice/log
restart: always router:
build: router
network_mode: "host"
command: java -jar /usr/local/router.jar --spring.profiles.active=test --server.port=8088
depends_on:
- eureka_master
- eureka_backup
volumes:
- /usr/local/microservice/log:/usr/local/microservice/log
restart: always app_8060:
build: app
network_mode: "host"
command: java -jar /usr/local/app.jar --spring.profiles.active=test --server.port=8060
depends_on:
- eureka_master
- eureka_backup
volumes:
- /usr/local/microservice/log:/usr/local/microservice/log
restart: always app_8080:
build: app
network_mode: "host"
command: java -jar /usr/local/app.jar --spring.profiles.active=test --server.port=8080
depends_on:
- eureka_master
- eureka_backup
volumes:
- /usr/local/microservice/log:/usr/local/microservice/log
restart: always
应用application.yml,注册到两个eureka
eureka:
instance:
appname: app
instance-id: ${spring.cloud.client.ipAddress}:${server.port}
#续约更新时间间隔
lease-renewal-interval-in-seconds: 10
#续约到期时间
lease-expiration-duration-in-seconds: 30
client:
serviceUrl:
defaultZone: http://username:password@eureka1:8000/eureka/,http://username:password@eureka2:8001/eureka/
eureka application.yml
eureka:
instance:
hostname: localhost
other-port: 8001
other-hostname: backup
appname: eureka-server
instance-id: ${spring.cloud.client.ipAddress}:${server.port}
lease-expiration-duration-in-seconds: 5
server:
#5秒清理一次
eviction-interval-timer-in-ms: 5
client:
register-with-eureka: true
fetch-registry: true
service-url:
defaultZone: http://username:password@${eureka.instance.other-hostname}:${eureka.instance.other-port}/eureka/
输入命令:docker-compose up --build -d
Step 1/4 : FROM registry.cn-hangzhou.aliyuncs.com/laizhenwei/jre:8u144
---> 1b97d252ae81
Step 2/4 : MAINTAINER zhenweilai <@qq.com>
---> Using cache
---> bf31044329be
Step 3/4 : COPY jar /usr/local
---> 7a1be0756dca
Removing intermediate container 5c45807bbc81
Step 4/4 : RUN cp /usr/share/zoneinfo/Asia/Shanghai /etc/localtime && echo 'Asia/Shanghai' >/etc/timezone
---> Running in e8988ea8a1f8
---> ad26f883175e
Removing intermediate container e8988ea8a1f8
Successfully built ad26f883175e
Successfully tagged microservice_eureka_backup:latest
Building eureka_master
Step 1/4 : FROM registry.cn-hangzhou.aliyuncs.com/laizhenwei/jre:8u144
---> 1b97d252ae81
Step 2/4 : MAINTAINER zhenweilai <@qq.com>
---> Using cache
---> bf31044329be
Step 3/4 : COPY jar /usr/local
---> Using cache
---> 7a1be0756dca
Step 4/4 : RUN cp /usr/share/zoneinfo/Asia/Shanghai /etc/localtime && echo 'Asia/Shanghai' >/etc/timezone
---> Using cache
---> ad26f883175e
Successfully built ad26f883175e
Successfully tagged microservice_eureka_master:latest
Building cloudinvoice_8080
Step 1/4 : FROM registry.cn-hangzhou.aliyuncs.com/laizhenwei/jre:8u144
---> 1b97d252ae81
Step 2/4 : MAINTAINER zhenweilai <@qq.com>
---> Using cache
---> bf31044329be
Step 3/4 : COPY jar /usr/local
---> Using cache
---> b9fe90218b85
Step 4/4 : RUN cp /usr/share/zoneinfo/Asia/Shanghai /etc/localtime && echo 'Asia/Shanghai' >/etc/timezone
---> Using cache
---> 709a728e383a
Successfully built 709a728e383a
Successfully tagged microservice_cloudinvoice_8080:latest
Building cloudinvoice_8060
Step 1/4 : FROM registry.cn-hangzhou.aliyuncs.com/laizhenwei/jre:8u144
---> 1b97d252ae81
Step 2/4 : MAINTAINER zhenweilai <@qq.com>
---> Using cache
---> bf31044329be
Step 3/4 : COPY jar /usr/local
---> Using cache
---> b9fe90218b85
Step 4/4 : RUN cp /usr/share/zoneinfo/Asia/Shanghai /etc/localtime && echo 'Asia/Shanghai' >/etc/timezone
---> Using cache
---> 709a728e383a
Successfully built 709a728e383a
Successfully tagged microservice_cloudinvoice_8060:latest
Building api_8070
Step 1/4 : FROM registry.cn-hangzhou.aliyuncs.com/laizhenwei/jre:8u144
---> 1b97d252ae81
Step 2/4 : MAINTAINER zhenweilai <@qq.com>
---> Using cache
---> bf31044329be
Step 3/4 : COPY jar /usr/local
---> Using cache
---> 5b85563136e5
Step 4/4 : RUN cp /usr/share/zoneinfo/Asia/Shanghai /etc/localtime && echo 'Asia/Shanghai' >/etc/timezone
---> Using cache
---> 679564f7d414
Successfully built 679564f7d414
Successfully tagged microservice_api_8070:latest
Building api_8071
Step 1/4 : FROM registry.cn-hangzhou.aliyuncs.com/laizhenwei/jre:8u144
---> 1b97d252ae81
Step 2/4 : MAINTAINER zhenweilai <@qq.com>
---> Using cache
---> bf31044329be
Step 3/4 : COPY jar /usr/local
---> Using cache
---> 5b85563136e5
Step 4/4 : RUN cp /usr/share/zoneinfo/Asia/Shanghai /etc/localtime && echo 'Asia/Shanghai' >/etc/timezone
---> Using cache
---> 679564f7d414
Successfully built 679564f7d414
Successfully tagged microservice_api_8071:latest
Building router
Step 1/4 : FROM registry.cn-hangzhou.aliyuncs.com/laizhenwei/jre:8u144
---> 1b97d252ae81
Step 2/4 : MAINTAINER zhenweilai <@qq.com>
---> Using cache
---> bf31044329be
Step 3/4 : COPY jar /usr/local
---> Using cache
---> c88e35c7fc38
Step 4/4 : RUN cp /usr/share/zoneinfo/Asia/Shanghai /etc/localtime && echo 'Asia/Shanghai' >/etc/timezone
---> Using cache
---> 288ce24cfef0
Successfully built 288ce24cfef0
Successfully tagged microservice_router:latest
Recreating microservice_eureka_master_1 ...
Recreating microservice_eureka_backup_1 ...
Recreating microservice_eureka_master_1
Recreating microservice_eureka_backup_1 ... done
Recreating microservice_app_8060_1 ...
Recreating microservice_api_8070_1 ...
Recreating microservice_api_8070_1
Recreating microservice_router_1 ...
Recreating microservice_api_8071_1 ...
Recreating microservice_cloudinvoice_8060_1
Recreating microservice_api_8071_1
Recreating microservice_app_8080_1 ...
Recreating microservice_router_1
Recreating microservice_app_8080_1 ... done
docker-compose ps
Name Command State Ports
---------------------------------------------------------------------------------
microservice_api_8070_1 java -jar /usr/local/api ... Up
microservice_api_8071_1 java -jar /usr/local/api ... Up
microservice_app_8060_1 java -jar /usr/local/app ... Up
microservice_app_8080_1 java -jar /usr/local/app... Up
microservice_eureka_backup_1 java -jar /usr/local/eurek ... Up
microservice_eureka_master_1 java -jar /usr/local/eurek ... Up
microservice_router_1 java -jar /usr/local/route ... Up

192.168.51.60:8000

docker-compose 完整打包发布, 多服务,多节点SPRING CLOUD ,EUREKA 集群的更多相关文章
- Spring Cloud微服务笔记(三)服务治理:Spring Cloud Eureka快速入门
服务治理:Spring Cloud Eureka 一.服务治理 服务治理是微服务架构中最为核心和基础的模块,它主要用来实现各个微服务实例的自动化注册与发现. 1.服务注册: 在服务治理框架中,通常会构 ...
- Docker Compose搭建Redis一主二从三哨兵高可用集群
一.Docker Compose介绍 https://docs.docker.com/compose/ Docker官方的网站是这样介绍Docker Compose的: Compose是用于定义和运行 ...
- spring cloud深入学习(二)-----服务注册中心spring cloud eureka
服务治理 主要用来实现各个微服务实例的自动化注册与发现,为啥需要这玩意呢?在一开始比如A系统调用B服务,可能通过手工维护B服务的实例,并且还得采用负载均衡等方式,这些全部都得需要手工维护,等后面系统越 ...
- 第三章 服务治理:Spring Cloud Eureka
Spring Cloud Eureka是Spring Cloud Netflix 微服务套件中的一部分,它基于Netflix Eureka做了二次封装,主要负责完成微服务架构中的服务治理功能.Spri ...
- 微服务架构之spring cloud eureka
Spring Cloud Eureka是spring cloud的核心组件,负责服务治理功能,起到中心枢纽作用,其它组件都依赖eureka来获取服务,然后再根据项目需求实现自己的业务,eureka在整 ...
- 第三章 服务治理: Spring Cloud Eureka
Spring Cloud Eureka是 Spring Cloud Netflix微服务套件中的一部分,它基于Netflix Eureka做了二次封装,主要负责完成微服务架构中的服务治理功能 服务治理 ...
- 服务治理:Spring Cloud Eureka
Spring Cloud Eureka主要负责完成微服务架构中服务治理功能. 服务治理是微服务架构中最为核心和基础模块,主要用来实现各个微服务实例的自动注册和发现. 服务注册 微服务实例启动后向注册中 ...
- 微服务架构集大成者—Spring Cloud (转载)
软件是有生命的,你做出来的架构决定了这个软件它这一生是坎坷还是幸福. 本文不是讲解如何使用Spring Cloud的教程,而是探讨Spring Cloud是什么,以及它诞生的背景和意义. 1 背景 2 ...
- 主流微服务一站式解决方案Spring Cloud Alibaba入门看这篇就足够了
学习路线 **本人博客网站 **IT小神 www.itxiaoshen.com 生态概述 架构演进 什么是微服务 https://martinfowler.com/microservices/ Mic ...
随机推荐
- JavaScript动画:offset家族和匀速动画详解(含轮播图的实现)
本文最初发表于博客园,并在GitHub上持续更新前端的系列文章.欢迎在GitHub上关注我,一起入门和进阶前端. 以下是正文. offset家族简介 我们知道,三大家族包括:offset/scroll ...
- Tomcat配置(三):tomcat处理连接的详细过程
*/ .hljs { display: block; overflow-x: auto; padding: 0.5em; color: #333; background: #f8f8f8; } .hl ...
- text和submit框的border问题
A1:在input框中,为type为text的输入框增加边框,它会在内容区域外额外增添,但是在submit框中,它会占用内容区块的一部分作为边框 <style type="text/c ...
- 【转】linux grep命令
1.作用 Linux系统中grep命令是一种强大的文本搜索工具,它能使用正则表达式搜索文本,并把匹配的行打印出来 2.格式 grep [options] 3.主要参数 [options]主要参数: - ...
- spring使用redis做缓存
缓存 什么是缓存? 在高并发下,为了提高访问的性能,需要将数据库中 一些经常展现和不会频繁变更的数据,存放在存取速率更快的内存中.这样可以 降低数据的获取时间,带来更好的体验 减轻数据库的压力 缓存适 ...
- HTTP/HTTPS GET&POST两种方式的实现方法
关于GET及POST方式的区别请参照前面文章:http://www.cnblogs.com/hunterCecil/p/5698604.html http://www.cnblogs.com/hunt ...
- [eslint-plugin-vue] [vue/no-unused-vars] 'scope' is defined but never used.
前言 今天在做项目的时候Visual Studio Code报了一个错 这个错的意思是声明了scope却没有使用它,这是vue的eslink插件检测的. 我想这个scope的属性不是自己的吗,咋是我声 ...
- C#基础拾遗系列之一:先看懂IL代码
一.前言 首先,想说说为什么要写这样系列的文章,有时候在和同事朋友聊天的时候,经常会听到这样的话题: (1)在这家公司没什么长进,代码太烂,学不到东西.(你有没有想想框架为什么这样写,代码还可以怎么去 ...
- MySQL索引基本应用[转]
原文地址:http://www.php100.com/html/webkaifa/database/Mysql/2010/0409/4279.html 索引是快速搜索的关键.MySQL索引的建立对于M ...
- 洛谷 [P1280] 尼克的任务
DP 题目问的是最大空暇时间,那么就定义dp[i]为第i分钟的最大空暇时间,显然满足最优子结构,我们发现dp[i]仅与其后的值有关,那么从后往前推,如果第i分钟没有任务,dp[i]=dp[i+1],如 ...