Skip to content

Commit

Permalink
refactor index manager service add index service API to expose index …
Browse files Browse the repository at this point in the history
…informations

Signed-off-by: kpango <kpango@vdaas.org>
  • Loading branch information
kpango committed Jul 17, 2024
1 parent a9a9a2f commit 6b5c021
Show file tree
Hide file tree
Showing 355 changed files with 6,859 additions and 5,563 deletions.
24 changes: 16 additions & 8 deletions .gitfiles
Original file line number Diff line number Diff line change
Expand Up @@ -161,8 +161,6 @@ apis/grpc/v1/filter/egress/egress_filter.pb.go
apis/grpc/v1/filter/egress/egress_filter_vtproto.pb.go
apis/grpc/v1/filter/ingress/ingress_filter.pb.go
apis/grpc/v1/filter/ingress/ingress_filter_vtproto.pb.go
apis/grpc/v1/manager/index/index_manager.pb.go
apis/grpc/v1/manager/index/index_manager_vtproto.pb.go
apis/grpc/v1/mirror/mirror.go
apis/grpc/v1/mirror/mirror.pb.go
apis/grpc/v1/mirror/mirror_vtproto.pb.go
Expand All @@ -177,6 +175,8 @@ apis/grpc/v1/vald/filter.pb.go
apis/grpc/v1/vald/filter_vtproto.pb.go
apis/grpc/v1/vald/flush.pb.go
apis/grpc/v1/vald/flush_vtproto.pb.go
apis/grpc/v1/vald/index.pb.go
apis/grpc/v1/vald/index_vtproto.pb.go
apis/grpc/v1/vald/insert.pb.go
apis/grpc/v1/vald/insert_vtproto.pb.go
apis/grpc/v1/vald/object.pb.go
Expand All @@ -197,12 +197,12 @@ apis/proto/v1/agent/sidecar/sidecar.proto
apis/proto/v1/discoverer/discoverer.proto
apis/proto/v1/filter/egress/egress_filter.proto
apis/proto/v1/filter/ingress/ingress_filter.proto
apis/proto/v1/manager/index/index_manager.proto
apis/proto/v1/mirror/mirror.proto
apis/proto/v1/payload/payload.proto
apis/proto/v1/rpc/errdetails/error_details.proto
apis/proto/v1/vald/filter.proto
apis/proto/v1/vald/flush.proto
apis/proto/v1/vald/index.proto
apis/proto/v1/vald/insert.proto
apis/proto/v1/vald/object.proto
apis/proto/v1/vald/remove.proto
Expand All @@ -214,12 +214,12 @@ apis/swagger/v1/agent/sidecar/sidecar.swagger.json
apis/swagger/v1/discoverer/discoverer.swagger.json
apis/swagger/v1/filter/egress/egress_filter.swagger.json
apis/swagger/v1/filter/ingress/ingress_filter.swagger.json
apis/swagger/v1/manager/index/index_manager.swagger.json
apis/swagger/v1/mirror/mirror.swagger.json
apis/swagger/v1/payload/payload.swagger.json
apis/swagger/v1/rpc/errdetails/error_details.swagger.json
apis/swagger/v1/vald/filter.swagger.json
apis/swagger/v1/vald/flush.swagger.json
apis/swagger/v1/vald/index.swagger.json
apis/swagger/v1/vald/insert.swagger.json
apis/swagger/v1/vald/object.swagger.json
apis/swagger/v1/vald/remove.swagger.json
Expand All @@ -228,6 +228,7 @@ apis/swagger/v1/vald/update.swagger.json
apis/swagger/v1/vald/upsert.swagger.json
assets/docs/guides/observability-configuration/architecture.png
assets/docs/guides/operations/grafana-example.png
assets/docs/guides/read-replica-and-rotator/architecture.png
assets/docs/overview/component/agent/agent.drawio
assets/docs/overview/component/agent/ngt.png
assets/docs/overview/component/agent/sidecar_backup.png
Expand Down Expand Up @@ -556,6 +557,7 @@ docs/api/upsert.md
docs/contributing/coding-style.md
docs/contributing/contributing-guide.md
docs/contributing/development.md
docs/contributing/reviewer-guideline.md
docs/contributing/unit-test-guideline.md
docs/overview/about-vald.md
docs/overview/architecture.md
Expand All @@ -571,8 +573,8 @@ docs/performance/benchmark.md
docs/performance/continuous-benchmark.md
docs/performance/loadtest.md
docs/performance/tuning-search-performance.md
docs/support/FAQ.md
docs/support/contacts.md
docs/support/faq.md
docs/troubleshooting/README.md
docs/troubleshooting/client-side.md
docs/troubleshooting/mirror-gateway.md
Expand All @@ -595,6 +597,7 @@ docs/user-guides/mirroring-configuration.md
docs/user-guides/network-policy.md
docs/user-guides/observability-configuration.md
docs/user-guides/operations.md
docs/user-guides/read-replica-and-rotator.md
docs/user-guides/sdks.md
docs/user-guides/upgrade-cluster.md
example/client/agent/main.go
Expand Down Expand Up @@ -1016,7 +1019,6 @@ internal/hash/hash.go
internal/hash/hash_test.go
internal/info/info.go
internal/info/info_bench_test.go
internal/info/info_test.go
internal/info/option.go
internal/info/option_test.go
internal/io/copy.go
Expand Down Expand Up @@ -1820,6 +1822,14 @@ renovate.json
rust/Cargo.lock
rust/Cargo.toml
rust/bin/agent/Cargo.toml
rust/bin/agent/src/handler.rs
rust/bin/agent/src/handler/common.rs
rust/bin/agent/src/handler/index.rs
rust/bin/agent/src/handler/insert.rs
rust/bin/agent/src/handler/remove.rs
rust/bin/agent/src/handler/search.rs
rust/bin/agent/src/handler/update.rs
rust/bin/agent/src/handler/upsert.rs
rust/bin/agent/src/main.rs
rust/libs/ngt-rs/Cargo.toml
rust/libs/ngt-rs/build.rs
Expand All @@ -1838,8 +1848,6 @@ rust/libs/proto/src/filter.egress.v1.tonic.rs
rust/libs/proto/src/filter.ingress.v1.rs
rust/libs/proto/src/filter.ingress.v1.tonic.rs
rust/libs/proto/src/lib.rs
rust/libs/proto/src/manager.index.v1.rs
rust/libs/proto/src/manager.index.v1.tonic.rs
rust/libs/proto/src/mirror.v1.rs
rust/libs/proto/src/mirror.v1.tonic.rs
rust/libs/proto/src/payload.v1.rs
Expand Down
6 changes: 3 additions & 3 deletions .github/ISSUE_TEMPLATE/bug_report.md
Original file line number Diff line number Diff line change
Expand Up @@ -22,8 +22,8 @@ assignees: ""

