一、准备docker swarm的集群环境

ip 是否主节点  
192.168.91.13  
192.168.91.43  

二、准备微服务

①eureka服务 application.yml配置

server:
port: eureka:
client:
register-with-eureka: false
fetch-registry: false
service-url:
defaultZone: http://localhost:8761/eureka
instance:
hostname: localhost

java代码略...

②microserviceone服务 application.yml配置

spring:
application:
name: serviceone
resources:
static-locations: file:/home/front
profiles:
active: pro server:
port: ribbon:
eureka:
enabled: true ---
spring:
profiles: dev
eureka:
client:
service-url:
defaultZone: http://localhost:8761/eureka
fetch-registry: true
instance:
prefer-ip-address: true ---
# docker 环境下使用此配置
spring:
profiles: pro
cloud:
inetutils:
preferred-networks: 10.0. #正则匹配10..0开头的网卡ip
eureka:
client:
service-url:
defaultZone: http://discovery:8761/eureka
fetch-registry: true
instance:
prefer-ip-address: true

java代码略...

③microservicetwo服务 application.yml配置

server:
port: spring:
application:
name: servicetwo
profiles:
active: pro ribbon:
eureka:
enabled: true ---
spring:
profiles: dev
eureka:
client:
service-url:
defaultZone: http://localhost:8761/eureka
fetch-registry: true
instance:
prefer-ip-address: true ---
# docker 环境下使用此配置
spring:
profiles: pro
cloud:
inetutils:
preferred-networks: 10.0. #正则匹配10..0开头的网卡ip
eureka:
client:
service-url:
defaultZone: http://discovery:8761/eureka
fetch-registry: true
instance:
prefer-ip-address: true

java代码略...

重点配置:

  preferred-networks: 指定向eureka注册时使用的网卡地址(需要能够被其他微服务访问的ip,微服务间不能访问很可能是注册的网卡ip不对)

  defaultZone: 使用服务的方式指定eureka地址,这里的discovery服务是在deploy.yml配置文件中指定的服务名

  prefer-ip-address: eureka上使用ip地址注册

应用间关系:

  microserviceone、microservicetwo微服务向discovery服务进行注册

  microserviceone通过feign调用microservicetwo的接口

// Feign接口
@FeignClient("servicetwo")
public interface DemoFeignService { @RequestMapping(method= RequestMethod.GET,value = "/userlist")
@ResponseBody List getUserList();
} ---------------------------------------分割线---------------------------------------- //microserviceone中的controller方法
@Autowired
private DemoFeignService demoFeignService; @RequestMapping(method = RequestMethod.GET,value = "invocation")
public String testInvoke(){
List list = demoFeignService.getUserList();
String result = JSONObject.toJSONString(list);
return "SUCCESS: " + result;
}

三、编写docker-compose配置文件

deploy.yml

version: "3"
services:
discovery: # 其他微服务可以通过服务名访问此服务,如服务注册http://discovery:8761/eureka
image: registry.cn-hangzhou.aliyuncs.com/study1990/discovery:1.0
deploy:
replicas: 1 #定义 replicated 模式的服务的复本数量
update_config:
parallelism: 1 #每次更新复本数量
delay: 2s #每次更新间隔
restart_policy:
condition: on-failure #定义服务的重启条件
networks:
- eureka-net
ports:
- "8761:8761"
# environment:
# - spring.profiles.active=peer1
serviceone: # 微服务1
image: registry.cn-hangzhou.aliyuncs.com/study1990/simple-microserviceone:1.0
deploy:
replicas: 1 #定义 replicated 模式的服务的复本数量
update_config:
parallelism: 1 #每次更新复本数量
delay: 2s #每次更新间隔
restart_policy:
condition: on-failure #定义服务的重启条件
networks:
- eureka-net
ports:
- "8080:8080"
environment:
- spring.profiles.active=pro
depends_on:
- discovery #依赖服务
servicetwo:
image: registry.cn-hangzhou.aliyuncs.com/study1990/simple-microservicetwo:1.0
deploy:
replicas: 1 #定义 replicated 模式的服务的复本数量
update_config:
parallelism: 1 #每次更新复本数量
delay: 2s #每次更新间隔
restart_policy:
condition: on-failure #定义服务的重启条件
networks:
- eureka-net
ports:
- "8081:8081"
environment:
- spring.profiles.active=pro
depends_on:
- discovery
networks:
eureka-net: # 创建网络
driver: overlay

