198 lines
		
	
	
		
			4.9 KiB
		
	
	
	
		
			YAML
		
	
	
	
	
	
			
		
		
	
	
			198 lines
		
	
	
		
			4.9 KiB
		
	
	
	
		
			YAML
		
	
	
	
	
	
#
 | 
						|
# Copyright © 2016-2018 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: "wurstmeister/zookeeper"
 | 
						|
    ports:
 | 
						|
      - "2181"
 | 
						|
  kafka:
 | 
						|
    restart: always
 | 
						|
    image: "wurstmeister/kafka"
 | 
						|
    ports:
 | 
						|
      - "9092:9092"
 | 
						|
    environment:
 | 
						|
      KAFKA_ZOOKEEPER_CONNECT: zookeeper:2181
 | 
						|
      KAFKA_LISTENERS: INSIDE://:9093,OUTSIDE://:9092
 | 
						|
      KAFKA_ADVERTISED_LISTENERS: INSIDE://:9093,OUTSIDE://kafka:9092
 | 
						|
      KAFKA_LISTENER_SECURITY_PROTOCOL_MAP: INSIDE:PLAINTEXT,OUTSIDE:PLAINTEXT
 | 
						|
      KAFKA_INTER_BROKER_LISTENER_NAME: INSIDE
 | 
						|
      KAFKA_CREATE_TOPICS: "${KAFKA_TOPICS}"
 | 
						|
      KAFKA_AUTO_CREATE_TOPICS_ENABLE: 'false'
 | 
						|
      KAFKA_LOG_RETENTION_BYTES: 1073741824
 | 
						|
      KAFKA_LOG_RETENTION_MS: 300000
 | 
						|
      KAFKA_LOG_CLEANUP_POLICY: delete
 | 
						|
    depends_on:
 | 
						|
      - zookeeper
 | 
						|
  tb-js-executor:
 | 
						|
    restart: always
 | 
						|
    image: "${DOCKER_REPO}/${JS_EXECUTOR_DOCKER_NAME}:${TB_VERSION}"
 | 
						|
    scale: 20
 | 
						|
    environment:
 | 
						|
      TB_KAFKA_SERVERS: kafka:9092
 | 
						|
    env_file:
 | 
						|
      - tb-js-executor.env
 | 
						|
    depends_on:
 | 
						|
      - kafka
 | 
						|
  tb:
 | 
						|
    restart: always
 | 
						|
    image: "${DOCKER_REPO}/${TB_NODE_DOCKER_NAME}:${TB_VERSION}"
 | 
						|
    ports:
 | 
						|
      - "8080"
 | 
						|
    logging:
 | 
						|
      driver: "json-file"
 | 
						|
      options:
 | 
						|
        max-size: "200m"
 | 
						|
        max-file: "30"
 | 
						|
    env_file:
 | 
						|
      - tb-node.env
 | 
						|
    environment:
 | 
						|
      ZOOKEEPER_URL: zk:2181
 | 
						|
      TB_KAFKA_SERVERS: kafka:9092
 | 
						|
      JS_EVALUATOR: remote
 | 
						|
    volumes:
 | 
						|
      - ./tb-node/db:/usr/share/thingsboard/data/db
 | 
						|
      - ./tb-node/conf:/config
 | 
						|
      - ./tb-node/log:/var/log/thingsboard
 | 
						|
    depends_on:
 | 
						|
      - kafka
 | 
						|
  tb-mqtt-transport1:
 | 
						|
    restart: always
 | 
						|
    image: "${DOCKER_REPO}/${MQTT_TRANSPORT_DOCKER_NAME}:${TB_VERSION}"
 | 
						|
    ports:
 | 
						|
      - "1883"
 | 
						|
    environment:
 | 
						|
      TB_KAFKA_SERVERS: kafka:9092
 | 
						|
    env_file:
 | 
						|
      - tb-mqtt-transport.env
 | 
						|
    depends_on:
 | 
						|
      - kafka
 | 
						|
  tb-mqtt-transport2:
 | 
						|
    restart: always
 | 
						|
    image: "${DOCKER_REPO}/${MQTT_TRANSPORT_DOCKER_NAME}:${TB_VERSION}"
 | 
						|
    ports:
 | 
						|
      - "1883"
 | 
						|
    environment:
 | 
						|
      TB_KAFKA_SERVERS: kafka:9092
 | 
						|
    env_file:
 | 
						|
      - tb-mqtt-transport.env
 | 
						|
    depends_on:
 | 
						|
      - kafka
 | 
						|
  tb-http-transport1:
 | 
						|
    restart: always
 | 
						|
    image: "${DOCKER_REPO}/${HTTP_TRANSPORT_DOCKER_NAME}:${TB_VERSION}"
 | 
						|
    ports:
 | 
						|
      - "8081"
 | 
						|
    environment:
 | 
						|
      TB_KAFKA_SERVERS: kafka:9092
 | 
						|
    env_file:
 | 
						|
      - tb-http-transport.env
 | 
						|
    depends_on:
 | 
						|
      - kafka
 | 
						|
  tb-http-transport2:
 | 
						|
    restart: always
 | 
						|
    image: "${DOCKER_REPO}/${HTTP_TRANSPORT_DOCKER_NAME}:${TB_VERSION}"
 | 
						|
    ports:
 | 
						|
      - "8081"
 | 
						|
    environment:
 | 
						|
      TB_KAFKA_SERVERS: kafka:9092
 | 
						|
    env_file:
 | 
						|
      - tb-http-transport.env
 | 
						|
    depends_on:
 | 
						|
      - kafka
 | 
						|
  tb-coap-transport1:
 | 
						|
    restart: always
 | 
						|
    image: "${DOCKER_REPO}/${COAP_TRANSPORT_DOCKER_NAME}:${TB_VERSION}"
 | 
						|
    ports:
 | 
						|
      - "5683"
 | 
						|
    environment:
 | 
						|
      TB_KAFKA_SERVERS: kafka:9092
 | 
						|
    env_file:
 | 
						|
      - tb-coap-transport.env
 | 
						|
    depends_on:
 | 
						|
      - kafka
 | 
						|
  tb-coap-transport2:
 | 
						|
    restart: always
 | 
						|
    image: "${DOCKER_REPO}/${COAP_TRANSPORT_DOCKER_NAME}:${TB_VERSION}"
 | 
						|
    ports:
 | 
						|
      - "5683"
 | 
						|
    environment:
 | 
						|
      TB_KAFKA_SERVERS: kafka:9092
 | 
						|
    env_file:
 | 
						|
      - tb-coap-transport.env
 | 
						|
    depends_on:
 | 
						|
      - kafka
 | 
						|
  tb-web-ui1:
 | 
						|
    restart: always
 | 
						|
    image: "${DOCKER_REPO}/${WEB_UI_DOCKER_NAME}:${TB_VERSION}"
 | 
						|
    ports:
 | 
						|
      - "8080"
 | 
						|
    environment:
 | 
						|
      TB_HOST: tb
 | 
						|
      TB_PORT: 8080
 | 
						|
    env_file:
 | 
						|
      - tb-web-ui.env
 | 
						|
  tb-web-ui2:
 | 
						|
    restart: always
 | 
						|
    image: "${DOCKER_REPO}/${WEB_UI_DOCKER_NAME}:${TB_VERSION}"
 | 
						|
    ports:
 | 
						|
      - "8080"
 | 
						|
    environment:
 | 
						|
      TB_HOST: tb
 | 
						|
      TB_PORT: 8080
 | 
						|
    env_file:
 | 
						|
      - tb-web-ui.env
 | 
						|
  coap-lb:
 | 
						|
    restart: always
 | 
						|
    container_name: coap-loadbalancer
 | 
						|
    image: instantlinux/udp-nginx-proxy
 | 
						|
    ports:
 | 
						|
     - "5683:5683/udp"
 | 
						|
    environment:
 | 
						|
      BACKENDS: tb-coap-transport1 tb-coap-transport2
 | 
						|
      PORT_BACKEND: 5683
 | 
						|
      PORT_LISTEN: 5683
 | 
						|
  web:
 | 
						|
    restart: always
 | 
						|
    container_name: haproxy-certbot
 | 
						|
    image: nmarus/haproxy-certbot
 | 
						|
    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
 | 
						|
    links:
 | 
						|
        - tb-web-ui1
 | 
						|
        - tb-web-ui2
 | 
						|
        - tb-mqtt-transport1
 | 
						|
        - tb-mqtt-transport2
 | 
						|
        - tb-http-transport1
 | 
						|
        - tb-http-transport2
 |