<!--- Please change the versions below along with your environment -->

- Go Version: 1.22.3
- Go Version: 1.22.5
- Rust Version: 1.77.2
- Docker Version: 20.10.8
- Kubernetes Version: v1.30.0
- NGT Version: 2.2.1
- Kubernetes Version: v1.30.2
- NGT Version: 2.2.2
6 changes: 3 additions & 3 deletions .github/ISSUE_TEMPLATE/security_issue_report.md
Original file line number Diff line number Diff line change
Expand Up @@ -16,8 +16,8 @@ assignees: ""

<!--- Please change the versions below along with your environment -->

- Go Version: 1.22.3
- Go Version: 1.22.5
- Rust Version: 1.77.2
- Docker Version: 20.10.8
- Kubernetes Version: v1.30.0
- NGT Version: 2.2.1
- Kubernetes Version: v1.30.2
- NGT Version: 2.2.2
6 changes: 3 additions & 3 deletions .github/PULL_REQUEST_TEMPLATE.md
Original file line number Diff line number Diff line change
Expand Up @@ -16,11 +16,11 @@

<!--- Please change the versions below along with your environment -->

- Go Version: 1.22.3
- Go Version: 1.22.5
- Rust Version: 1.77.2
- Docker Version: 20.10.8
- Kubernetes Version: v1.30.0
- NGT Version: 2.2.1
- Kubernetes Version: v1.30.2
- NGT Version: 2.2.2

### Checklist

