mirror of
https://gitee.com/milvus-io/milvus.git
synced 2024-12-11 09:46:26 +08:00
6b348e4e91
Cherry-pick from master pr: #33063 See also #33062 This PR: - Add lock.RWMutex & lock.Mutex alias to switch implementation based on build flags - When build flags has test in it, use go-deadlock to detect possible deadlocks - Replace all sync.RWMutex & sync.Mutex in datacoord pkg Signed-off-by: Congqi Xia <congqi.xia@zilliz.com> |
||
---|---|---|
.. | ||
sql | ||
3rdparty_build.sh | ||
antlr-4.9-complete.jar | ||
azure_build.sh | ||
check_cpp_fmt.sh | ||
check_proto_product.sh | ||
collect_arrow_dep.sh | ||
core_build.sh | ||
devcontainer.sh | ||
docker_image_find_tag.sh | ||
download_milvus_proto.sh | ||
generate_proto.sh | ||
gofmt.sh | ||
install_deps_embd.sh | ||
install_deps_msys.sh | ||
install_deps.sh | ||
OWNERS | ||
package_windows.sh | ||
README.md | ||
run_cpp_codecov.sh | ||
run_cpp_unittest.sh | ||
run_docker.sh | ||
run_go_codecov.sh | ||
run_go_unittest.sh | ||
run_intergration_test.sh | ||
setenv.sh | ||
standalone_embed.sh | ||
start_cluster.sh | ||
start_standalone.sh | ||
stop_graceful.sh | ||
stop.sh | ||
update-api-version.sh |
Compile and install milvus cluster
Environment
OS: Ubuntu 20.04
go:1.21
cmake: >=3.18
gcc: 7.5
Install dependencies
Install compile dependencies
$ sudo apt install -y g++ gcc make libssl-dev zlib1g-dev libboost-regex-dev \
libboost-program-options-dev libboost-system-dev libboost-filesystem-dev \
libboost-serialization-dev python3-dev libboost-python-dev libcurl4-openssl-dev gfortran libtbb-dev
$ export GO111MODULE=on
$ go get github.com/golang/protobuf/protoc-gen-go@v1.3.2
Install OpenBlas library
$ wget https://github.com/xianyi/OpenBLAS/archive/v0.3.9.tar.gz && \
$ tar zxvf v0.3.9.tar.gz && cd OpenBLAS-0.3.9 && \
$ make TARGET=CORE2 DYNAMIC_ARCH=1 DYNAMIC_OLDER=1 USE_THREAD=0 USE_OPENMP=0 FC=gfortran CC=gcc COMMON_OPT="-O3 -g -fPIC" FCOMMON_OPT="-O3 -g -fPIC -frecursive" NMAX="NUM_THREADS=128" LIBPREFIX="libopenblas" INTERFACE64=0 NO_STATIC=1 && \
$ make PREFIX=/usr install
Compile
Generate the go files from proto file
$ make check-proto-product
Check code specifications
$ make verifiers
Compile milvus
$ make milvus
Install docker-compose
refer: https://docs.docker.com/compose/install/
$ sudo curl -L "https://github.com/docker/compose/releases/download/1.27.4/docker-compose-$(uname -s)-$(uname -m)" -o /usr/local/bin/docker-compose
$ sudo chmod +x /usr/local/bin/docker-compose
$ sudo ln -s /usr/local/bin/docker-compose /usr/bin/docker-compose
$ docker-compose --version
Start service
Start third-party service:
$ cd [milvus project path]/deployments/docker/cluster
$ docker-compose up -d
Start milvus cluster:
$ cd [milvus project path]
$ ./scripts/start_cluster.sh
Run unittest
Run all unittest including go and cpp cases:
$ make unittest
You also can run go unittest only:
$ make test-go
Run cpp unittest only:
$ make test-cpp
Run code coverage
Run code coverage including go and cpp:
$ make codecov
You also can run go code coverage only:
$ make codecov-go
Run cpp code coverage only:
$ make codecov-cpp