搜图引擎Javasdk

groot e0f0b665f5 Refine the schema cache machinery and add test cases (#1457) hai 2 semanas
.github 9dd6d230f0 Add checkHealth/getPersistentSegmentInfo/getQuerySegmentInfo/transferNode interfaces (#1373) hai 3 meses
doc 96874ab954 Update doc (#1035) hai 11 meses
examples a650fd4fdc Fix a bug of SearchResultsWrapper.getRowRecords() that returns wrong data for output fields (#1445) hai 3 semanas
sdk-bulkwriter 40e7215c61 BulkWriter supports Int8Vector (#1441) hai 3 semanas
sdk-core e0f0b665f5 Refine the schema cache machinery and add test cases (#1457) hai 2 semanas
tests 98775b9029 Make CreateSchema() to be static (#1398) hai 2 meses
.gitignore 1044dc68d9 Change example code path (#1295) hai 5 meses
.gitmodules a14f8e93cd Split to 2 packages (#1224) hai 7 meses
CHANGELOG.md 9224f2fe90 Prepare for v2.6.0 (#1431) hai 1 mes
CODE_REVIEW.md d041eef7f7 Add code review.md (#216) %!s(int64=3) %!d(string=hai) anos
CONTRIBUTING.md 38971b3c3c add CONTRIBUTING.md %!s(int64=5) %!d(string=hai) anos
DEVELOPMENT.md a14f8e93cd Split to 2 packages (#1224) hai 7 meses
LICENSE d986181d72 Initial commit %!s(int64=5) %!d(string=hai) anos
OWNERS 166b8381de Add maintainer member (#327) %!s(int64=3) %!d(string=hai) anos
README.md 40e7215c61 BulkWriter supports Int8Vector (#1441) hai 3 semanas
docker-compose.yml a5ada94e15 Fix a bug of collection schema cache for V1 and V2 (#1449) hai 3 semanas
pom.xml 9224f2fe90 Prepare for v2.6.0 (#1431) hai 1 mes

README.md

Milvus Java SDK

Maven Central

Java SDK for Milvus. To contribute to this project, please read our contribution guidelines first.

Getting started

Prerequisites

-   Java 8 or higher
-   Apache Maven or Gradle

The following table shows compatibilities between Milvus and Java SDK.

Milvus version Java SDK version
2.0 2.0.4
2.1 2.1.0-beta4
2.2.0 ~ 2.2.8 2.2.0 ~ 2.2.5
>= 2.2.9 2.2.7 ~ 2.2.15
2.3.x 2.3.11
2.4.x 2.4.11
2.5.x 2.5.10
2.6.x 2.6.0

Install Java SDK

You can use Apache Maven or Gradle add Milvus SDK to your project.

  • Apache Maven

        <dependency>
            <groupId>io.milvus</groupId>
            <artifactId>milvus-sdk-java</artifactId>
            <version>2.6.0</version>
        </dependency>
    
  • Gradle/Groovy

    ```groovy
    implementation 'io.milvus:milvus-sdk-java:2.6.0'
    ```
    
  • Gradle/Kotlin

    ```kotlin
    implementation("io.milvus:milvus-sdk-java:2.6.0")
    ```
    

From v2.5.2, milvus Java SDK is split into two packages: milvus-sdk-java and milvus-sdk-java-bulkwriter, because BulkWriter requires quite a lot of dependencies. If you don't need BulkWriter tool, you can ignore the milvus-sdk-java-bulkwriter package. To use BulkWriter, import milvus-sdk-java-bulkwriter to your project.

  • Apache Maven

     <dependency>
         <groupId>io.milvus</groupId>
         <artifactId>milvus-sdk-java-bulkwriter</artifactId>
         <version>2.6.0</version>
     </dependency>
    
  • Gradle/Groovy

     implementation 'io.milvus:milvus-sdk-java-bulkwriter:2.6.0'
    
  • Gradle/Kotlin

     implementation("io.milvus:milvus-sdk-java-bulkwriter:2.6.0")
    

Examples

Please refer to examples folder for Java SDK examples.

Documentation

Troubleshooting

  • If you encounter the following error when running your application:

    Exception in thread "main" java.lang.NoClassDefFoundError: org/slf4j/LoggerFactory
    

    This is because SLF4J jar files need to be added into your application's classpath. SLF4J is required by Java SDK for logging purpose.

To fix this issue, you can use Apache Maven or Gradle to download the required jar files.

- Apache Maven

    ```xml
     <dependency>
         <groupId>org.slf4j</groupId>
         <artifactId>slf4j-api</artifactId>
         <version>1.7.30</version>
     </dependency>
    ```

- Gradle/Groovy

     ```groovy
     compile group: 'org.slf4j', name: 'slf4j-api', version: '1.7.30'
     ```
- Gradle/Kotlin

    ```kotlin
    implementation("org.slf4j:slf4j-api:1.7.30")
    ```

Development

For developers interested in contributing to the Milvus Java SDK, please refer to our DEVELOPMENT.md file. This document provides detailed instructions on:

  • Setting up your development environment
  • Cloning the repository
  • Building the SDK
  • Updating Milvus proto files
  • Running tests
  • Contributing guidelines

We welcome contributions from the community!