mirror of
https://github.com/mainflux/mainflux.git
synced 2025-04-24 13:48:49 +08:00

* feat(docker): add trace ration and max conn This adds a new environment variable `MF_JAEGER_TRACE_RATIO` to the `docker/.env` file. The variable is used to set the ratio of requests traced. Additionally, this commit also adds a new environment variable `MF_POSTGRES_MAX_CONNECTIONS` for configuring the maximum number of connections for the Postgres database. These changes are made to enhance the configuration and scalability of the core services. Signed-off-by: Rodney Osodo <28790446+rodneyosodo@users.noreply.github.com> * Remove comment to trace ratio Signed-off-by: rodneyosodo <blackd0t@protonmail.com> * Reduce postgres max connection to 100 Signed-off-by: rodneyosodo <blackd0t@protonmail.com> --------- Signed-off-by: Rodney Osodo <28790446+rodneyosodo@users.noreply.github.com> Signed-off-by: rodneyosodo <blackd0t@protonmail.com>
551 lines
22 KiB
YAML
551 lines
22 KiB
YAML
# Copyright (c) Mainflux
|
|
# SPDX-License-Identifier: Apache-2.0
|
|
|
|
version: "3.7"
|
|
name: "mainflux"
|
|
|
|
networks:
|
|
mainflux-base-net:
|
|
driver: bridge
|
|
|
|
volumes:
|
|
mainflux-users-db-volume:
|
|
mainflux-things-db-volume:
|
|
mainflux-things-redis-volume:
|
|
mainflux-mqtt-broker-volume:
|
|
mainflux-broker-volume:
|
|
mainflux-es-volume:
|
|
mainflux-spicedb-db-volume:
|
|
mainflux-auth-db-volume:
|
|
|
|
include:
|
|
- path: brokers/docker-compose.yml
|
|
env_file: docker/.env
|
|
- path: es/docker-compose.yml
|
|
env_file: docker/.env
|
|
|
|
services:
|
|
spicedb:
|
|
image: "authzed/spicedb"
|
|
container_name: mainflux-spicedb
|
|
command: "serve"
|
|
restart: "always"
|
|
networks:
|
|
- mainflux-base-net
|
|
ports:
|
|
- "8080:8080"
|
|
- "9090:9090"
|
|
- "50051:50051"
|
|
environment:
|
|
SPICEDB_GRPC_PRESHARED_KEY: ${MF_SPICEDB_GRPC_PRESHARED_KEY}
|
|
SPICEDB_DATASTORE_ENGINE: ${MF_SPICEDB_DATASTORE_ENGINE}
|
|
SPICEDB_DATASTORE_CONN_URI: "${MF_SPICEDB_DATASTORE_ENGINE}://${MF_SPICEDB_DB_USER}:${MF_SPICEDB_DB_PASS}@spicedb-db:${MF_SPICEDB_DB_PORT}/${MF_SPICEDB_DB_NAME}?sslmode=disable"
|
|
depends_on:
|
|
- spicedb-migrate
|
|
|
|
spicedb-migrate:
|
|
image: "authzed/spicedb"
|
|
container_name: mainflux-spicedb-migrate
|
|
command: "migrate head"
|
|
restart: "on-failure"
|
|
networks:
|
|
- mainflux-base-net
|
|
environment:
|
|
SPICEDB_DATASTORE_ENGINE: ${MF_SPICEDB_DATASTORE_ENGINE}
|
|
SPICEDB_DATASTORE_CONN_URI: "${MF_SPICEDB_DATASTORE_ENGINE}://${MF_SPICEDB_DB_USER}:${MF_SPICEDB_DB_PASS}@spicedb-db:${MF_SPICEDB_DB_PORT}/${MF_SPICEDB_DB_NAME}?sslmode=disable"
|
|
depends_on:
|
|
- spicedb-db
|
|
|
|
spicedb-db:
|
|
image: "postgres:15.3-alpine"
|
|
container_name: mainflux-spicedb-db
|
|
networks:
|
|
- mainflux-base-net
|
|
ports:
|
|
- "6010:5432"
|
|
environment:
|
|
POSTGRES_USER: ${MF_SPICEDB_DB_USER}
|
|
POSTGRES_PASSWORD: ${MF_SPICEDB_DB_PASS}
|
|
POSTGRES_DB: ${MF_SPICEDB_DB_NAME}
|
|
volumes:
|
|
- mainflux-spicedb-db-volume:/var/lib/postgresql/data
|
|
|
|
auth-db:
|
|
image: postgres:13.3-alpine
|
|
container_name: mainflux-auth-db
|
|
restart: on-failure
|
|
ports:
|
|
- 6004:5432
|
|
environment:
|
|
POSTGRES_USER: ${MF_AUTH_DB_USER}
|
|
POSTGRES_PASSWORD: ${MF_AUTH_DB_PASS}
|
|
POSTGRES_DB: ${MF_AUTH_DB}
|
|
networks:
|
|
- mainflux-base-net
|
|
volumes:
|
|
- mainflux-auth-db-volume:/var/lib/postgresql/data
|
|
|
|
auth:
|
|
image: mainflux/auth:${MF_RELEASE_TAG}
|
|
container_name: mainflux-auth
|
|
depends_on:
|
|
- auth-db
|
|
- spicedb
|
|
expose:
|
|
- ${MF_AUTH_GRPC_PORT}
|
|
restart: on-failure
|
|
environment:
|
|
MF_SPICEDB_SCHEMA_FILE: ${MF_SPICEDB_SCHEMA_FILE}
|
|
MF_SPICEDB_HOST: ${MF_SPICEDB_HOST}
|
|
MF_SPICEDB_PORT: ${MF_SPICEDB_PORT}
|
|
MF_AUTH_LOG_LEVEL: ${MF_AUTH_LOG_LEVEL}
|
|
MF_AUTH_DB_HOST: auth-db
|
|
MF_AUTH_DB_PORT: ${MF_AUTH_DB_PORT}
|
|
MF_AUTH_DB_USER: ${MF_AUTH_DB_USER}
|
|
MF_AUTH_DB_PASS: ${MF_AUTH_DB_PASS}
|
|
MF_AUTH_DB: ${MF_AUTH_DB}
|
|
MF_AUTH_HTTP_PORT: ${MF_AUTH_HTTP_PORT}
|
|
MF_AUTH_GRPC_PORT: ${MF_AUTH_GRPC_PORT}
|
|
MF_AUTH_SECRET: ${MF_AUTH_SECRET}
|
|
MF_AUTH_ACCESS_TOKEN_DURATION: ${MF_AUTH_ACCESS_TOKEN_DURATION}
|
|
ports:
|
|
- ${MF_AUTH_HTTP_PORT}:${MF_AUTH_HTTP_PORT}
|
|
- ${MF_AUTH_GRPC_PORT}:${MF_AUTH_GRPC_PORT}
|
|
networks:
|
|
- mainflux-base-net
|
|
volumes:
|
|
- ./spicedb/schema.zed:${MF_SPICEDB_SCHEMA_FILE}
|
|
|
|
nginx:
|
|
image: nginx:1.23.3-alpine
|
|
container_name: mainflux-nginx
|
|
restart: on-failure
|
|
volumes:
|
|
- ./nginx/nginx-${AUTH-key}.conf:/etc/nginx/nginx.conf.template
|
|
- ./nginx/entrypoint.sh:/docker-entrypoint.d/entrypoint.sh
|
|
- ./nginx/snippets:/etc/nginx/snippets
|
|
- ./ssl/authorization.js:/etc/nginx/authorization.js
|
|
- ./ssl/certs/mainflux-server.crt:/etc/ssl/certs/mainflux-server.crt
|
|
- ./ssl/certs/ca.crt:/etc/ssl/certs/ca.crt
|
|
- ./ssl/certs/mainflux-server.key:/etc/ssl/private/mainflux-server.key
|
|
- ./ssl/dhparam.pem:/etc/ssl/certs/dhparam.pem
|
|
ports:
|
|
- ${MF_NGINX_HTTP_PORT}:${MF_NGINX_HTTP_PORT}
|
|
- ${MF_NGINX_SSL_PORT}:${MF_NGINX_SSL_PORT}
|
|
- ${MF_NGINX_MQTT_PORT}:${MF_NGINX_MQTT_PORT}
|
|
- ${MF_NGINX_MQTTS_PORT}:${MF_NGINX_MQTTS_PORT}
|
|
networks:
|
|
- mainflux-base-net
|
|
env_file:
|
|
- .env
|
|
depends_on:
|
|
- things
|
|
- users
|
|
- mqtt-adapter
|
|
- http-adapter
|
|
- ws-adapter
|
|
|
|
things-db:
|
|
image: postgres:13.3-alpine
|
|
container_name: mainflux-things-db
|
|
restart: on-failure
|
|
command: postgres -c "max_connections=${MF_POSTGRES_MAX_CONNECTIONS}"
|
|
environment:
|
|
POSTGRES_USER: ${MF_THINGS_DB_USER}
|
|
POSTGRES_PASSWORD: ${MF_THINGS_DB_PASS}
|
|
POSTGRES_DB: ${MF_THINGS_DB_NAME}
|
|
MF_POSTGRES_MAX_CONNECTIONS: ${MF_POSTGRES_MAX_CONNECTIONS}
|
|
networks:
|
|
- mainflux-base-net
|
|
ports:
|
|
- 6006:5432
|
|
volumes:
|
|
- mainflux-things-db-volume:/var/lib/postgresql/data
|
|
|
|
things-redis:
|
|
image: redis:6.2.2-alpine
|
|
container_name: mainflux-things-redis
|
|
restart: on-failure
|
|
networks:
|
|
- mainflux-base-net
|
|
volumes:
|
|
- mainflux-things-redis-volume:/data
|
|
|
|
things:
|
|
image: mainflux/things:${MF_RELEASE_TAG}
|
|
container_name: mainflux-things
|
|
depends_on:
|
|
- things-db
|
|
- users
|
|
restart: on-failure
|
|
environment:
|
|
MF_THINGS_LOG_LEVEL: ${MF_THINGS_LOG_LEVEL}
|
|
MF_THINGS_STANDALONE_ID: ${MF_THINGS_STANDALONE_ID}
|
|
MF_THINGS_STANDALONE_TOKEN: ${MF_THINGS_STANDALONE_TOKEN}
|
|
MF_THINGS_CACHE_KEY_DURATION: ${MF_THINGS_CACHE_KEY_DURATION}
|
|
MF_THINGS_HTTP_HOST: ${MF_THINGS_HTTP_HOST}
|
|
MF_THINGS_HTTP_PORT: ${MF_THINGS_HTTP_PORT}
|
|
MF_THINGS_AUTH_GRPC_HOST: ${MF_THINGS_AUTH_GRPC_HOST}
|
|
MF_THINGS_AUTH_GRPC_PORT: ${MF_THINGS_AUTH_GRPC_PORT}
|
|
## Compose supports parameter expansion in environment,
|
|
## Eg: ${VAR:+replacement} or ${VAR+replacement} -> replacement if VAR is set and non-empty, otherwise empty
|
|
## Eg :${VAR:-default} or ${VAR-default} -> value of VAR if set and non-empty, otherwise default
|
|
MF_THINGS_AUTH_GRPC_SERVER_CERT: ${MF_THINGS_AUTH_GRPC_SERVER_CERT:+/things-grpc-server.crt}
|
|
MF_THINGS_AUTH_GRPC_SERVER_KEY: ${MF_THINGS_AUTH_GRPC_SERVER_KEY:+/things-grpc-server.key}
|
|
MF_THINGS_AUTH_GRPC_SERVER_CA_CERTS: ${MF_THINGS_AUTH_GRPC_SERVER_CA_CERTS:+/things-grpc-server-ca.crt}
|
|
MF_THINGS_AUTH_GRPC_CLIENT_CA_CERTS: ${MF_THINGS_AUTH_GRPC_CLIENT_CA_CERTS:+/things-grpc-client-ca.crt}
|
|
MF_THINGS_ES_URL: ${MF_ES_STORE_URL}
|
|
MF_THINGS_CACHE_URL: ${MF_THINGS_CACHE_URL}
|
|
MF_THINGS_DB_HOST: ${MF_THINGS_DB_HOST}
|
|
MF_THINGS_DB_PORT: ${MF_THINGS_DB_PORT}
|
|
MF_THINGS_DB_USER: ${MF_THINGS_DB_USER}
|
|
MF_THINGS_DB_PASS: ${MF_THINGS_DB_PASS}
|
|
MF_THINGS_DB_NAME: ${MF_THINGS_DB_NAME}
|
|
MF_THINGS_DB_SSL_MODE: ${MF_THINGS_DB_SSL_MODE}
|
|
MF_THINGS_DB_SSL_CERT: ${MF_THINGS_DB_SSL_CERT}
|
|
MF_THINGS_DB_SSL_KEY: ${MF_THINGS_DB_SSL_KEY}
|
|
MF_THINGS_DB_SSL_ROOT_CERT: ${MF_THINGS_DB_SSL_ROOT_CERT}
|
|
MF_AUTH_GRPC_URL: ${MF_AUTH_GRPC_URL}
|
|
MF_AUTH_GRPC_TIMEOUT: ${MF_AUTH_GRPC_TIMEOUT}
|
|
MF_AUTH_GRPC_CLIENT_CERT: ${MF_AUTH_GRPC_CLIENT_CERT:+/users-grpc-client.crt}
|
|
MF_AUTH_GRPC_CLIENT_KEY: ${MF_AUTH_GRPC_CLIENT_KEY:+/users-grpc-client.key}
|
|
MF_AUTH_GRPC_SERVER_CA_CERTS: ${MF_AUTH_GRPC_SERVER_CA_CERTS:+/users-grpc-server-ca.crt}
|
|
MF_JAEGER_URL: ${MF_JAEGER_URL}
|
|
MF_JAEGER_TRACE_RATIO: ${MF_JAEGER_TRACE_RATIO}
|
|
MF_SEND_TELEMETRY: ${MF_SEND_TELEMETRY}
|
|
ports:
|
|
- ${MF_THINGS_HTTP_PORT}:${MF_THINGS_HTTP_PORT}
|
|
- ${MF_THINGS_AUTH_GRPC_PORT}:${MF_THINGS_AUTH_GRPC_PORT}
|
|
networks:
|
|
- mainflux-base-net
|
|
volumes:
|
|
# Things gRPC server certificates
|
|
- type: bind
|
|
source: ${MF_THINGS_AUTH_GRPC_SERVER_CERT:-ssl/certs/dummy/server_cert}
|
|
target: /things-grpc-server${MF_THINGS_AUTH_GRPC_SERVER_CERT:+.crt}
|
|
bind:
|
|
create_host_path: true
|
|
- type: bind
|
|
source: ${MF_THINGS_AUTH_GRPC_SERVER_KEY:-ssl/certs/dummy/server_key}
|
|
target: /things-grpc-server${MF_THINGS_AUTH_GRPC_SERVER_KEY:+.key}
|
|
bind:
|
|
create_host_path: true
|
|
- type: bind
|
|
source: ${MF_THINGS_AUTH_GRPC_SERVER_CA_CERTS:-ssl/certs/dummy/server_ca_certs}
|
|
target: /things-grpc-server-ca${MF_THINGS_AUTH_GRPC_SERVER_CA_CERTS:+.crt}
|
|
bind:
|
|
create_host_path: true
|
|
- type: bind
|
|
source: ${MF_THINGS_AUTH_GRPC_CLIENT_CA_CERTS:-ssl/certs/dummy/client_ca_certs}
|
|
target: /things-grpc-client-ca${MF_THINGS_AUTH_GRPC_CLIENT_CA_CERTS:+.crt}
|
|
bind:
|
|
create_host_path: true
|
|
# Users gRPC client certificates
|
|
- type: bind
|
|
source: ${MF_USERS_GRPC_CLIENT_CERT:-ssl/certs/dummy/client_cert}
|
|
target: /users-grpc-client${MF_USERS_GRPC_CLIENT_CERT:+.crt}
|
|
bind:
|
|
create_host_path: true
|
|
- type: bind
|
|
source: ${MF_USERS_GRPC_CLIENT_KEY:-ssl/certs/dummy/client_key}
|
|
target: /users-grpc-client${MF_USERS_GRPC_CLIENT_KEY:+.key}
|
|
bind:
|
|
create_host_path: true
|
|
- type: bind
|
|
source: ${MF_USERS_GRPC_SERVER_CA_CERTS:-ssl/certs/dummy/server_ca}
|
|
target: /users-grpc-server-ca${MF_USERS_GRPC_SERVER_CA_CERTS:+.crt}
|
|
bind:
|
|
create_host_path: true
|
|
|
|
users-db:
|
|
image: postgres:15.1-alpine
|
|
container_name: mainflux-users-db
|
|
restart: on-failure
|
|
command: postgres -c "max_connections=${MF_POSTGRES_MAX_CONNECTIONS}"
|
|
environment:
|
|
POSTGRES_USER: ${MF_USERS_DB_USER}
|
|
POSTGRES_PASSWORD: ${MF_USERS_DB_PASS}
|
|
POSTGRES_DB: ${MF_USERS_DB_NAME}
|
|
MF_POSTGRES_MAX_CONNECTIONS: ${MF_POSTGRES_MAX_CONNECTIONS}
|
|
networks:
|
|
- mainflux-base-net
|
|
volumes:
|
|
- mainflux-users-db-volume:/var/lib/postgresql/data
|
|
|
|
users:
|
|
image: mainflux/users:${MF_RELEASE_TAG}
|
|
container_name: mainflux-users
|
|
depends_on:
|
|
- users-db
|
|
restart: on-failure
|
|
environment:
|
|
MF_USERS_LOG_LEVEL: ${MF_USERS_LOG_LEVEL}
|
|
MF_USERS_SECRET_KEY: ${MF_USERS_SECRET_KEY}
|
|
MF_USERS_ADMIN_EMAIL: ${MF_USERS_ADMIN_EMAIL}
|
|
MF_USERS_ADMIN_PASSWORD: ${MF_USERS_ADMIN_PASSWORD}
|
|
MF_USERS_PASS_REGEX: ${MF_USERS_PASS_REGEX}
|
|
MF_USERS_ACCESS_TOKEN_DURATION: ${MF_USERS_ACCESS_TOKEN_DURATION}
|
|
MF_USERS_REFRESH_TOKEN_DURATION: ${MF_USERS_REFRESH_TOKEN_DURATION}
|
|
MF_TOKEN_RESET_ENDPOINT: ${MF_TOKEN_RESET_ENDPOINT}
|
|
MF_USERS_HTTP_HOST: ${MF_USERS_HTTP_HOST}
|
|
MF_USERS_HTTP_PORT: ${MF_USERS_HTTP_PORT}
|
|
MF_USERS_HTTP_SERVER_CERT: ${MF_USERS_HTTP_SERVER_CERT}
|
|
MF_USERS_HTTP_SERVER_KEY: ${MF_USERS_HTTP_SERVER_KEY}
|
|
MF_USERS_GRPC_HOST: ${MF_USERS_GRPC_HOST}
|
|
MF_USERS_GRPC_PORT: ${MF_USERS_GRPC_PORT}
|
|
MF_USERS_GRPC_SERVER_CERT: ${MF_USERS_GRPC_SERVER_CERT:+/users-grpc-server.crt}
|
|
MF_USERS_GRPC_SERVER_KEY: ${MF_USERS_GRPC_SERVER_KEY:+/users-grpc-server.key}
|
|
MF_USERS_GRPC_SERVER_CA_CERTS: ${MF_USERS_GRPC_SERVER_CA_CERTS:+/users-grpc-server-ca.crt}
|
|
MF_USERS_GRPC_CLIENT_CA_CERTS: ${MF_USERS_GRPC_CLIENT_CA_CERTS:+/users-grpc-client-ca.crt}
|
|
MF_USERS_DB_HOST: ${MF_USERS_DB_HOST}
|
|
MF_USERS_DB_PORT: ${MF_USERS_DB_PORT}
|
|
MF_USERS_DB_USER: ${MF_USERS_DB_USER}
|
|
MF_USERS_DB_PASS: ${MF_USERS_DB_PASS}
|
|
MF_USERS_DB_NAME: ${MF_USERS_DB_NAME}
|
|
MF_USERS_DB_SSL_MODE: ${MF_USERS_DB_SSL_MODE}
|
|
MF_USERS_DB_SSL_CERT: ${MF_USERS_DB_SSL_CERT}
|
|
MF_USERS_DB_SSL_KEY: ${MF_USERS_DB_SSL_KEY}
|
|
MF_USERS_DB_SSL_ROOT_CERT: ${MF_USERS_DB_SSL_ROOT_CERT}
|
|
MF_EMAIL_HOST: ${MF_EMAIL_HOST}
|
|
MF_EMAIL_PORT: ${MF_EMAIL_PORT}
|
|
MF_EMAIL_USERNAME: ${MF_EMAIL_USERNAME}
|
|
MF_EMAIL_PASSWORD: ${MF_EMAIL_PASSWORD}
|
|
MF_EMAIL_FROM_ADDRESS: ${MF_EMAIL_FROM_ADDRESS}
|
|
MF_EMAIL_FROM_NAME: ${MF_EMAIL_FROM_NAME}
|
|
MF_EMAIL_TEMPLATE: ${MF_EMAIL_TEMPLATE}
|
|
MF_USERS_ES_URL: ${MF_ES_STORE_URL}
|
|
MF_JAEGER_URL: ${MF_JAEGER_URL}
|
|
MF_JAEGER_TRACE_RATIO: ${MF_JAEGER_TRACE_RATIO}
|
|
MF_SEND_TELEMETRY: ${MF_SEND_TELEMETRY}
|
|
MF_AUTH_GRPC_URL: ${MF_AUTH_GRPC_URL}
|
|
MF_AUTH_GRPC_TIMEOUT: ${MF_AUTH_GRPC_TIMEOUT}
|
|
ports:
|
|
- ${MF_USERS_HTTP_PORT}:${MF_USERS_HTTP_PORT}
|
|
- ${MF_USERS_GRPC_PORT}:${MF_USERS_GRPC_PORT}
|
|
networks:
|
|
- mainflux-base-net
|
|
volumes:
|
|
- ./templates/${MF_USERS_RESET_PWD_TEMPLATE}:/email.tmpl
|
|
# Users gRPC mTLS server certificates
|
|
- type: bind
|
|
source: ${MF_USERS_GRPC_SERVER_CERT:-ssl/certs/dummy/server_cert}
|
|
target: /users-grpc-server${MF_USERS_GRPC_SERVER_CERT:+.crt}
|
|
bind:
|
|
create_host_path: true
|
|
- type: bind
|
|
source: ${MF_USERS_GRPC_SERVER_KEY:-ssl/certs/dummy/server_key}
|
|
target: /users-grpc-server${MF_USERS_GRPC_SERVER_KEY:+.key}
|
|
bind:
|
|
create_host_path: true
|
|
- type: bind
|
|
source: ${MF_USERS_GRPC_SERVER_CA_CERTS:-ssl/certs/dummy/server_ca_certs}
|
|
target: /users-grpc-server-ca${MF_USERS_GRPC_SERVER_CA_CERTS:+.crt}
|
|
bind:
|
|
create_host_path: true
|
|
- type: bind
|
|
source: ${MF_USERS_GRPC_CLIENT_CA_CERTS:-ssl/certs/dummy/client_ca_certs}
|
|
target: /users-grpc-client-ca${MF_USERS_GRPC_CLIENT_CA_CERTS:+.crt}
|
|
bind:
|
|
create_host_path: true
|
|
|
|
jaeger:
|
|
image: jaegertracing/all-in-one:1.38.0
|
|
container_name: mainflux-jaeger
|
|
ports:
|
|
- ${MF_JAEGER_PORT}:${MF_JAEGER_PORT}/udp
|
|
- ${MF_JAEGER_FRONTEND}:${MF_JAEGER_FRONTEND}
|
|
- ${MF_JAEGER_COLLECTOR}:${MF_JAEGER_COLLECTOR}
|
|
- ${MF_JAEGER_CONFIGS}:${MF_JAEGER_CONFIGS}
|
|
networks:
|
|
- mainflux-base-net
|
|
|
|
mqtt-adapter:
|
|
image: mainflux/mqtt:${MF_RELEASE_TAG}
|
|
container_name: mainflux-mqtt
|
|
depends_on:
|
|
- things
|
|
- nats
|
|
restart: on-failure
|
|
environment:
|
|
MF_MQTT_ADAPTER_LOG_LEVEL: ${MF_MQTT_ADAPTER_LOG_LEVEL}
|
|
MF_MQTT_ADAPTER_MQTT_PORT: ${MF_MQTT_ADAPTER_MQTT_PORT}
|
|
MF_MQTT_ADAPTER_MQTT_TARGET_HOST: ${MF_MQTT_ADAPTER_MQTT_TARGET_HOST}
|
|
MF_MQTT_ADAPTER_MQTT_TARGET_PORT: ${MF_MQTT_ADAPTER_MQTT_TARGET_PORT}
|
|
MF_MQTT_ADAPTER_FORWARDER_TIMEOUT: ${MF_MQTT_ADAPTER_FORWARDER_TIMEOUT}
|
|
MF_MQTT_ADAPTER_MQTT_TARGET_HEALTH_CHECK: ${MF_MQTT_ADAPTER_MQTT_TARGET_HEALTH_CHECK}
|
|
MF_MQTT_ADAPTER_WS_PORT: ${MF_MQTT_ADAPTER_WS_PORT}
|
|
MF_MQTT_ADAPTER_INSTANCE_ID: ${MF_MQTT_ADAPTER_INSTANCE_ID}
|
|
MF_MQTT_ADAPTER_WS_TARGET_HOST: ${MF_MQTT_ADAPTER_WS_TARGET_HOST}
|
|
MF_MQTT_ADAPTER_WS_TARGET_PORT: ${MF_MQTT_ADAPTER_WS_TARGET_PORT}
|
|
MF_MQTT_ADAPTER_WS_TARGET_PATH: ${MF_MQTT_ADAPTER_WS_TARGET_PATH}
|
|
MF_MQTT_ADAPTER_INSTANCE: ${MF_MQTT_ADAPTER_INSTANCE}
|
|
MF_MQTT_ADAPTER_ES_URL: ${MF_ES_STORE_URL}
|
|
MF_THINGS_AUTH_GRPC_URL: ${MF_THINGS_AUTH_GRPC_URL}
|
|
MF_THINGS_AUTH_GRPC_TIMEOUT: ${MF_THINGS_AUTH_GRPC_TIMEOUT}
|
|
MF_THINGS_AUTH_GRPC_CLIENT_CERT: ${MF_THINGS_AUTH_GRPC_CLIENT_CERT:+/things-grpc-client.crt}
|
|
MF_THINGS_AUTH_GRPC_CLIENT_KEY: ${MF_THINGS_AUTH_GRPC_CLIENT_KEY:+/things-grpc-client.key}
|
|
MF_THINGS_AUTH_GRPC_SERVER_CA_CERTS: ${MF_THINGS_AUTH_GRPC_SERVER_CA_CERTS:+/things-grpc-server-ca.crt}
|
|
MF_JAEGER_URL: ${MF_JAEGER_URL}
|
|
MF_MESSAGE_BROKER_URL: ${MF_MESSAGE_BROKER_URL}
|
|
MF_JAEGER_TRACE_RATIO: ${MF_JAEGER_TRACE_RATIO}
|
|
MF_SEND_TELEMETRY: ${MF_SEND_TELEMETRY}
|
|
networks:
|
|
- mainflux-base-net
|
|
volumes:
|
|
# Things gRPC mTLS client certificates
|
|
- type: bind
|
|
source: ${MF_THINGS_AUTH_GRPC_CLIENT_CERT:-ssl/certs/dummy/client_cert}
|
|
target: /client${MF_THINGS_AUTH_GRPC_CLIENT_CERT:+.crt}
|
|
bind:
|
|
create_host_path: true
|
|
- type: bind
|
|
source: ${MF_THINGS_AUTH_GRPC_CLIENT_KEY:-ssl/certs/dummy/client_key}
|
|
target: /client${MF_THINGS_AUTH_GRPC_CLIENT_KEY:+.key}
|
|
bind:
|
|
create_host_path: true
|
|
- type: bind
|
|
source: ${MF_THINGS_AUTH_GRPC_SERVER_CA_CERTS:-ssl/certs/dummy/server_ca}
|
|
target: /server_ca${MF_THINGS_AUTH_GRPC_SERVER_CA_CERTS:+.crt}
|
|
bind:
|
|
create_host_path: true
|
|
|
|
http-adapter:
|
|
image: mainflux/http:${MF_RELEASE_TAG}
|
|
container_name: mainflux-http
|
|
depends_on:
|
|
- things
|
|
- nats
|
|
restart: on-failure
|
|
environment:
|
|
MF_HTTP_ADAPTER_LOG_LEVEL: ${MF_HTTP_ADAPTER_LOG_LEVEL}
|
|
MF_HTTP_ADAPTER_HOST: ${MF_HTTP_ADAPTER_HOST}
|
|
MF_HTTP_ADAPTER_PORT: ${MF_HTTP_ADAPTER_PORT}
|
|
MF_HTTP_ADAPTER_SERVER_CERT: ${MF_HTTP_ADAPTER_SERVER_CERT}
|
|
MF_HTTP_ADAPTER_SERVER_KEY: ${MF_HTTP_ADAPTER_SERVER_KEY}
|
|
MF_THINGS_AUTH_GRPC_URL: ${MF_THINGS_AUTH_GRPC_URL}
|
|
MF_THINGS_AUTH_GRPC_TIMEOUT: ${MF_THINGS_AUTH_GRPC_TIMEOUT}
|
|
MF_THINGS_AUTH_GRPC_CLIENT_CERT: ${MF_THINGS_AUTH_GRPC_CLIENT_CERT:+/things-grpc-client.crt}
|
|
MF_THINGS_AUTH_GRPC_CLIENT_KEY: ${MF_THINGS_AUTH_GRPC_CLIENT_KEY:+/things-grpc-client.key}
|
|
MF_THINGS_AUTH_GRPC_SERVER_CA_CERTS: ${MF_THINGS_AUTH_GRPC_SERVER_CA_CERTS:+/things-grpc-server-ca.crt}
|
|
MF_MESSAGE_BROKER_URL: ${MF_MESSAGE_BROKER_URL}
|
|
MF_JAEGER_URL: ${MF_JAEGER_URL}
|
|
MF_JAEGER_TRACE_RATIO: ${MF_JAEGER_TRACE_RATIO}
|
|
MF_SEND_TELEMETRY: ${MF_SEND_TELEMETRY}
|
|
MF_HTTP_ADAPTER_INSTANCE_ID: ${MF_HTTP_ADAPTER_INSTANCE_ID}
|
|
ports:
|
|
- ${MF_HTTP_ADAPTER_PORT}:${MF_HTTP_ADAPTER_PORT}
|
|
networks:
|
|
- mainflux-base-net
|
|
volumes:
|
|
# Things gRPC mTLS client certificates
|
|
- type: bind
|
|
source: ${MF_THINGS_AUTH_GRPC_CLIENT_CERT:-ssl/certs/dummy/client_cert}
|
|
target: /client${MF_THINGS_AUTH_GRPC_CLIENT_CERT:+.crt}
|
|
bind:
|
|
create_host_path: true
|
|
- type: bind
|
|
source: ${MF_THINGS_AUTH_GRPC_CLIENT_KEY:-ssl/certs/dummy/client_key}
|
|
target: /client${MF_THINGS_AUTH_GRPC_CLIENT_KEY:+.key}
|
|
bind:
|
|
create_host_path: true
|
|
- type: bind
|
|
source: ${MF_THINGS_AUTH_GRPC_SERVER_CA_CERTS:-ssl/certs/dummy/server_ca}
|
|
target: /server_ca${MF_THINGS_AUTH_GRPC_SERVER_CA_CERTS:+.crt}
|
|
bind:
|
|
create_host_path: true
|
|
|
|
coap-adapter:
|
|
image: mainflux/coap:${MF_RELEASE_TAG}
|
|
container_name: mainflux-coap
|
|
depends_on:
|
|
- things
|
|
- nats
|
|
restart: on-failure
|
|
environment:
|
|
MF_COAP_ADAPTER_LOG_LEVEL: ${MF_COAP_ADAPTER_LOG_LEVEL}
|
|
MF_COAP_ADAPTER_HOST: ${MF_COAP_ADAPTER_HOST}
|
|
MF_COAP_ADAPTER_PORT: ${MF_COAP_ADAPTER_PORT}
|
|
MF_COAP_ADAPTER_SERVER_CERT: ${MF_COAP_ADAPTER_SERVER_CERT}
|
|
MF_COAP_ADAPTER_SERVER_KEY: ${MF_COAP_ADAPTER_SERVER_KEY}
|
|
MF_COAP_ADAPTER_HTTP_HOST: ${MF_COAP_ADAPTER_HTTP_HOST}
|
|
MF_COAP_ADAPTER_HTTP_PORT: ${MF_COAP_ADAPTER_HTTP_PORT}
|
|
MF_COAP_ADAPTER_HTTP_SERVER_CERT: ${MF_COAP_ADAPTER_HTTP_SERVER_CERT}
|
|
MF_COAP_ADAPTER_HTTP_SERVER_KEY: ${MF_COAP_ADAPTER_HTTP_SERVER_KEY}
|
|
MF_THINGS_AUTH_GRPC_URL: ${MF_THINGS_AUTH_GRPC_URL}
|
|
MF_THINGS_AUTH_GRPC_TIMEOUT: ${MF_THINGS_AUTH_GRPC_TIMEOUT}
|
|
MF_THINGS_AUTH_GRPC_CLIENT_CERT: ${MF_THINGS_AUTH_GRPC_CLIENT_CERT:+/things-grpc-client.crt}
|
|
MF_THINGS_AUTH_GRPC_CLIENT_KEY: ${MF_THINGS_AUTH_GRPC_CLIENT_KEY:+/things-grpc-client.key}
|
|
MF_THINGS_AUTH_GRPC_SERVER_CA_CERTS: ${MF_THINGS_AUTH_GRPC_SERVER_CA_CERTS:+/things-grpc-server-ca.crt}
|
|
MF_MESSAGE_BROKER_URL: ${MF_MESSAGE_BROKER_URL}
|
|
MF_JAEGER_URL: ${MF_JAEGER_URL}
|
|
MF_JAEGER_TRACE_RATIO: ${MF_JAEGER_TRACE_RATIO}
|
|
MF_SEND_TELEMETRY: ${MF_SEND_TELEMETRY}
|
|
MF_COAP_ADAPTER_INSTANCE_ID: ${MF_COAP_ADAPTER_INSTANCE_ID}
|
|
ports:
|
|
- ${MF_COAP_ADAPTER_PORT}:${MF_COAP_ADAPTER_PORT}/udp
|
|
- ${MF_COAP_ADAPTER_HTTP_PORT}:${MF_COAP_ADAPTER_HTTP_PORT}/tcp
|
|
networks:
|
|
- mainflux-base-net
|
|
volumes:
|
|
## Things gRPC mTLS client certificates
|
|
- type: bind
|
|
source: ${MF_THINGS_AUTH_GRPC_CLIENT_CERT:-ssl/certs/dummy/client_cert}
|
|
target: /client${MF_THINGS_AUTH_GRPC_CLIENT_CERT:+.crt}
|
|
bind:
|
|
create_host_path: true
|
|
- type: bind
|
|
source: ${MF_THINGS_AUTH_GRPC_CLIENT_KEY:-ssl/certs/dummy/client_key}
|
|
target: /client${MF_THINGS_AUTH_GRPC_CLIENT_KEY:+.key}
|
|
bind:
|
|
create_host_path: true
|
|
- type: bind
|
|
source: ${MF_THINGS_AUTH_GRPC_SERVER_CA_CERTS:-ssl/certs/dummy/server_ca}
|
|
target: /server_ca${MF_THINGS_AUTH_GRPC_SERVER_CA_CERTS:+.crt}
|
|
bind:
|
|
create_host_path: true
|
|
|
|
ws-adapter:
|
|
image: mainflux/ws:${MF_RELEASE_TAG}
|
|
container_name: mainflux-ws
|
|
depends_on:
|
|
- things
|
|
- nats
|
|
restart: on-failure
|
|
environment:
|
|
MF_WS_ADAPTER_LOG_LEVEL: ${MF_WS_ADAPTER_LOG_LEVEL}
|
|
MF_WS_ADAPTER_HTTP_HOST: ${MF_WS_ADAPTER_HTTP_HOST}
|
|
MF_WS_ADAPTER_HTTP_PORT: ${MF_WS_ADAPTER_HTTP_PORT}
|
|
MF_WS_ADAPTER_HTTP_SERVER_CERT: ${MF_WS_ADAPTER_HTTP_SERVER_CERT}
|
|
MF_WS_ADAPTER_HTTP_SERVER_KEY: ${MF_WS_ADAPTER_HTTP_SERVER_KEY}
|
|
MF_THINGS_AUTH_GRPC_URL: ${MF_THINGS_AUTH_GRPC_URL}
|
|
MF_THINGS_AUTH_GRPC_TIMEOUT: ${MF_THINGS_AUTH_GRPC_TIMEOUT}
|
|
MF_THINGS_AUTH_GRPC_CLIENT_CERT: ${MF_THINGS_AUTH_GRPC_CLIENT_CERT:+/things-grpc-client.crt}
|
|
MF_THINGS_AUTH_GRPC_CLIENT_KEY: ${MF_THINGS_AUTH_GRPC_CLIENT_KEY:+/things-grpc-client.key}
|
|
MF_THINGS_AUTH_GRPC_SERVER_CA_CERTS: ${MF_THINGS_AUTH_GRPC_SERVER_CA_CERTS:+/things-grpc-server-ca.crt}
|
|
MF_MESSAGE_BROKER_URL: ${MF_MESSAGE_BROKER_URL}
|
|
MF_JAEGER_URL: ${MF_JAEGER_URL}
|
|
MF_JAEGER_TRACE_RATIO: ${MF_JAEGER_TRACE_RATIO}
|
|
MF_SEND_TELEMETRY: ${MF_SEND_TELEMETRY}
|
|
MF_WS_ADAPTER_INSTANCE_ID: ${MF_WS_ADAPTER_INSTANCE_ID}
|
|
ports:
|
|
- ${MF_WS_ADAPTER_HTTP_PORT}:${MF_WS_ADAPTER_HTTP_PORT}
|
|
networks:
|
|
- mainflux-base-net
|
|
volumes:
|
|
# Things gRPC mTLS client certificates
|
|
- type: bind
|
|
source: ${MF_THINGS_AUTH_GRPC_CLIENT_CERT:-ssl/certs/dummy/client_cert}
|
|
target: /client${MF_THINGS_AUTH_GRPC_CLIENT_CERT:+.crt}
|
|
bind:
|
|
create_host_path: true
|
|
- type: bind
|
|
source: ${MF_THINGS_AUTH_GRPC_CLIENT_KEY:-ssl/certs/dummy/client_key}
|
|
target: /client${MF_THINGS_AUTH_GRPC_CLIENT_KEY:+.key}
|
|
bind:
|
|
create_host_path: true
|
|
- type: bind
|
|
source: ${MF_THINGS_AUTH_GRPC_SERVER_CA_CERTS:-ssl/certs/dummy/server_ca}
|
|
target: /server_ca${MF_THINGS_AUTH_GRPC_SERVER_CA_CERTS:+.crt}
|
|
bind:
|
|
create_host_path: true
|