Expand Down
6 changes: 5 additions & 1 deletion .github/actions/docker-build/action.yaml
Original file line number Diff line number Diff line change
Expand Up @@ -113,7 +113,11 @@ runs:
REMOTE="true" \
DOCKER="docker" \
BUILDKIT_INLINE_CACHE=0 \
DOCKER_OPTS="--platform ${PLATFORMS} --builder ${BUILDER} ${LABEL_OPTS} --label org.opencontainers.image.version=${PRIMARY_TAG} --label org.opencontainers.image.title=${TARGET}" \
DOCKER_OPTS="--platform ${PLATFORMS} --builder ${BUILDER} ${LABEL_OPTS} \
--label org.opencontainers.image.version=${PRIMARY_TAG} \
--label org.opencontainers.image.title=${TARGET} \
--label org.opencontainers.image.created=\"$(date --rfc-3339=ns)\" \
--label org.opencontainers.image.licenses=\"Apache 2.0\"" \
EXTRA_ARGS="${EXTRA_TAGS}" \
TAG="${PRIMARY_TAG}" \
docker/build/${TARGET}
Expand Down
2 changes: 1 addition & 1 deletion .github/workflows/release.yml
Original file line number Diff line number Diff line change
Expand Up @@ -61,7 +61,7 @@ jobs:
git push origin ${VERSION}
echo "VERSION=${VERSION}" >> $GITHUB_OUTPUT
- name: Create release
uses: softprops/action-gh-release@v1
uses: softprops/action-gh-release@v2
env:
GITHUB_TOKEN: ${{ secrets.DISPATCH_TOKEN }}
with:
Expand Down
23 changes: 20 additions & 3 deletions Makefile
Original file line number Diff line number Diff line change
Expand Up @@ -238,6 +238,7 @@ GO_SOURCES = $(eval GO_SOURCES := $(shell find \
-not -path '$(ROOTDIR)/hack/benchmark/internal/starter/gateway/*' \
-not -path '$(ROOTDIR)/hack/gorules/*' \
-not -path '$(ROOTDIR)/hack/license/*' \
-not -path '$(ROOTDIR)/hack/docker/*' \
-not -path '$(ROOTDIR)/hack/swagger/*' \
-not -path '$(ROOTDIR)/hack/tools/*' \
-not -path '$(ROOTDIR)/tests/*' \
Expand Down Expand Up @@ -269,6 +270,7 @@ GO_OPTION_SOURCES = $(eval GO_OPTION_SOURCES := $(shell find \
-not -path '$(ROOTDIR)/hack/benchmark/internal/starter/gateway/*' \
-not -path '$(ROOTDIR)/hack/gorules/*' \
-not -path '$(ROOTDIR)/hack/license/*' \
-not -path '$(ROOTDIR)/hack/docker/*' \
-not -path '$(ROOTDIR)/hack/swagger/*' \
-not -path '$(ROOTDIR)/hack/tools/*' \
-not -path '$(ROOTDIR)/tests/*' \
Expand Down Expand Up @@ -411,6 +413,11 @@ files:
license:
$(call gen-license,$(ROOTDIR),$(MAINTAINER))

.PHONY: dockerfile
## generate dockerfiles
dockerfile:
$(call gen-dockerfile,$(ROOTDIR),$(MAINTAINER))

.PHONY: init
## initialize development environment
init: \
Expand Down Expand Up @@ -444,6 +451,7 @@ update: \
.PHONY: format
## format go codes
format: \
dockerfile \
license \
format/proto \
format/go \
Expand All @@ -454,6 +462,7 @@ format: \
.PHONY: format/go
## run golines, gofumpt, goimports for all go files
format/go: \
crlfmt/install \
golines/install \
gofumpt/install \
strictgoimports/install \
Expand All @@ -462,10 +471,12 @@ format/go: \
find $(ROOTDIR)/ -type d -name .git -prune -o -type f -regex '.*[^\.pb]\.go' -print | xargs -P$(CORES) $(GOBIN)/gofumpt -w
find $(ROOTDIR)/ -type d -name .git -prune -o -type f -regex '.*[^\.pb]\.go' -print | xargs -P$(CORES) $(GOBIN)/strictgoimports -w
find $(ROOTDIR)/ -type d -name .git -prune -o -type f -regex '.*\.go' -print | xargs -P$(CORES) $(GOBIN)/goimports -w
find $(ROOTDIR)/ -type d -name .git -prune -o -type f -regex '.*\.go' -print | xargs -P$(CORES) $(GOBIN)/crlfmt -w

.PHONY: format/go/test
## run golines, gofumpt, goimports for go test files
format/go/test: \
crlfmt/install \
golines/install \
gofumpt/install \
strictgoimports/install \
Expand All @@ -474,6 +485,7 @@ format/go/test: \
find $(ROOTDIR) -name '*_test.go' | xargs -P$(CORES) $(GOBIN)/gofumpt -w
find $(ROOTDIR) -name '*_test.go' | xargs -P$(CORES) $(GOBIN)/strictgoimports -w
find $(ROOTDIR) -name '*_test.go' | xargs -P$(CORES) $(GOBIN)/goimports -w
find $(ROOTDIR) -name '*_test.go' | xargs -P$(CORES) $(GOBIN)/crlfmt -w

.PHONY: format/yaml
format/yaml: \
Expand Down Expand Up @@ -516,6 +528,7 @@ deps: \
.PHONY: deps/install
## install dependencies
deps/install: \
crlfmt/install \
golines/install \
gofumpt/install \
strictgoimports/install \
Expand Down Expand Up @@ -592,8 +605,8 @@ ngt/install: /usr/local/include/NGT/Capi.h
## install Faiss
faiss/install: /usr/local/lib/libfaiss.so
/usr/local/lib/libfaiss.so:
curl -fsSLO https://github.com/facebookresearch/faiss/archive/v$(FAISS_VERSION).tar.gz
tar zxf v$(FAISS_VERSION).tar.gz -C $(TEMP_DIR)/
curl -fsSL https://github.com/facebookresearch/faiss/archive/v$(FAISS_VERSION).tar.gz -o $(TEMP_DIR)/v$(FAISS_VERSION).tar.gz
tar zxf $(TEMP_DIR)/v$(FAISS_VERSION).tar.gz -C $(TEMP_DIR)/
cd $(TEMP_DIR)/faiss-$(FAISS_VERSION) && \
cmake -DFAISS_ENABLE_GPU=OFF -DFAISS_ENABLE_PYTHON=OFF -DBUILD_TESTING=OFF -DCMAKE_BUILD_TYPE=Release -DBUILD_SHARED_LIBS=ON -B build . && \
make -C build -j faiss && \
Expand All @@ -607,7 +620,11 @@ faiss/install: /usr/local/lib/libfaiss.so
lint: \
docs/lint \
files/lint \
vet
vet \
go/lint

.PHONY: go/lint
go/lint:
$(call go-lint)

.PHONY: vet
Expand Down
9 changes: 5 additions & 4 deletions Makefile.d/build.mk
Original file line number Diff line number Diff line change
Expand Up @@ -17,8 +17,6 @@
.PHONY: binary/build
## build all binaries
binary/build: \
cmd/agent/core/faiss/faiss \
cmd/agent/core/ngt/ngt \
cmd/agent/sidecar/sidecar \
cmd/discoverer/k8s/discoverer \
cmd/gateway/filter/filter \
Expand All @@ -31,13 +29,15 @@ binary/build: \
cmd/manager/index/index \
cmd/tools/benchmark/job/job \
cmd/tools/benchmark/operator/operator \
cmd/index/operator/index-operator
cmd/index/operator/index-operator \
cmd/agent/core/ngt/ngt \
cmd/agent/core/faiss/faiss


cmd/agent/core/ngt/ngt: \
ngt/install
$(eval CGO_ENABLED = 1)
$(call go-build,agent/core/ngt,-linkmode 'external',-static -fPIC -pthread -fopenmp -std=gnu++20 -lstdc++ -lm -z relro -z now $(EXTLDFLAGS), cgo,NGT-$(NGT_VERSION),$@)
$(call go-build,agent/core/ngt,-linkmode 'external',-static -fPIC -pthread -fopenmp -std=gnu++20 -lstdc++ -lm -z relro -z now -flto -march=native -fno-plt -Ofast -fvisibility=hidden -ffp-contract=fast $(EXTLDFLAGS), cgo,NGT-$(NGT_VERSION),$@)

cmd/agent/core/faiss/faiss: \
faiss/install
Expand Down Expand Up @@ -89,6 +89,7 @@ cmd/index/operator/index-operator:
$(call go-build,index/operator,,-static,,,$@)

cmd/tools/benchmark/job/job:
$(eval CGO_ENABLED = 1)
$(call go-build,tools/benchmark/job,-linkmode 'external',-static -fPIC -pthread -fopenmp -std=gnu++20 -lhdf5 -lhdf5_hl -lm -ldl, cgo,$(HDF5_VERSION),$@)

cmd/tools/benchmark/operator/operator:
Expand Down
3 changes: 2 additions & 1 deletion Makefile.d/dependencies.mk
Original file line number Diff line number Diff line change
Expand Up @@ -47,7 +47,8 @@ go/download:

.PHONY: go/deps
## install Go package dependencies
go/deps:
go/deps: \
update/go
sed -i "3s/go [0-9]\+\.[0-9]\+\(\.[0-9]\+\)\?/go $(GO_VERSION)/g" $(ROOTDIR)/hack/go.mod.default
if $(GO_CLEAN_DEPS); then \
rm -rf $(ROOTDIR)/vendor \
Expand Down
2 changes: 2 additions & 0 deletions Makefile.d/docker.mk
Original file line number Diff line number Diff line change
Expand Up @@ -46,7 +46,9 @@ ifeq ($(REMOTE),true)
@echo "starting remote build for $(IMAGE):$(TAG)"
DOCKER_BUILDKIT=1 $(DOCKER) buildx build \
$(DOCKER_OPTS) \
--cache-to type=gha,scope=$(TAG)-buildcache,mode=max \
--cache-to type=registry,ref=$(GHCRORG)/$(IMAGE):$(TAG)-buildcache,mode=max \
--cache-from type=gha,scope=$(TAG)-buildcache \
--cache-from type=registry,ref=$(GHCRORG)/$(IMAGE):$(TAG)-buildcache \
--build-arg BUILDKIT_INLINE_CACHE=$(BUILDKIT_INLINE_CACHE) \
--build-arg GO_VERSION=$(GO_VERSION) \
Expand Down
21 changes: 18 additions & 3 deletions Makefile.d/functions.mk
Original file line number Diff line number Diff line change
Expand Up @@ -295,6 +295,23 @@ define gen-license
rm -rf $$BIN_PATH
endef

define gen-dockerfile
BIN_PATH="$(TEMP_DIR)/vald-dockerfile-gen"; \
rm -rf $$BIN_PATH; \
MAINTAINER=$2 \
GOPRIVATE=$(GOPRIVATE) \
GOARCH=$(GOARCH) \
GOOS=$(GOOS) \
go build -modcacherw \
-mod=readonly \
-a \
-tags "osusergo netgo static_build" \
-trimpath \
-o $$BIN_PATH $(ROOTDIR)/hack/docker/gen/main.go; \
$$BIN_PATH $1; \
rm -rf $$BIN_PATH
endef

define gen-vald-helm-schema
BIN_PATH="$(TEMP_DIR)/vald-helm-schema-gen"; \
rm -rf $$BIN_PATH; \
Expand Down Expand Up @@ -333,14 +350,12 @@ define gen-vald-crd
endef

define update-github-actions
@for ACTION_NAME in $1; do \
@set -e; for ACTION_NAME in $1; do \
if [ -n "$$ACTION_NAME" ] && [ "$$ACTION_NAME" != "security-and-quality" ]; then \
FILE_NAME=`echo $$ACTION_NAME | tr '/' '_' | tr '-' '_' | tr '[:lower:]' '[:upper:]'`; \
if [ -n "$$FILE_NAME" ]; then \
if [ "$$ACTION_NAME" = "aquasecurity/trivy-action" ] || [ "$$ACTION_NAME" = "machine-learning-apps/actions-chatops" ]; then \
VERSION="master"; \
elif [ "$$ACTION_NAME" = "softprops/action-gh-release" ]; then \
VERSION="1.0.0"; \
else \
REPO_NAME=`echo $$ACTION_NAME | cut -d'/' -f1-2`; \
VERSION=`curl -fsSL https://api.github.com/repos/$$REPO_NAME/releases/latest | grep -Po '"tag_name": "\K.*?(?=")' | sed 's/v//g' | sed -E 's/[^0-9.]+//g'`;\
Expand Down
1 change: 1 addition & 0 deletions Makefile.d/proto.mk
Original file line number Diff line number Diff line change
Expand Up @@ -59,3 +59,4 @@ proto/gen: \
find $(ROOTDIR)/apis/grpc/* -name '*.go' | xargs -P$(CORES) sed -i -E "s%google.golang.org/grpc/status%github.com/vdaas/vald/internal/net/grpc/status%g"
find $(ROOTDIR)/apis/grpc/* -name '*.go' | xargs -P$(CORES) sed -i -E "s%\"io\"%\"github.com/vdaas/vald/internal/io\"%g"
find $(ROOTDIR)/apis/grpc/* -name '*.go' | xargs -P$(CORES) sed -i -E "s%\"sync\"%\"github.com/vdaas/vald/internal/sync\"%g"
find $(ROOTDIR)/apis/grpc/* -name '*.go' | xargs -P$(CORES) sed -i -E "s%any%any%g"
6 changes: 6 additions & 0 deletions Makefile.d/tools.mk
Original file line number Diff line number Diff line change
Expand Up @@ -46,6 +46,12 @@ golines/install: $(GOBIN)/golines
$(GOBIN)/golines:
$(call go-install, github.com/segmentio/golines)

.PHONY: crlfmt/install
crlfmt/install: $(GOBIN)/crlfmt

$(GOBIN)/crlfmt:
$(call go-install, github.com/cockroachdb/crlfmt)

.PHONY: prettier/install
prettier/install: $(BINDIR)/prettier
$(BINDIR)/prettier:
Expand Down
Loading

0 comments on commit 6b5c021

Please sign in to comment.