docker-compose.yml 5.1 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174
  1. version: '3'
  2. services:
  3. # Frontend
  4. web:
  5. image: jitsi/web
  6. volumes:
  7. - ${CONFIG}/web:/config
  8. - ${CONFIG}/web/letsencrypt:/etc/letsencrypt
  9. - ${CONFIG}/transcripts:/usr/share/jitsi-meet/transcripts
  10. environment:
  11. - ENABLE_AUTH
  12. - ENABLE_GUESTS
  13. - ENABLE_LETSENCRYPT
  14. - ENABLE_HTTP_REDIRECT
  15. - ENABLE_TRANSCRIPTIONS
  16. - DISABLE_HTTPS
  17. - JICOFO_AUTH_USER
  18. - LETSENCRYPT_DOMAIN
  19. - LETSENCRYPT_EMAIL
  20. - PUBLIC_URL
  21. - XMPP_DOMAIN
  22. - XMPP_AUTH_DOMAIN
  23. - XMPP_BOSH_URL_BASE
  24. - XMPP_GUEST_DOMAIN
  25. - XMPP_MUC_DOMAIN
  26. - XMPP_RECORDER_DOMAIN
  27. - ETHERPAD_URL_BASE
  28. - TZ
  29. - JIBRI_BREWERY_MUC
  30. - JIBRI_PENDING_TIMEOUT
  31. - JIBRI_XMPP_USER
  32. - JIBRI_XMPP_PASSWORD
  33. - JIBRI_RECORDER_USER
  34. - JIBRI_RECORDER_PASSWORD
  35. - ENABLE_RECORDING
  36. networks:
  37. # traefik: change the following line to your external docker network
  38. web:
  39. meet.jitsi:
  40. aliases:
  41. - ${XMPP_DOMAIN}
  42. labels:
  43. traefik.http.middlewares.redirect.redirectscheme.scheme: https
  44. traefik.http.routers.app-http.entrypoints: web
  45. traefik.http.routers.app-http.middlewares: redirect
  46. traefik.http.routers.app-http.rule: 'Host(`your.host.name`)'
  47. traefik.http.routers.app.entrypoints: websecure
  48. traefik.http.routers.app.rule: 'Host(`your.host.name`)'
  49. traefik.http.routers.app.tls: 'true'
  50. traefik.http.routers.app.tls.certresolver: le
  51. traefik.http.services.app.loadbalancer.server.port: 80
  52. # XMPP server
  53. prosody:
  54. image: jitsi/prosody
  55. expose:
  56. - '5222'
  57. - '5347'
  58. - '5280'
  59. volumes:
  60. - ${CONFIG}/prosody:/config
  61. environment:
  62. - AUTH_TYPE
  63. - ENABLE_AUTH
  64. - ENABLE_GUESTS
  65. - GLOBAL_MODULES
  66. - GLOBAL_CONFIG
  67. - LDAP_URL
  68. - LDAP_BASE
  69. - LDAP_BINDDN
  70. - LDAP_BINDPW
  71. - LDAP_FILTER
  72. - LDAP_AUTH_METHOD
  73. - LDAP_VERSION
  74. - LDAP_USE_TLS
  75. - LDAP_TLS_CIPHERS
  76. - LDAP_TLS_CHECK_PEER
  77. - LDAP_TLS_CACERT_FILE
  78. - LDAP_TLS_CACERT_DIR
  79. - LDAP_START_TLS
  80. - XMPP_DOMAIN
  81. - XMPP_AUTH_DOMAIN
  82. - XMPP_GUEST_DOMAIN
  83. - XMPP_MUC_DOMAIN
  84. - XMPP_INTERNAL_MUC_DOMAIN
  85. - XMPP_MODULES
  86. - XMPP_MUC_MODULES
  87. - XMPP_INTERNAL_MUC_MODULES
  88. - XMPP_RECORDER_DOMAIN
  89. - JICOFO_COMPONENT_SECRET
  90. - JICOFO_AUTH_USER
  91. - JICOFO_AUTH_PASSWORD
  92. - JVB_AUTH_USER
  93. - JVB_AUTH_PASSWORD
  94. - JIGASI_XMPP_USER
  95. - JIGASI_XMPP_PASSWORD
  96. - JIBRI_XMPP_USER
  97. - JIBRI_XMPP_PASSWORD
  98. - JIBRI_RECORDER_USER
  99. - JIBRI_RECORDER_PASSWORD
  100. - JWT_APP_ID
  101. - JWT_APP_SECRET
  102. - JWT_ACCEPTED_ISSUERS
  103. - JWT_ACCEPTED_AUDIENCES
  104. - JWT_ASAP_KEYSERVER
  105. - JWT_ALLOW_EMPTY
  106. - JWT_AUTH_TYPE
  107. - JWT_TOKEN_AUTH_MODULE
  108. - LOG_LEVEL
  109. - TZ
  110. networks:
  111. meet.jitsi:
  112. aliases:
  113. - ${XMPP_SERVER}
  114. # Focus component
  115. jicofo:
  116. image: jitsi/jicofo
  117. volumes:
  118. - ${CONFIG}/jicofo:/config
  119. environment:
  120. - ENABLE_AUTH
  121. - XMPP_DOMAIN
  122. - XMPP_AUTH_DOMAIN
  123. - XMPP_INTERNAL_MUC_DOMAIN
  124. - XMPP_SERVER
  125. - JICOFO_COMPONENT_SECRET
  126. - JICOFO_AUTH_USER
  127. - JICOFO_AUTH_PASSWORD
  128. - JICOFO_RESERVATION_REST_BASE_URL
  129. - JVB_BREWERY_MUC
  130. - JIGASI_BREWERY_MUC
  131. - JIBRI_BREWERY_MUC
  132. - JIBRI_PENDING_TIMEOUT
  133. - TZ
  134. depends_on:
  135. - prosody
  136. networks:
  137. meet.jitsi:
  138. # Video bridge
  139. jvb:
  140. image: jitsi/jvb
  141. ports:
  142. - '${JVB_PORT}:${JVB_PORT}/udp'
  143. - '${JVB_TCP_PORT}:${JVB_TCP_PORT}'
  144. volumes:
  145. - ${CONFIG}/jvb:/config
  146. environment:
  147. - DOCKER_HOST_ADDRESS
  148. - XMPP_AUTH_DOMAIN
  149. - XMPP_INTERNAL_MUC_DOMAIN
  150. - XMPP_SERVER
  151. - JVB_AUTH_USER
  152. - JVB_AUTH_PASSWORD
  153. - JVB_BREWERY_MUC
  154. - JVB_PORT
  155. - JVB_TCP_HARVESTER_DISABLED
  156. - JVB_TCP_PORT
  157. - JVB_STUN_SERVERS
  158. - JVB_ENABLE_APIS
  159. - TZ
  160. depends_on:
  161. - prosody
  162. networks:
  163. meet.jitsi:
  164. # Custom network so all services can communicate using a FQDN
  165. networks:
  166. meet.jitsi:
  167. # traefik: change the following line to your external docker network
  168. web:
  169. external: true