Merge "[BUG] Retry interval for kafka consumer"
[cps.git] / docker-compose / docker-compose.yml
1 # ============LICENSE_START=======================================================
2 # Copyright (c) 2020 Pantheon.tech.
3 # Modifications Copyright (C) 2021 Bell Canada.
4 # Modifications Copyright (C) 2022-2024 Nordix Foundation.
5 # ================================================================================
6 # Licensed under the Apache License, Version 2.0 (the "License");
7 # you may not use this file except in compliance with the License.
8 # You may obtain a copy of the License at
9 #
10 #       http://www.apache.org/licenses/LICENSE-2.0
11 #
12 # Unless required by applicable law or agreed to in writing, software
13 # distributed under the License is distributed on an "AS IS" BASIS,
14 # WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
15 # See the License for the specific language governing permissions and
16 # limitations under the License.
17 # ============LICENSE_END=========================================================
18
19 services:
20
21   ### docker-compose --profile dmi-service up -d -> run CPS services incl. dmi-plugin ###
22   ### docker-compose --profile dmi-stub --profile monitoring up -d -> run CPS with stubbed dmi-plugin (for registration performance testing)
23   ### to disable notifications make notification.enabled to false & comment out kafka/zookeeper services ###
24
25   dbpostgresql:
26     container_name: dbpostgresql
27     image: postgres:14.1-alpine
28     ports:
29       - ${DB_PORT:-5432}:5432
30     environment:
31       POSTGRES_DB: cpsdb
32       POSTGRES_USER: ${DB_USERNAME:-cps}
33       POSTGRES_PASSWORD: ${DB_PASSWORD:-cps}
34     deploy:
35       resources:
36         reservations:
37           cpus: '1'
38           memory: 1G
39         limits:
40           cpus: '6'
41           memory: 3G
42
43   cps-and-ncmp:
44     container_name: cps-and-ncmp
45     image: ${DOCKER_REPO:-nexus3.onap.org:10003}/onap/cps-and-ncmp:${CPS_VERSION:-latest}
46     ports:
47       - ${CPS_CORE_PORT:-8883}:8080
48       - ${CPS_CORE_DEBUG_PORT:-5005}:5005
49     environment:
50       CPS_USERNAME: ${CPS_CORE_USERNAME:-cpsuser}
51       CPS_PASSWORD: ${CPS_CORE_PASSWORD:-cpsr0cks!}
52       DB_HOST: ${DB_HOST:-dbpostgresql}
53       DB_USERNAME: ${DB_USERNAME:-cps}
54       DB_PASSWORD: ${DB_PASSWORD:-cps}
55       DMI_USERNAME: ${DMI_USERNAME:-cpsuser}
56       DMI_PASSWORD: ${DMI_PASSWORD:-cpsr0cks!}
57       KAFKA_BOOTSTRAP_SERVER: kafka:29092
58       notification.enabled: 'true'
59       notification.async.executor.time-out-value-in-ms: 2000
60       NCMP_TIMERS_ADVISED-MODULES-SYNC_SLEEP-TIME-MS: ${ADVISED_MODULES_SYNC_SLEEP_TIME_MS:-30000}
61       NCMP_TIMERS_CM-HANDLE-DATA-SYNC_SLEEP-TIME-MS: ${CMHANDLE_DATA_SYNC_SLEEP_TIME_MS:-30000}
62       JAVA_TOOL_OPTIONS: -agentlib:jdwp=transport=dt_socket,server=y,suspend=n,address=*:5005
63     restart: unless-stopped
64     depends_on:
65       - dbpostgresql
66     deploy:
67       resources:
68         reservations:
69           cpus: '2'
70           memory: 2G
71         limits:
72           cpus: '3'
73           memory: 3G
74
75   ### if kafka is not required comment out zookeeper and kafka ###
76   zookeeper:
77     image: confluentinc/cp-zookeeper:6.2.1
78     container_name: zookeeper
79     ports:
80       - '2181:2181'
81     environment:
82       ZOOKEEPER_CLIENT_PORT: 2181
83
84   kafka:
85     image: confluentinc/cp-kafka:6.2.1
86     container_name: kafka
87     ports:
88       - '9092:9092'
89     depends_on:
90       - zookeeper
91     environment:
92       KAFKA_BROKER_ID: 1
93       KAFKA_ZOOKEEPER_CONNECT: zookeeper:2181
94       KAFKA_LISTENER_SECURITY_PROTOCOL_MAP: PLAINTEXT:PLAINTEXT,CONNECTIONS_FROM_HOST:PLAINTEXT
95       KAFKA_ADVERTISED_LISTENERS: PLAINTEXT://kafka:29092,CONNECTIONS_FROM_HOST://localhost:9092
96       KAFKA_OFFSETS_TOPIC_REPLICATION_FACTOR: 1
97
98   ncmp-dmi-plugin:
99     container_name: ncmp-dmi-plugin
100     image: ${DOCKER_REPO:-nexus3.onap.org:10003}/onap/ncmp-dmi-plugin:${DMI_VERSION:-1.5.0-SNAPSHOT-latest}
101     ports:
102       - ${DMI_PORT:-8783}:8080
103     environment:
104       CPS_USERNAME: ${CPS_CORE_USERNAME:-cpsuser}
105       CPS_PASSWORD: ${CPS_CORE_PASSWORD:-cpsr0cks!}
106       CPS_CORE_HOST: ${CPS_CORE_HOST:-cps-and-ncmp}
107       CPS_CORE_PORT: ${CPS_CORE_PORT:-8080}
108       CPS_CORE_USERNAME: ${CPS_CORE_USERNAME:-cpsuser}
109       CPS_CORE_PASSWORD: ${CPS_CORE_PASSWORD:-cpsr0cks!}
110       SDNC_HOST: ${SDNC_HOST:-sdnc}
111       SDNC_PORT: ${SDNC_PORT:-8181}
112       SDNC_USERNAME: ${SDNC_USERNAME:-admin}
113       SDNC_PASSWORD: ${SDNC_PASSWORD:-Kp8bJ4SXszM0WXlhak3eHlcse2gAw84vaoGGmJvUy2U}
114       DMI_SERVICE_URL: ${DMI_SERVICE_URL:-http://ncmp-dmi-plugin:8783}
115       DMI_SERVICE_NAME: ${DMI_SERVICE_NAME:-dminame1}
116       DMI_USERNAME: ${DMI_USERNAME:-cpsuser}
117       DMI_PASSWORD: ${DMI_PASSWORD:-cpsr0cks!}
118       KAFKA_BOOTSTRAP_SERVER: kafka:29092
119     restart: unless-stopped
120     profiles:
121       - dmi-service
122
123   ncmp-dmi-plugin-demo-and-csit-stub:
124     container_name: ncmp-dmi-plugin-demo-and-csit-stub
125     image: ${DOCKER_REPO:-nexus3.onap.org:10003}/onap/dmi-plugin-demo-and-csit-stub:${DMI_DEMO_STUB_VERSION:-latest}
126     ports:
127       - ${DMI_DEMO_STUB_PORT:-8784}:8092
128     environment:
129       KAFKA_BOOTSTRAP_SERVER: kafka:29092
130       NCMP_CONSUMER_GROUP_ID: ncmp-group
131       NCMP_ASYNC_M2M_TOPIC: ncmp-async-m2m
132     restart: unless-stopped
133     profiles:
134       - dmi-stub
135       - dmi-service
136
137   prometheus:
138     container_name: prometheus-container
139     image: prom/prometheus:latest
140     ports:
141       - 9090:9090
142     restart: always
143     volumes:
144       - ./prometheus.yml:/etc/prometheus/prometheus.yml
145     profiles:
146       - monitoring
147
148   grafana:
149     image: grafana/grafana-oss:latest
150     user: ""
151     container_name: grafana-container
152     depends_on:
153       prometheus:
154         condition: service_started
155     ports:
156       - 3000:3000
157     volumes:
158       - grafana:/var/lib/grafana
159     environment:
160       - GF_SECURITY_ADMIN_PASSWORD=admin
161       - GF_SERVER_DOMAIN:localhost
162     profiles:
163       - monitoring
164
165 volumes:
166   grafana: