* docs: deep audit — fix stale config keys, missing commands, and registry drift Cross-checked ~80 high-impact docs pages (getting-started, reference, top-level user-guide, user-guide/features) against the live registries: hermes_cli/commands.py COMMAND_REGISTRY (slash commands) hermes_cli/auth.py PROVIDER_REGISTRY (providers) hermes_cli/config.py DEFAULT_CONFIG (config keys) toolsets.py TOOLSETS (toolsets) tools/registry.py get_all_tool_names() (tools) python -m hermes_cli.main <subcmd> --help (CLI args) reference/ - cli-commands.md: drop duplicate hermes fallback row + duplicate section, add stepfun/lmstudio to --provider enum, expand auth/mcp/curator subcommand lists to match --help output (status/logout/spotify, login, archive/prune/ list-archived). - slash-commands.md: add missing /sessions and /reload-skills entries + correct the cross-platform Notes line. - tools-reference.md: drop bogus '68 tools' headline, drop fictional 'browser-cdp toolset' (these tools live in 'browser' and are runtime-gated), add missing 'kanban' and 'video' toolset sections, fix MCP example to use the real mcp_<server>_<tool> prefix. - toolsets-reference.md: list browser_cdp/browser_dialog inside the 'browser' row, add missing 'kanban' and 'video' toolset rows, drop the stale '38 tools' count for hermes-cli. - profile-commands.md: add missing install/update/info subcommands, document fish completion. - environment-variables.md: dedupe GMI_API_KEY/GMI_BASE_URL rows (kept the one with the correct gmi-serving.com default). - faq.md: Anthropic/Google/OpenAI examples — direct providers exist (not just via OpenRouter), refresh the OpenAI model list. getting-started/ - installation.md: PortableGit (not MinGit) is what the Windows installer fetches; document the 32-bit MinGit fallback. - installation.md / termux.md: installer prefers .[termux-all] then falls back to .[termux]. - nix-setup.md: Python 3.12 (not 3.11), Node.js 22 (not 20); fix invalid 'nix flake update --flake' invocation. - updating.md: 'hermes backup restore --state pre-update' doesn't exist — point at the snapshot/quick-snapshot flow; correct config key 'updates.pre_update_backup' (was 'update.backup'). user-guide/ - configuration.md: api_max_retries default 3 (not 2); display.runtime_footer is the real key (not display.runtime_metadata_footer); checkpoints defaults enabled=false / max_snapshots=20 (not true / 50). - configuring-models.md: 'hermes model list' / 'hermes model set ...' don't exist — hermes model is interactive only. - tui.md: busy_indicator -> tui_status_indicator with values kaomoji|emoji|unicode|ascii (not kawaii|minimal|dots|wings|none). - security.md: SSH backend keys (TERMINAL_SSH_HOST/USER/KEY) live in .env, not config.yaml. - windows-wsl-quickstart.md: there is no 'hermes api' subcommand — the OpenAI-compatible API server runs inside hermes gateway. user-guide/features/ - computer-use.md: approvals.mode (not security.approval_level); fix broken ./browser-use.md link to ./browser.md. - fallback-providers.md: top-level fallback_providers (not model.fallback_providers); the picker is subcommand-based, not modal. - api-server.md: API_SERVER_* are env vars — write to per-profile .env, not 'hermes config set' which targets YAML. - web-search.md: drop web_crawl as a registered tool (it isn't); deep-crawl modes are exposed through web_extract. - kanban.md: failure_limit default is 2, not '~5'. - plugins.md: drop hard-coded '33 providers' count. - honcho.md: fix unclosed quote in echo HONCHO_API_KEY snippet; document that 'hermes honcho' subcommand is gated on memory.provider=honcho; reconcile subcommand list with actual --help output. - memory-providers.md: legacy 'hermes honcho setup' redirect documented. Verified via 'npm run build' — site builds cleanly; broken-link count went from 149 to 146 (no regressions, fixed a few in passing). * docs: round 2 audit fixes + regenerate skill catalogs Follow-up to the previous commit on this branch: Round 2 manual fixes: - quickstart.md: KIMI_CODING_API_KEY mentioned alongside KIMI_API_KEY; voice-mode and ACP install commands rewritten — bare 'pip install ...' doesn't work for curl-installed setups (no pip on PATH, not in repo dir); replaced with 'cd ~/.hermes/hermes-agent && uv pip install -e ".[voice]"'. ACP already ships in [all] so the curl install includes it. - cli.md / configuration.md: 'auxiliary.compression.model' shown as 'google/gemini-3-flash-preview' (the doc's own claimed default); actual default is empty (= use main model). Reworded as 'leave empty (default) or pin a cheap model'. - built-in-plugins.md: added the bundled 'kanban/dashboard' plugin row that was missing from the table. Regenerated skill catalogs: - ran website/scripts/generate-skill-docs.py to refresh all 163 per-skill pages and both reference catalogs (skills-catalog.md, optional-skills-catalog.md). This adds the entries that were genuinely missing — productivity/teams-meeting-pipeline (bundled), optional/finance/* (entire category — 7 skills: 3-statement-model, comps-analysis, dcf-model, excel-author, lbo-model, merger-model, pptx-author), creative/hyperframes, creative/kanban-video-orchestrator, devops/watchers, productivity/shop-app, research/searxng-search, apple/macos-computer-use — and rewrites every other per-skill page from the current SKILL.md. Most diffs are tiny (one line of refreshed metadata). Validation: - 'npm run build' succeeded. - Broken-link count moved 146 -> 155 — the +9 are zh-Hans translation shells that lag every newly-added skill page (pre-existing pattern). No regressions on any en/ page.
378 lines
8.4 KiB
Markdown
378 lines
8.4 KiB
Markdown
---
|
|
title: "Pinecone — Managed vector database for production AI applications"
|
|
sidebar_label: "Pinecone"
|
|
description: "Managed vector database for production AI applications"
|
|
---
|
|
|
|
{/* This page is auto-generated from the skill's SKILL.md by website/scripts/generate-skill-docs.py. Edit the source SKILL.md, not this page. */}
|
|
|
|
# Pinecone
|
|
|
|
Managed vector database for production AI applications. Fully managed, auto-scaling, with hybrid search (dense + sparse), metadata filtering, and namespaces. Low latency (<100ms p95). Use for production RAG, recommendation systems, or semantic search at scale. Best for serverless, managed infrastructure.
|
|
|
|
## Skill metadata
|
|
|
|
| | |
|
|
|---|---|
|
|
| Source | Optional — install with `hermes skills install official/mlops/pinecone` |
|
|
| Path | `optional-skills/mlops/pinecone` |
|
|
| Version | `1.0.0` |
|
|
| Author | Orchestra Research |
|
|
| License | MIT |
|
|
| Dependencies | `pinecone-client` |
|
|
| Platforms | linux, macos, windows |
|
|
| Tags | `RAG`, `Pinecone`, `Vector Database`, `Managed Service`, `Serverless`, `Hybrid Search`, `Production`, `Auto-Scaling`, `Low Latency`, `Recommendations` |
|
|
|
|
## Reference: full SKILL.md
|
|
|
|
:::info
|
|
The following is the complete skill definition that Hermes loads when this skill is triggered. This is what the agent sees as instructions when the skill is active.
|
|
:::
|
|
|
|
# Pinecone - Managed Vector Database
|
|
|
|
The vector database for production AI applications.
|
|
|
|
## When to use Pinecone
|
|
|
|
**Use when:**
|
|
- Need managed, serverless vector database
|
|
- Production RAG applications
|
|
- Auto-scaling required
|
|
- Low latency critical (<100ms)
|
|
- Don't want to manage infrastructure
|
|
- Need hybrid search (dense + sparse vectors)
|
|
|
|
**Metrics**:
|
|
- Fully managed SaaS
|
|
- Auto-scales to billions of vectors
|
|
- **p95 latency <100ms**
|
|
- 99.9% uptime SLA
|
|
|
|
**Use alternatives instead**:
|
|
- **Chroma**: Self-hosted, open-source
|
|
- **FAISS**: Offline, pure similarity search
|
|
- **Weaviate**: Self-hosted with more features
|
|
|
|
## Quick start
|
|
|
|
### Installation
|
|
|
|
```bash
|
|
pip install pinecone-client
|
|
```
|
|
|
|
### Basic usage
|
|
|
|
```python
|
|
from pinecone import Pinecone, ServerlessSpec
|
|
|
|
# Initialize
|
|
pc = Pinecone(api_key="your-api-key")
|
|
|
|
# Create index
|
|
pc.create_index(
|
|
name="my-index",
|
|
dimension=1536, # Must match embedding dimension
|
|
metric="cosine", # or "euclidean", "dotproduct"
|
|
spec=ServerlessSpec(cloud="aws", region="us-east-1")
|
|
)
|
|
|
|
# Connect to index
|
|
index = pc.Index("my-index")
|
|
|
|
# Upsert vectors
|
|
index.upsert(vectors=[
|
|
{"id": "vec1", "values": [0.1, 0.2, ...], "metadata": {"category": "A"}},
|
|
{"id": "vec2", "values": [0.3, 0.4, ...], "metadata": {"category": "B"}}
|
|
])
|
|
|
|
# Query
|
|
results = index.query(
|
|
vector=[0.1, 0.2, ...],
|
|
top_k=5,
|
|
include_metadata=True
|
|
)
|
|
|
|
print(results["matches"])
|
|
```
|
|
|
|
## Core operations
|
|
|
|
### Create index
|
|
|
|
```python
|
|
# Serverless (recommended)
|
|
pc.create_index(
|
|
name="my-index",
|
|
dimension=1536,
|
|
metric="cosine",
|
|
spec=ServerlessSpec(
|
|
cloud="aws", # or "gcp", "azure"
|
|
region="us-east-1"
|
|
)
|
|
)
|
|
|
|
# Pod-based (for consistent performance)
|
|
from pinecone import PodSpec
|
|
|
|
pc.create_index(
|
|
name="my-index",
|
|
dimension=1536,
|
|
metric="cosine",
|
|
spec=PodSpec(
|
|
environment="us-east1-gcp",
|
|
pod_type="p1.x1"
|
|
)
|
|
)
|
|
```
|
|
|
|
### Upsert vectors
|
|
|
|
```python
|
|
# Single upsert
|
|
index.upsert(vectors=[
|
|
{
|
|
"id": "doc1",
|
|
"values": [0.1, 0.2, ...], # 1536 dimensions
|
|
"metadata": {
|
|
"text": "Document content",
|
|
"category": "tutorial",
|
|
"timestamp": "2025-01-01"
|
|
}
|
|
}
|
|
])
|
|
|
|
# Batch upsert (recommended)
|
|
vectors = [
|
|
{"id": f"vec{i}", "values": embedding, "metadata": metadata}
|
|
for i, (embedding, metadata) in enumerate(zip(embeddings, metadatas))
|
|
]
|
|
|
|
index.upsert(vectors=vectors, batch_size=100)
|
|
```
|
|
|
|
### Query vectors
|
|
|
|
```python
|
|
# Basic query
|
|
results = index.query(
|
|
vector=[0.1, 0.2, ...],
|
|
top_k=10,
|
|
include_metadata=True,
|
|
include_values=False
|
|
)
|
|
|
|
# With metadata filtering
|
|
results = index.query(
|
|
vector=[0.1, 0.2, ...],
|
|
top_k=5,
|
|
filter={"category": {"$eq": "tutorial"}}
|
|
)
|
|
|
|
# Namespace query
|
|
results = index.query(
|
|
vector=[0.1, 0.2, ...],
|
|
top_k=5,
|
|
namespace="production"
|
|
)
|
|
|
|
# Access results
|
|
for match in results["matches"]:
|
|
print(f"ID: {match['id']}")
|
|
print(f"Score: {match['score']}")
|
|
print(f"Metadata: {match['metadata']}")
|
|
```
|
|
|
|
### Metadata filtering
|
|
|
|
```python
|
|
# Exact match
|
|
filter = {"category": "tutorial"}
|
|
|
|
# Comparison
|
|
filter = {"price": {"$gte": 100}} # $gt, $gte, $lt, $lte, $ne
|
|
|
|
# Logical operators
|
|
filter = {
|
|
"$and": [
|
|
{"category": "tutorial"},
|
|
{"difficulty": {"$lte": 3}}
|
|
]
|
|
} # Also: $or
|
|
|
|
# In operator
|
|
filter = {"tags": {"$in": ["python", "ml"]}}
|
|
```
|
|
|
|
## Namespaces
|
|
|
|
```python
|
|
# Partition data by namespace
|
|
index.upsert(
|
|
vectors=[{"id": "vec1", "values": [...]}],
|
|
namespace="user-123"
|
|
)
|
|
|
|
# Query specific namespace
|
|
results = index.query(
|
|
vector=[...],
|
|
namespace="user-123",
|
|
top_k=5
|
|
)
|
|
|
|
# List namespaces
|
|
stats = index.describe_index_stats()
|
|
print(stats['namespaces'])
|
|
```
|
|
|
|
## Hybrid search (dense + sparse)
|
|
|
|
```python
|
|
# Upsert with sparse vectors
|
|
index.upsert(vectors=[
|
|
{
|
|
"id": "doc1",
|
|
"values": [0.1, 0.2, ...], # Dense vector
|
|
"sparse_values": {
|
|
"indices": [10, 45, 123], # Token IDs
|
|
"values": [0.5, 0.3, 0.8] # TF-IDF scores
|
|
},
|
|
"metadata": {"text": "..."}
|
|
}
|
|
])
|
|
|
|
# Hybrid query
|
|
results = index.query(
|
|
vector=[0.1, 0.2, ...],
|
|
sparse_vector={
|
|
"indices": [10, 45],
|
|
"values": [0.5, 0.3]
|
|
},
|
|
top_k=5,
|
|
alpha=0.5 # 0=sparse, 1=dense, 0.5=hybrid
|
|
)
|
|
```
|
|
|
|
## LangChain integration
|
|
|
|
```python
|
|
from langchain_pinecone import PineconeVectorStore
|
|
from langchain_openai import OpenAIEmbeddings
|
|
|
|
# Create vector store
|
|
vectorstore = PineconeVectorStore.from_documents(
|
|
documents=docs,
|
|
embedding=OpenAIEmbeddings(),
|
|
index_name="my-index"
|
|
)
|
|
|
|
# Query
|
|
results = vectorstore.similarity_search("query", k=5)
|
|
|
|
# With metadata filter
|
|
results = vectorstore.similarity_search(
|
|
"query",
|
|
k=5,
|
|
filter={"category": "tutorial"}
|
|
)
|
|
|
|
# As retriever
|
|
retriever = vectorstore.as_retriever(search_kwargs={"k": 10})
|
|
```
|
|
|
|
## LlamaIndex integration
|
|
|
|
```python
|
|
from llama_index.vector_stores.pinecone import PineconeVectorStore
|
|
|
|
# Connect to Pinecone
|
|
pc = Pinecone(api_key="your-key")
|
|
pinecone_index = pc.Index("my-index")
|
|
|
|
# Create vector store
|
|
vector_store = PineconeVectorStore(pinecone_index=pinecone_index)
|
|
|
|
# Use in LlamaIndex
|
|
from llama_index.core import StorageContext, VectorStoreIndex
|
|
|
|
storage_context = StorageContext.from_defaults(vector_store=vector_store)
|
|
index = VectorStoreIndex.from_documents(documents, storage_context=storage_context)
|
|
```
|
|
|
|
## Index management
|
|
|
|
```python
|
|
# List indices
|
|
indexes = pc.list_indexes()
|
|
|
|
# Describe index
|
|
index_info = pc.describe_index("my-index")
|
|
print(index_info)
|
|
|
|
# Get index stats
|
|
stats = index.describe_index_stats()
|
|
print(f"Total vectors: {stats['total_vector_count']}")
|
|
print(f"Namespaces: {stats['namespaces']}")
|
|
|
|
# Delete index
|
|
pc.delete_index("my-index")
|
|
```
|
|
|
|
## Delete vectors
|
|
|
|
```python
|
|
# Delete by ID
|
|
index.delete(ids=["vec1", "vec2"])
|
|
|
|
# Delete by filter
|
|
index.delete(filter={"category": "old"})
|
|
|
|
# Delete all in namespace
|
|
index.delete(delete_all=True, namespace="test")
|
|
|
|
# Delete entire index
|
|
index.delete(delete_all=True)
|
|
```
|
|
|
|
## Best practices
|
|
|
|
1. **Use serverless** - Auto-scaling, cost-effective
|
|
2. **Batch upserts** - More efficient (100-200 per batch)
|
|
3. **Add metadata** - Enable filtering
|
|
4. **Use namespaces** - Isolate data by user/tenant
|
|
5. **Monitor usage** - Check Pinecone dashboard
|
|
6. **Optimize filters** - Index frequently filtered fields
|
|
7. **Test with free tier** - 1 index, 100K vectors free
|
|
8. **Use hybrid search** - Better quality
|
|
9. **Set appropriate dimensions** - Match embedding model
|
|
10. **Regular backups** - Export important data
|
|
|
|
## Performance
|
|
|
|
| Operation | Latency | Notes |
|
|
|-----------|---------|-------|
|
|
| Upsert | ~50-100ms | Per batch |
|
|
| Query (p50) | ~50ms | Depends on index size |
|
|
| Query (p95) | ~100ms | SLA target |
|
|
| Metadata filter | ~+10-20ms | Additional overhead |
|
|
|
|
## Pricing (as of 2025)
|
|
|
|
**Serverless**:
|
|
- $0.096 per million read units
|
|
- $0.06 per million write units
|
|
- $0.06 per GB storage/month
|
|
|
|
**Free tier**:
|
|
- 1 serverless index
|
|
- 100K vectors (1536 dimensions)
|
|
- Great for prototyping
|
|
|
|
## Resources
|
|
|
|
- **Website**: https://www.pinecone.io
|
|
- **Docs**: https://docs.pinecone.io
|
|
- **Console**: https://app.pinecone.io
|
|
- **Pricing**: https://www.pinecone.io/pricing
|