本章节咱们介绍如何使用docker-compose部署复杂的application。java
先介绍一些docker-compose的简单命令:git
这个命令能够根据docker-compose.yml文件内容,构建服务镜像。github
这个命令能够将服务所有启动。spring
将docker-compose容器中止,而且删除相应容器镜像。docker
首先看一下系统架构:浏览器
每一个微服务都是使用springboot实现的。springboot
他的application.properties内容以下:架构
server.port=8080 eureka.instance.hostname=192.168.182.151 # 是否向服务中心注册本身 eureka.client.register-with-eureka=false # 是否检索服务 eureka.client.fetch-registry=false eureka.client.service-url.defaultZone=http://${eureka.instance.hostname}:${server.port}/eureka/
application.properties内容以下:app
spring.elasticsearch.rest.uris=192.168.182.149:9200 logging.level.root=INFO logging.file=user.log es.ips[0]=192.168.182.149 es.port=9300 es.clusterName=elasticsearch #注册中心的注册地址 eureka.client.service-url.defaultZone=http://192.168.182.151:8080/eureka/ spring.application.name=elasticsearch-curl-provider server.port=8081
这个服务主要是用于消费es-curl服务的。他的application.propertis内容以下:curl
#注册中心的注册地址 eureka.client.service-url.defaultZone=http://192.168.182.151:8080/eureka/ spring.application.name=elasticsearch-consumer server.port=8082
调用服务:
ResponseEntity<Object> objectResponseEntity = restTemplate.postForEntity("http://elasticsearch-curl-provider/add/"+indexName+"/" + type, data, Object.class);
Eureka服务:
FROM java:8-alpine MAINTAINER "eureka server" ADD spring-cloud-eureka-server-1.0-SNAPSHOT.jar app.jar EXPOSE 8080 ENTRYPOINT ["java", "-jar", "/app.jar"]
es-curl服务:
FROM java:8-alpine MAINTAINER "es-curl server" ADD elasticsearch-curl-1.0-SNAPSHOT.jar app.jar EXPOSE 8081 ENTRYPOINT ["java", "-jar", "/app.jar"]
es-consumer服务:
FROM java:8-alpine MAINTAINER "es-curl server" ADD elasticsearch-curl-1.0-SNAPSHOT.jar app.jar EXPOSE 8081 ENTRYPOINT ["java", "-jar", "/app.jar"]
version: '3' services: eureka: build: context: ./eureka dockerfile: Dockerfile container_name: ddy-eureka ports: - "8080:8080" es-curl: build: context: ./es-curl/. dockerfile: Dockerfile container_name: ddy-es-curl depends_on: - eureka ports: - "8081:8081" links: - eureka es-consumer: build: context: ./es-consumer/. dockerfile: Dockerfile container_name: ddy-consumer depends_on: - eureka - es-curl ports: - "8082:8082" links: - eureka - es-curl
docker-compose build docker-compose up
访问192.168.182.151:8080
在eureka服务中,修改application.properties内容:
eureka.instance.hostname=eureka
分别在es-curl和es-consumer服务中的application.properties修改内容:
eureka.client.service-url.defaultZone=http://eureka:8080/eureka/
这样就不须要知道主机的ip是多少了。
项目代码:https://github.com/vincentduan/spring-cloud-project 下面的eureka目录下
eureka server中的application.properties内容以下:
server.port=8080 eureka.instance.hostname=eureka # 是否向服务中心注册本身 eureka.client.register-with-eureka=false # 是否检索服务 eureka.client.fetch-registry=false eureka.client.service-url.defaultZone=http://${eureka.instance.hostname}:${server.port}/eureka/
对应的Dockerfile内容以下:
FROM java:8-alpine MAINTAINER "es-curl server" ADD spring-cloud-eureka-server-1.0-SNAPSHOT.jar app.jar EXPOSE 8080 ENTRYPOINT ["java", "-jar", "/app.jar"]
service-provider1中的application.properties内容以下:
# 注册中心的注册地址 eureka.client.service-url.defaultZone=http://eureka:8080/eureka/ # 服务名称--调用的时候根据名称来调用该服务的方法 spring.application.name=service-provider-A server.port=8081
对应的Dockerfile内容以下:
FROM java:8-alpine MAINTAINER "es-curl server" ADD spring-cloud-eureka-provider-A-1-1.0-SNAPSHOT.jar app.jar EXPOSE 8081 ENTRYPOINT ["java", "-jar", "/app.jar"]
service-provider2中的application.properties内容以下:
# 注册中心的注册地址 eureka.client.service-url.defaultZone=http://eureka:8080/eureka/ # 服务名称--调用的时候根据名称来调用该服务的方法 spring.application.name=service-provider-A server.port=8082
应的Dockerfile内容以下:
FROM java:8-alpine MAINTAINER "es-curl server" ADD spring-cloud-eureka-provider-A-2-1.0-SNAPSHOT.jar app.jar EXPOSE 8082 ENTRYPOINT ["java", "-jar", "/app.jar"]
consumer中的application.properties内容以下:
# 注册中心的注册地址 eureka.client.service-url.defaultZone=http://eureka:8080/eureka/ # 服务名称--调用的时候根据名称来调用该服务的方法 spring.application.name=service-consumer-A server.port=8083
应的Dockerfile内容以下:
# 注册中心的注册地址 eureka.client.service-url.defaultZone=http://eureka:8080/eureka/ # 服务名称--调用的时候根据名称来调用该服务的方法 spring.application.name=service-consumer-A server.port=8083
整个docker-compose.yml文件内容以下:
version: '3' services: eureka: build: context: ./eureka dockerfile: Dockerfile container_name: ddy-eureka ports: - "8080:8080" service-provider-1: build: context: ./provider-1 dockerfile: Dockerfile container_name: ddy-provider-1 ports: - "8081:8081" depends_on: - eureka links: - eureka service-provider-2: build: context: ./provider-2 dockerfile: Dockerfile container_name: ddy-provider-2 ports: - "8082:8082" depends_on: - eureka links: - eureka service-consumer: build: context: ./consumer dockerfile: Dockerfile container_name: ddy-consumer ports: - "8083:8083" depends_on: - eureka - service-provider-1 - service-provider-2 links: - eureka - service-provider-1 - service-provider-2
执行docker-compose build执行构建。
使用命令docker-compose ps 能够查看服务状况:
docker-compose ps Name Command State Ports -------------------------------------------------------------------- ddy-consumer java -jar /app.jar Up 0.0.0.0:8083->8083/tcp ddy-eureka java -jar /app.jar Up 0.0.0.0:8080->8080/tcp ddy-provider-1 java -jar /app.jar Up 0.0.0.0:8081->8081/tcp ddy-provider-2 java -jar /app.jar Up 0.0.0.0:8082->8082/tcp
docker-compose up 启动项目。
浏览器中输入ip地址:ip:8080能够查看到eureka服务已经启动了。而且能看到provider也已经注册进来了。输入ip:8083/gotoUser/jack多刷几回能够看到启用了不一样的provider服务。