Comprehensive developer toolkit providing reusable skills for Java/Spring Boot, TypeScript/NestJS/React/Next.js, Python, PHP, AWS CloudFormation, AI/RAG, DevOps, and more.
82
82%
Does it follow best practices?
Impact
Pending
No eval scenarios have been run
Risky
Do not use without reviewing
Production-ready examples for configuring and using various vector stores with LangChain4j.
Scenario: Quick development and testing without external dependencies.
import dev.langchain4j.store.embedding.inmemory.InMemoryEmbeddingStore;
import dev.langchain4j.data.segment.TextSegment;
import dev.langchain4j.data.embedding.Embedding;
public class InMemoryStoreExample {
public static void main(String[] args) {
var store = new InMemoryEmbeddingStore<TextSegment>();
// Add embeddings
Embedding embedding1 = new Embedding(new float[]{0.1f, 0.2f, 0.3f});
String id1 = store.add("doc-001", embedding1,
TextSegment.from("Spring Boot documentation"));
// Search
EmbeddingSearchRequest request = EmbeddingSearchRequest.builder()
.queryEmbedding(embedding1)
.maxResults(5)
.build();
var results = store.search(request);
results.matches().forEach(match ->
System.out.println("Score: " + match.score())
);
// Remove
store.remove(id1);
}
}Scenario: Serverless vector database for scalable RAG.
import dev.langchain4j.store.embedding.pinecone.PineconeEmbeddingStore;
public class PineconeStoreExample {
public static void main(String[] args) {
var store = PineconeEmbeddingStore.builder()
.apiKey(System.getenv("PINECONE_API_KEY"))
.indexName("my-index")
.namespace("production") // Optional: organize by namespace
.dimension(1536) // Match embedding model
.build();
// Setup embedding model and ingestor
var embeddingModel = OpenAiEmbeddingModel.builder()
.apiKey(System.getenv("OPENAI_API_KEY"))
.modelName("text-embedding-3-small")
.build();
var ingestor = EmbeddingStoreIngestor.builder()
.embeddingModel(embeddingModel)
.embeddingStore(store)
.documentSplitter(DocumentSplitters.recursive(500, 50))
.build();
// Ingest documents
ingestor.ingest(Document.from("Your document content..."));
}
}Scenario: Open-source vector database with hybrid search.
import dev.langchain4j.store.embedding.weaviate.WeaviateEmbeddingStore;
public class WeaviateStoreExample {
public static void main(String[] args) {
var store = WeaviateEmbeddingStore.builder()
.host("localhost")
.port(8080)
.scheme("http") // or "https"
.collectionName("Documents")
.useGrpc(false) // Use REST endpoint
.build();
// Use with embedding model
var embeddingModel = OpenAiEmbeddingModel.builder()
.apiKey(System.getenv("OPENAI_API_KEY"))
.build();
// Add and search
var embedding = embeddingModel.embed("test").content();
var segment = TextSegment.from("Document content");
store.add(embedding, segment);
}
}Scenario: Fast vector search with filtering capabilities.
import dev.langchain4j.store.embedding.qdrant.QdrantEmbeddingStore;
public class QdrantStoreExample {
public static void main(String[] args) {
var store = QdrantEmbeddingStore.builder()
.host("localhost")
.port(6333)
.collectionName("documents")
.https(false) // Set to true for HTTPS
.preferGrpc(true) // Use gRPC for better performance
.build();
// Configure with metadata filtering
var retriever = EmbeddingStoreContentRetriever.builder()
.embeddingStore(store)
.embeddingModel(embeddingModel)
.maxResults(5)
.dynamicFilter(query ->
new IsEqualTo("source", "documentation")
)
.build();
}
}Scenario: Easy-to-use local or remote vector store.
import dev.langchain4j.store.embedding.chroma.ChromaEmbeddingStore;
public class ChromaStoreExample {
public static void main(String[] args) {
// Local Chroma server
var store = ChromaEmbeddingStore.builder()
.baseUrl("http://localhost:8000")
.collectionName("my-documents")
.logRequests(true)
.logResponses(true)
.build();
// Remote Chroma
var remoteStore = ChromaEmbeddingStore.builder()
.baseUrl("https://chroma.example.com")
.collectionName("production-docs")
.build();
}
}Scenario: Use existing PostgreSQL database for vectors.
import dev.langchain4j.store.embedding.pgvector.PgVectorEmbeddingStore;
public class PostgresStoreExample {
public static void main(String[] args) {
var store = PgVectorEmbeddingStore.builder()
.host("localhost")
.port(5432)
.database("embeddings")
.user("postgres")
.password("password")
.table("embeddings")
.createTableIfNotExists(true)
.dropTableIfExists(false)
.build();
// With SSL
var sslStore = PgVectorEmbeddingStore.builder()
.host("db.example.com")
.port(5432)
.database("embeddings")
.user("postgres")
.password("password")
.sslMode("require")
.table("embeddings")
.build();
}
}Scenario: Store vectors in MongoDB with metadata.
import dev.langchain4j.store.embedding.mongodb.MongoDbEmbeddingStore;
import dev.langchain4j.store.embedding.mongodb.IndexMapping;
import com.mongodb.client.MongoClient;
import com.mongodb.client.MongoClients;
public class MongoDbStoreExample {
public static void main(String[] args) {
MongoClient mongoClient = MongoClients.create(
System.getenv("MONGODB_URI")
);
var indexMapping = IndexMapping.builder()
.dimension(1536)
.metadataFieldNames(Set.of("source", "userId"))
.build();
var store = MongoDbEmbeddingStore.builder()
.databaseName("search")
.collectionName("documents")
.createIndex(true)
.indexName("vector_index")
.indexMapping(indexMapping)
.fromClient(mongoClient)
.build();
// With metadata
var segment = TextSegment.from(
"Content",
Metadata.from(Map.of("source", "docs", "userId", "123"))
);
store.add(embedding, segment);
}
}Scenario: Combine graph relationships with semantic search.
import dev.langchain4j.store.embedding.neo4j.Neo4jEmbeddingStore;
import org.neo4j.driver.Driver;
import org.neo4j.driver.GraphDatabase;
public class Neo4jStoreExample {
public static void main(String[] args) {
var store = Neo4jEmbeddingStore.builder()
.withBasicAuth("bolt://localhost:7687", "neo4j", "password")
.dimension(1536)
.label("Document")
.embeddingProperty("embedding")
.textProperty("text")
.metadataPrefix("metadata_")
.build();
// Hybrid search with full-text index
var hybridStore = Neo4jEmbeddingStore.builder()
.withBasicAuth("bolt://localhost:7687", "neo4j", "password")
.dimension(1536)
.fullTextIndexName("documents_ft")
.autoCreateFullText(true)
.fullTextQuery("Spring")
.build();
}
}Scenario: Open-source vector database for large-scale ML.
import dev.langchain4j.store.embedding.milvus.MilvusEmbeddingStore;
import dev.langchain4j.store.embedding.milvus.IndexType;
import dev.langchain4j.store.embedding.milvus.MetricType;
public class MilvusStoreExample {
public static void main(String[] args) {
var store = MilvusEmbeddingStore.builder()
.host("localhost")
.port(19530)
.collectionName("documents")
.dimension(1536)
.indexType(IndexType.HNSW) // or IVF_FLAT, IVF_SQ8
.metricType(MetricType.COSINE) // or L2, IP
.username("root")
.password("Milvus")
.autoCreateCollection(true)
.consistencyLevel("Session")
.build();
}
}Scenario: Advanced setup with metadata filtering.
import dev.langchain4j.store.embedding.filter.comparison.*;
public class HybridStoreExample {
public static void main(String[] args) {
// Create store
var store = QdrantEmbeddingStore.builder()
.host("localhost")
.port(6333)
.collectionName("multi_tenant_docs")
.build();
// Ingest with rich metadata
var ingestor = EmbeddingStoreIngestor.builder()
.documentTransformer(doc -> {
doc.metadata().put("userId", "user123");
doc.metadata().put("source", "api");
doc.metadata().put("created", LocalDate.now().toString());
doc.metadata().put("version", 1);
return doc;
})
.documentSplitter(DocumentSplitters.recursive(500, 50))
.embeddingModel(embeddingModel)
.embeddingStore(store)
.build();
// Setup retriever with complex filters
var retriever = EmbeddingStoreContentRetriever.builder()
.embeddingStore(store)
.embeddingModel(embeddingModel)
.maxResults(5)
.dynamicFilter(query -> {
// Multi-tenant isolation
String userId = "user123";
return new And(
new IsEqualTo("userId", userId),
new IsEqualTo("version", 1),
new IsGreaterThan("score", 0.7)
);
})
.build();
}
}plugins
developer-kit-ai
skills
chunking-strategy
prompt-engineering
developer-kit-aws
skills
aws
aws-cli-beast
aws-cost-optimization
aws-drawio-architecture-diagrams
aws-sam-bootstrap
aws-cloudformation
aws-cloudformation-auto-scaling
references
aws-cloudformation-bedrock
references
aws-cloudformation-cloudfront
references
aws-cloudformation-cloudwatch
references
aws-cloudformation-dynamodb
references
aws-cloudformation-ec2
aws-cloudformation-ecs
references
aws-cloudformation-elasticache
aws-cloudformation-iam
references
aws-cloudformation-lambda
references
aws-cloudformation-rds
aws-cloudformation-s3
references
aws-cloudformation-security
references
aws-cloudformation-task-ecs-deploy-gh
aws-cloudformation-vpc
developer-kit-core
skills
developer-kit-java
skills
aws-lambda-java-integration
aws-rds-spring-boot-integration
aws-sdk-java-v2-bedrock
aws-sdk-java-v2-core
aws-sdk-java-v2-dynamodb
aws-sdk-java-v2-kms
aws-sdk-java-v2-lambda
aws-sdk-java-v2-messaging
aws-sdk-java-v2-rds
aws-sdk-java-v2-s3
aws-sdk-java-v2-secrets-manager
graalvm-native-image
langchain4j
langchain4j-mcp-server-patterns
langchain4j-ai-services-patterns
references
langchain4j-mcp-server-patterns
references
langchain4j-rag-implementation-patterns
references
langchain4j-spring-boot-integration
langchain4j-testing-strategies
langchain4j-tool-function-calling-patterns
langchain4j-vector-stores-configuration
references
qdrant
references
spring-ai-mcp-server-patterns
references
spring-boot-actuator
spring-boot-cache
spring-boot-crud-patterns
spring-boot-dependency-injection
spring-boot-event-driven-patterns
spring-boot-openapi-documentation
spring-boot-project-creator
spring-boot-resilience4j
spring-boot-rest-api-standards
spring-boot-saga-pattern
spring-boot-security-jwt
assets
references
scripts
spring-boot-test-patterns
spring-data-jpa
references
spring-data-neo4j
references
unit-test-application-events
unit-test-bean-validation
unit-test-boundary-conditions
unit-test-caching
unit-test-config-properties
unit-test-controller-layer
unit-test-exception-handler
unit-test-json-serialization
unit-test-mapper-converter
unit-test-parameterized
unit-test-scheduled-async
unit-test-service-layer
unit-test-utility-methods
unit-test-wiremock-rest-api
developer-kit-php
skills
aws-lambda-php-integration
developer-kit-python
skills
aws-lambda-python-integration
developer-kit-tools
developer-kit-typescript
skills
aws-lambda-typescript-integration
better-auth
drizzle-orm-patterns
dynamodb-toolbox-patterns
references
nestjs
nestjs-best-practices
nestjs-code-review
nestjs-drizzle-crud-generator
scripts
nextjs-app-router
nextjs-authentication
nextjs-code-review
nextjs-data-fetching
references
nextjs-deployment
nextjs-performance
nx-monorepo
react-code-review
react-patterns
references
shadcn-ui
tailwind-css-patterns
references
tailwind-design-system
references
turborepo-monorepo
typescript-docs
typescript-security-review
zod-validation-utilities