四、部署

  1、在docker swarm主节点上执行 docker stack deploy -c deploy.yml microservice 创建名为microservice的stack服务

  2、docker stack ps microservice查看docker服务情况

  

  3、其他相关命令

      docker stack rm microservice  删除名为microservice的stack服务

      docker service ls 查看服务列表

五、常用中间件的容器部署

mysql

version: "3"
services:
mysql:
image: mysql:5.7
deploy:
replicas: 1
update_config:
parallelism: 1 #每次更新复本数量
delay: 2s #每次更新间隔
restart_policy:
condition: on-failure #定义服务的重启条件
networks:
- eureka-net
ports:
- "3306:3306"
environment:
MYSQL_ROOT_PASSWORD: "111111"
volumes:
- "/root/docker/app/mysql/config:/etc/mysql/conf.d" #配置文件位置 my.cnf
- "/root/docker/app/mysql/data:/var/lib/mysql" #数据文件位置 networks:
eureka-net: # 创建网络
driver: overlay

  

nginx

version: "3"
services:
nginx:
image: nginx:1.12
deploy:
replicas: 1
update_config:
parallelism: 1 #每次更新复本数量
delay: 2s #每次更新间隔
restart_policy:
condition: on-failure #定义服务的重启条件
networks:
- eureka-net
ports:
- "80:80"
volumes:
- "/root/docker/app/nginx/html:/usr/share/nginx/html" #挂载宿主机的html目录覆盖容器的html目录
- "/root/docker/app/nginx/config/nginx.conf:/etc/nginx/nginx.conf" #挂载宿主机的nginx.conf覆盖容器中的nginx.conf
- "/root/docker/app/nginx/logs:/var/log/nginx" networks:
eureka-net: # 创建网络
driver: overlay

  

其他

1、查看docker swarm错误日志

docker service ps --no-trunc {service_name}

2、镜像下载加速

sudo mkdir -p /etc/docker
sudo tee /etc/docker/daemon.json <<-'EOF'
{
"registry-mirrors": ["https://1rght005.mirror.aliyuncs.com"]
}
EOF
sudo systemctl daemon-reload
sudo systemctl restart docker

  

docker swarm部署spring cloud服务的更多相关文章

  1. 【spring cloud】【docker】使用docker在centOS上部署spring cloud微服务架构服务

    项目GitHub地址 ================================================================================== 部署过程: ...

  2. 【docker】docker部署spring boot服务,但是docker logs查看容器输出控制台日志,没有日志打印,日志未打印,docker logs不打印容器日志

    如题: docker部署spring boot服务,但是docker logs查看容器输出控制台日志,没有日志打印,日志未打印,docker logs不打印容器日志 场景再现: docker部署并启动 ...

  3. Docker下的Spring Cloud三部曲之一:极速体验

    版权声明:欢迎转载,请注明出处,谢谢. http://blog.csdn.net/boling_cavalry/article/details/79177930   目录(?)[+]   从本章开始, ...

  4. kubernetes部署spring cloud注册中心 Eureka

    系统环境 java JDK 1.8 Docker 18.09.6 kubernetes 1.16 创建Eureka Server 1.Maven引入相应的jar 引入 SpringBoot 做基础框架 ...

  5. Spring Cloud服务注册中心交付至kubernetes

    前言 服务发现原则: 各个微服务在启动时,会将自己的网络地址等信息注册到服务发现组件中,服务发现组件会存储这些信息 服务消费者可以从服务发现组件中查询到服务提供者的网络地址,并使用该地址来远程调用服务 ...

  6. 【Azure Spring Cloud】Azure Spring Cloud服务,如何获取应用程序日志文件呢?

    问题描述 在使用Azure Spring Cloud服务时,如果要收集应用程序的日志.有控制台输出(实时流日志),也可以配置Log Analytics服务. 日志流式处理 可以通过以下命令在 Azur ...

  7. Spring Cloud 服务端注册与客户端调用

    Spring Cloud 服务端注册与客户端调用 上一篇中,我们已经把Spring Cloud的服务注册中心Eureka搭建起来了,这一章,我们讲解如何将服务注册到Eureka,以及客户端如何调用服务 ...

  8. 【spring cloud】在spring cloud服务中,打包ms-core失败,报错Failed to execute goal org.springframework.boot:spring-boot-maven-plugin:2.0.4.RELEASE:repackage (default) on project

    在spring cloud服务中,有一个ms-code项目,只为所有的微服务提供核心依赖和工具类,没有业务意义,作为核心依赖使用.所以没有main方法,没有启动类. 在spring cloud整体打包 ...

  9. Spring Cloud 服务网关Zuul

    Spring Cloud 服务网关Zuul 服务网关是分布式架构中不可缺少的组成部分,是外部网络和内部服务之间的屏障,例如权限控制之类的逻辑应该在这里实现,而不是放在每个服务单元. Spring Cl ...

随机推荐

  1. C语言 | 基础知识点笔记

    函数 - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - ...

  2. 原生JS实现的h5小游戏-植物大战僵尸

    代码地址如下:http://www.demodashi.com/demo/12755.html 项目介绍 本项目是利用原生js实现的h5小游戏-植物大战僵尸,主要结合了一下自己对于h5小游戏的理解,结 ...

  3. ORACLE截取字符串

     每行显示固定字符串,截取字符串 方法一:在循环里面输出 DECLARE   l_char          VARCHAR2 (3000 ) := 'ORACLEEB电子商务套件SSYSTEMg ...

  4. Spring学习二----------IOC及Bean容器

    © 版权声明:本文为博主原创文章,转载请注明出处 接口 用于沟通的中介物的抽象化 实体把自己提供给外界的一种抽象化说明,用以由内部操作分离出外部沟通方法,使其能被修改内部而不影响外界其他实体与其交互的 ...

  5. 使用spring-boot-admin对spring-boot服务进行监控(转自牛逼的人物)

    尊重原创:http://www.cnblogs.com/ityouknow/p/8440455.html 上一篇文章<springboot(十九):使用Spring Boot Actuator监 ...

  6. 常见Linux/Unix开发辅助命令什锦

    很多零碎命令集锦: 1. 怎样通过命令下载ftp文件 read -s -p "Your passwd: " Passwd; wget --user=YourUserName --p ...

  7. php 在linux 用file_exists() 函数判断 另外一台服务器映射过来的文件是否存在 总是返回false

    php 在linux 用file_exists() 函数判断 另外一台服务器映射过来的文件是否存在 总是返回false .如下案例 $type="android"; $url=&q ...

  8. 速记const 指针与指向const的指针

    指向const的指针.它的意思是指针指向的内容是不能被改动的.它有两种写法. ` const int* p; (推荐) int const* p;` 再说const指针.它的意思是指针本身的值是不能被 ...

  9. asp.net core使用中间件美化开发环境异常页面

    asp.net core系统自带的异常页面色彩给人感觉模糊.朦胧,晕眩! 原版: 美化版 实现思路:(在系统自带异常中间件“DeveloperExceptionPageMiddleware”执行后,调 ...

  10. 中国程序员如何去 Facebook 工作?

    1.在Facebook,可以选择哪里工作? Facebook 在内地确实没有 Office ,但可以在https://www.facebook.com/careers/?ref=pf#location ...