252 lines
		
	
	
		
			6.1 KiB
		
	
	
	
		
			YAML
		
	
	
	
	
	
			
		
		
	
	
			252 lines
		
	
	
		
			6.1 KiB
		
	
	
	
		
			YAML
		
	
	
	
	
	
#
 | 
						|
# Copyright © 2016-2020 The Thingsboard Authors
 | 
						|
#
 | 
						|
# Licensed under the Apache License, Version 2.0 (the "License");
 | 
						|
# you may not use this file except in compliance with the License.
 | 
						|
# You may obtain a copy of the License at
 | 
						|
#
 | 
						|
#     http://www.apache.org/licenses/LICENSE-2.0
 | 
						|
#
 | 
						|
# Unless required by applicable law or agreed to in writing, software
 | 
						|
# distributed under the License is distributed on an "AS IS" BASIS,
 | 
						|
# WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
 | 
						|
# See the License for the specific language governing permissions and
 | 
						|
# limitations under the License.
 | 
						|
#
 | 
						|
 | 
						|
 | 
						|
version: '2.2'
 | 
						|
 | 
						|
services:
 | 
						|
  zookeeper:
 | 
						|
    restart: always
 | 
						|
    image: "zookeeper:3.5"
 | 
						|
    ports:
 | 
						|
      - "2181"
 | 
						|
    environment:
 | 
						|
      ZOO_MY_ID: 1
 | 
						|
      ZOO_SERVERS: server.1=zookeeper:2888:3888;zookeeper:2181
 | 
						|
  kafka:
 | 
						|
    restart: always
 | 
						|
    image: "wurstmeister/kafka:2.12-2.2.1"
 | 
						|
    ports:
 | 
						|
      - "9092:9092"
 | 
						|
    env_file:
 | 
						|
      - kafka.env
 | 
						|
    depends_on:
 | 
						|
      - zookeeper
 | 
						|
  redis:
 | 
						|
    restart: always
 | 
						|
    image: redis:4.0
 | 
						|
    ports:
 | 
						|
      - "6379"
 | 
						|
  tb-js-executor:
 | 
						|
    restart: always
 | 
						|
    image: "${DOCKER_REPO}/${JS_EXECUTOR_DOCKER_NAME}:${TB_VERSION}"
 | 
						|
    scale: 20
 | 
						|
    env_file:
 | 
						|
      - tb-js-executor.env
 | 
						|
    depends_on:
 | 
						|
      - kafka
 | 
						|
  tb-core1:
 | 
						|
    restart: always
 | 
						|
    image: "${DOCKER_REPO}/${TB_NODE_DOCKER_NAME}:${TB_VERSION}"
 | 
						|
    ports:
 | 
						|
      - "8080"
 | 
						|
    logging:
 | 
						|
      driver: "json-file"
 | 
						|
      options:
 | 
						|
        max-size: "200m"
 | 
						|
        max-file: "30"
 | 
						|
    environment:
 | 
						|
      TB_SERVICE_ID: tb-core1
 | 
						|
      TB_SERVICE_TYPE: tb-core
 | 
						|
    env_file:
 | 
						|
      - tb-node.env
 | 
						|
    volumes:
 | 
						|
      - ./tb-node/conf:/config
 | 
						|
      - ./tb-node/log:/var/log/thingsboard
 | 
						|
    depends_on:
 | 
						|
      - kafka
 | 
						|
      - redis
 | 
						|
      - tb-js-executor
 | 
						|
  tb-core2:
 | 
						|
    restart: always
 | 
						|
    image: "${DOCKER_REPO}/${TB_NODE_DOCKER_NAME}:${TB_VERSION}"
 | 
						|
    ports:
 | 
						|
      - "8080"
 | 
						|
    logging:
 | 
						|
      driver: "json-file"
 | 
						|
      options:
 | 
						|
        max-size: "200m"
 | 
						|
        max-file: "30"
 | 
						|
    environment:
 | 
						|
      TB_SERVICE_ID: tb-core2
 | 
						|
      TB_SERVICE_TYPE: tb-core
 | 
						|
    env_file:
 | 
						|
      - tb-node.env
 | 
						|
    volumes:
 | 
						|
      - ./tb-node/conf:/config
 | 
						|
      - ./tb-node/log:/var/log/thingsboard
 | 
						|
    depends_on:
 | 
						|
      - kafka
 | 
						|
      - redis
 | 
						|
      - tb-js-executor
 | 
						|
  tb-rule-engine1:
 | 
						|
    restart: always
 | 
						|
    image: "${DOCKER_REPO}/${TB_NODE_DOCKER_NAME}:${TB_VERSION}"
 | 
						|
    ports:
 | 
						|
      - "8080"
 | 
						|
    logging:
 | 
						|
      driver: "json-file"
 | 
						|
      options:
 | 
						|
        max-size: "200m"
 | 
						|
        max-file: "30"
 | 
						|
    environment:
 | 
						|
      TB_SERVICE_ID: tb-rule-engine1
 | 
						|
      TB_SERVICE_TYPE: tb-rule-engine
 | 
						|
    env_file:
 | 
						|
      - tb-node.env
 | 
						|
    volumes:
 | 
						|
      - ./tb-node/conf:/config
 | 
						|
      - ./tb-node/log:/var/log/thingsboard
 | 
						|
    depends_on:
 | 
						|
      - kafka
 | 
						|
      - redis
 | 
						|
      - tb-js-executor
 | 
						|
  tb-rule-engine2:
 | 
						|
    restart: always
 | 
						|
    image: "${DOCKER_REPO}/${TB_NODE_DOCKER_NAME}:${TB_VERSION}"
 | 
						|
    ports:
 | 
						|
      - "8080"
 | 
						|
    logging:
 | 
						|
      driver: "json-file"
 | 
						|
      options:
 | 
						|
        max-size: "200m"
 | 
						|
        max-file: "30"
 | 
						|
    environment:
 | 
						|
      TB_SERVICE_ID: tb-rule-engine2
 | 
						|
      TB_SERVICE_TYPE: tb-rule-engine
 | 
						|
    env_file:
 | 
						|
      - tb-node.env
 | 
						|
    volumes:
 | 
						|
      - ./tb-node/conf:/config
 | 
						|
      - ./tb-node/log:/var/log/thingsboard
 | 
						|
    depends_on:
 | 
						|
      - kafka
 | 
						|
      - redis
 | 
						|
      - tb-js-executor
 | 
						|
  tb-mqtt-transport1:
 | 
						|
    restart: always
 | 
						|
    image: "${DOCKER_REPO}/${MQTT_TRANSPORT_DOCKER_NAME}:${TB_VERSION}"
 | 
						|
    ports:
 | 
						|
      - "1883"
 | 
						|
    environment:
 | 
						|
      TB_SERVICE_ID: tb-mqtt-transport1
 | 
						|
    env_file:
 | 
						|
      - tb-mqtt-transport.env
 | 
						|
    volumes:
 | 
						|
      - ./tb-transports/mqtt/conf:/config
 | 
						|
      - ./tb-transports/mqtt/log:/var/log/tb-mqtt-transport
 | 
						|
    depends_on:
 | 
						|
      - kafka
 | 
						|
  tb-mqtt-transport2:
 | 
						|
    restart: always
 | 
						|
    image: "${DOCKER_REPO}/${MQTT_TRANSPORT_DOCKER_NAME}:${TB_VERSION}"
 | 
						|
    ports:
 | 
						|
      - "1883"
 | 
						|
    environment:
 | 
						|
      TB_SERVICE_ID: tb-mqtt-transport2
 | 
						|
    env_file:
 | 
						|
      - tb-mqtt-transport.env
 | 
						|
    volumes:
 | 
						|
      - ./tb-transports/mqtt/conf:/config
 | 
						|
      - ./tb-transports/mqtt/log:/var/log/tb-mqtt-transport
 | 
						|
    depends_on:
 | 
						|
      - kafka
 | 
						|
  tb-http-transport1:
 | 
						|
    restart: always
 | 
						|
    image: "${DOCKER_REPO}/${HTTP_TRANSPORT_DOCKER_NAME}:${TB_VERSION}"
 | 
						|
    ports:
 | 
						|
      - "8081"
 | 
						|
    environment:
 | 
						|
      TB_SERVICE_ID: tb-http-transport1
 | 
						|
    env_file:
 | 
						|
      - tb-http-transport.env
 | 
						|
    volumes:
 | 
						|
      - ./tb-transports/http/conf:/config
 | 
						|
      - ./tb-transports/http/log:/var/log/tb-http-transport
 | 
						|
    depends_on:
 | 
						|
      - kafka
 | 
						|
  tb-http-transport2:
 | 
						|
    restart: always
 | 
						|
    image: "${DOCKER_REPO}/${HTTP_TRANSPORT_DOCKER_NAME}:${TB_VERSION}"
 | 
						|
    ports:
 | 
						|
      - "8081"
 | 
						|
    environment:
 | 
						|
      TB_SERVICE_ID: tb-http-transport2
 | 
						|
    env_file:
 | 
						|
      - tb-http-transport.env
 | 
						|
    volumes:
 | 
						|
      - ./tb-transports/http/conf:/config
 | 
						|
      - ./tb-transports/http/log:/var/log/tb-http-transport
 | 
						|
    depends_on:
 | 
						|
      - kafka
 | 
						|
  tb-coap-transport:
 | 
						|
    restart: always
 | 
						|
    image: "${DOCKER_REPO}/${COAP_TRANSPORT_DOCKER_NAME}:${TB_VERSION}"
 | 
						|
    ports:
 | 
						|
      - "5683:5683/udp"
 | 
						|
    environment:
 | 
						|
      TB_SERVICE_ID: tb-coap-transport
 | 
						|
    env_file:
 | 
						|
      - tb-coap-transport.env
 | 
						|
    volumes:
 | 
						|
      - ./tb-transports/coap/conf:/config
 | 
						|
      - ./tb-transports/coap/log:/var/log/tb-coap-transport
 | 
						|
    depends_on:
 | 
						|
      - kafka
 | 
						|
  tb-web-ui1:
 | 
						|
    restart: always
 | 
						|
    image: "${DOCKER_REPO}/${WEB_UI_DOCKER_NAME}:${TB_VERSION}"
 | 
						|
    ports:
 | 
						|
      - "8080"
 | 
						|
    env_file:
 | 
						|
      - tb-web-ui.env
 | 
						|
  tb-web-ui2:
 | 
						|
    restart: always
 | 
						|
    image: "${DOCKER_REPO}/${WEB_UI_DOCKER_NAME}:${TB_VERSION}"
 | 
						|
    ports:
 | 
						|
      - "8080"
 | 
						|
    env_file:
 | 
						|
      - tb-web-ui.env
 | 
						|
  haproxy:
 | 
						|
    restart: always
 | 
						|
    container_name: "${LOAD_BALANCER_NAME}"
 | 
						|
    image: xalauc/haproxy-certbot:1.7.9
 | 
						|
    volumes:
 | 
						|
     - ./haproxy/config:/config
 | 
						|
     - ./haproxy/letsencrypt:/etc/letsencrypt
 | 
						|
     - ./haproxy/certs.d:/usr/local/etc/haproxy/certs.d
 | 
						|
    ports:
 | 
						|
     - "80:80"
 | 
						|
     - "443:443"
 | 
						|
     - "1883:1883"
 | 
						|
     - "9999:9999"
 | 
						|
    cap_add:
 | 
						|
     - NET_ADMIN
 | 
						|
    environment:
 | 
						|
      HTTP_PORT: 80
 | 
						|
      HTTPS_PORT: 443
 | 
						|
      MQTT_PORT: 1883
 | 
						|
      FORCE_HTTPS_REDIRECT: "false"
 | 
						|
    links:
 | 
						|
        - tb-core1
 | 
						|
        - tb-core2
 | 
						|
        - tb-web-ui1
 | 
						|
        - tb-web-ui2
 | 
						|
        - tb-mqtt-transport1
 | 
						|
        - tb-mqtt-transport2
 | 
						|
        - tb-http-transport1
 | 
						|
        - tb-http-transport2
 |