docker-compose.yml 4.9 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150
  1. version: '3.5'
  2. x-ccache: &ccache
  3. CCACHE_COMPILERCHECK: content
  4. CCACHE_COMPRESS: 1
  5. CCACHE_COMPRESSLEVEL: 5
  6. CCACHE_MAXSIZE: 2G
  7. CCACHE_DIR: /ccache
  8. services:
  9. builder:
  10. image: ${IMAGE_REPO}/milvus-env:${OS_NAME}-${DATE_VERSION}
  11. # Build devcontainer
  12. build:
  13. context: .
  14. dockerfile: build/docker/builder/cpu/${OS_NAME}/Dockerfile
  15. args:
  16. TARGETARCH: ${IMAGE_ARCH}
  17. cache_from:
  18. - ${IMAGE_REPO}/milvus-env:${OS_NAME}-${LATEST_DATE_VERSION}
  19. platform: linux/${IMAGE_ARCH}
  20. shm_size: 2G
  21. # expose 19530 port so we can directly access milvus inside build container
  22. # ports:
  23. # - "19530:19530"
  24. environment:
  25. <<: *ccache
  26. OS_NAME: ${OS_NAME}
  27. PULSAR_ADDRESS: ${PULSAR_ADDRESS}
  28. ETCD_ENDPOINTS: ${ETCD_ENDPOINTS}
  29. MINIO_ADDRESS: ${MINIO_ADDRESS}
  30. CONAN_USER_HOME: /home/milvus
  31. AZURE_STORAGE_CONNECTION_STRING: ${AZURITE_CONNECTION_STRING}
  32. ENABLE_GCP_NATIVE: ${ENABLE_GCP_NATIVE}
  33. volumes: &builder-volumes
  34. - .:/go/src/github.com/milvus-io/milvus:delegated
  35. - ${DOCKER_VOLUME_DIRECTORY:-.docker}/${IMAGE_ARCH}-${OS_NAME}-ccache:/ccache:delegated
  36. - ${DOCKER_VOLUME_DIRECTORY:-.docker}/${IMAGE_ARCH}-${OS_NAME}-go-mod:/go/pkg/mod:delegated
  37. - ${DOCKER_VOLUME_DIRECTORY:-.docker}/${IMAGE_ARCH}-${OS_NAME}-vscode-extensions:/home/milvus/.vscode-server/extensions:delegated
  38. - ${DOCKER_VOLUME_DIRECTORY:-.docker}/${IMAGE_ARCH}-${OS_NAME}-conan:/home/milvus/.conan:delegated
  39. working_dir: '/go/src/github.com/milvus-io/milvus'
  40. depends_on:
  41. - etcd
  42. - minio
  43. - pulsar
  44. - azurite
  45. - gcpnative
  46. # Command
  47. command: &builder-command >
  48. /bin/bash -c "
  49. make check-proto-product && make verifiers && make unittest"
  50. gpubuilder:
  51. image: ${IMAGE_REPO}/milvus-env:gpu-${OS_NAME}-${GPU_DATE_VERSION}
  52. # Build devcontainer
  53. build:
  54. context: .
  55. dockerfile: build/docker/builder/gpu/${OS_NAME}/Dockerfile
  56. args:
  57. TARGETARCH: ${IMAGE_ARCH}
  58. cache_from:
  59. - ${IMAGE_REPO}/milvus-env:gpu-${OS_NAME}-${LATEST_GPU_DATE_VERSION}
  60. # user: {{ CURRENT_ID }}
  61. shm_size: 2G
  62. # expose 19530 port so we can directly access milvus inside build container
  63. # ports:
  64. # - "19530:19530"
  65. environment:
  66. <<: *ccache
  67. OS_NAME: ${OS_NAME}
  68. PULSAR_ADDRESS: ${PULSAR_ADDRESS}
  69. ETCD_ENDPOINTS: ${ETCD_ENDPOINTS}
  70. MINIO_ADDRESS: ${MINIO_ADDRESS}
  71. CONAN_USER_HOME: /home/milvus
  72. AZURE_STORAGE_CONNECTION_STRING: ${AZURITE_CONNECTION_STRING}
  73. ENABLE_GCP_NATIVE: ${ENABLE_GCP_NATIVE}
  74. volumes: &builder-volumes-gpu
  75. - .:/go/src/github.com/milvus-io/milvus:delegated
  76. - ${DOCKER_VOLUME_DIRECTORY:-.docker-gpu}/${OS_NAME}-ccache:/ccache:delegated
  77. - ${DOCKER_VOLUME_DIRECTORY:-.docker-gpu}/${OS_NAME}-go-mod:/go/pkg/mod:delegated
  78. - ${DOCKER_VOLUME_DIRECTORY:-.docker-gpu}/${OS_NAME}-vscode-extensions:/home/milvus/.vscode-server/extensions:delegated
  79. - ${DOCKER_VOLUME_DIRECTORY:-.docker-gpu}/${OS_NAME}-conan:/home/milvus/.conan:delegated
  80. working_dir: '/go/src/github.com/milvus-io/milvus'
  81. depends_on:
  82. - etcd
  83. - minio
  84. - pulsar
  85. - azurite
  86. - gcpnative
  87. # Command
  88. command: &builder-command-gpu >
  89. /bin/bash -c "
  90. make check-proto-product && make verifiers && make unittest"
  91. etcd:
  92. image: milvusdb/etcd:3.5.5-r2
  93. environment:
  94. - ALLOW_NONE_AUTHENTICATION=yes
  95. - ETCD_AUTO_COMPACTION_MODE=revision
  96. - ETCD_AUTO_COMPACTION_RETENTION=1000
  97. - ETCD_QUOTA_BACKEND_BYTES=4294967296
  98. - ETCD_SNAPSHOT_COUNT=50000
  99. healthcheck:
  100. test: [ 'CMD', '/opt/bitnami/scripts/etcd/healthcheck.sh' ]
  101. interval: 30s
  102. timeout: 20s
  103. retries: 3
  104. pulsar:
  105. image: apachepulsar/pulsar:2.8.2
  106. command: |
  107. /bin/bash -c \
  108. "bin/apply-config-from-env.py conf/standalone.conf && \
  109. exec bin/pulsar standalone --no-functions-worker --no-stream-storage"
  110. environment:
  111. # 10MB
  112. - PULSAR_PREFIX_maxMessageSize=10485760
  113. # this is 104857600 + 10240 (padding)
  114. - nettyMaxFrameSizeBytes=104867840
  115. - PULSAR_GC=-XX:+UseG1GC
  116. minio:
  117. image: minio/minio:RELEASE.2023-03-20T20-16-18Z
  118. environment:
  119. MINIO_ACCESS_KEY: minioadmin
  120. MINIO_SECRET_KEY: minioadmin
  121. command: minio server /minio_data
  122. healthcheck:
  123. test: [ 'CMD', 'curl', '-f', 'http://localhost:9000/minio/health/live' ]
  124. interval: 30s
  125. timeout: 20s
  126. retries: 3
  127. azurite:
  128. image: mcr.microsoft.com/azure-storage/azurite
  129. command: azurite-blob --blobHost 0.0.0.0
  130. jaeger:
  131. image: jaegertracing/all-in-one:latest
  132. gcpnative:
  133. image: fsouza/fake-gcs-server
  134. command: -scheme http -public-host storage.gcs.127.0.0.1.nip.io:4443 -external-url "http://storage.gcs.127.0.0.1.nip.io:4443"
  135. hostname: storage.gcs.127.0.0.1.nip.io
  136. ports:
  137. - "4443:4443"
  138. networks:
  139. default:
  140. name: milvus_dev