搜图引擎Javasdk

groot 4fb6310ed9 BulkWriter supports Int8Vector (#1440) 2 hours ago
.github 9dd6d230f0 Add checkHealth/getPersistentSegmentInfo/getQuerySegmentInfo/transferNode interfaces (#1373) 2 months ago
doc 96874ab954 Update doc (#1035) 10 months ago
examples 4fb6310ed9 BulkWriter supports Int8Vector (#1440) 2 hours ago
sdk-bulkwriter 4fb6310ed9 BulkWriter supports Int8Vector (#1440) 2 hours ago
sdk-core 4fb6310ed9 BulkWriter supports Int8Vector (#1440) 2 hours ago
tests 98775b9029 Make CreateSchema() to be static (#1398) 1 month ago
.gitignore 1044dc68d9 Change example code path (#1295) 4 months ago
.gitmodules a14f8e93cd Split to 2 packages (#1224) 6 months ago
CHANGELOG.md f60245e6c3 Prepare for v2.6.0 (#1431) (#1432) 2 weeks ago
CODE_REVIEW.md d041eef7f7 Add code review.md (#216) 3 years ago
CONTRIBUTING.md 38971b3c3c add CONTRIBUTING.md 5 years ago
DEVELOPMENT.md a14f8e93cd Split to 2 packages (#1224) 6 months ago
LICENSE d986181d72 Initial commit 5 years ago
OWNERS 166b8381de Add maintainer member (#327) 3 years ago
README.md 6d55b59c39 Add Development section to README.md (#1436) 5 days ago
docker-compose.yml ad315101c8 Support addCollectionField() (#1424) 3 weeks ago
pom.xml f60245e6c3 Prepare for v2.6.0 (#1431) (#1432) 2 weeks ago

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!