๐ Troubleshooting
This page is a list of common gotchas or issues and how to fix them.
If you don't see your problem listed here, please also search the Github Issues.
Using .get or .query, embeddings say None
โ
This is actually not an error. Embeddings are quite large and heavy to send back. Most application don't use the underlying embeddings and so, by default, chroma does not send them back.
To send them back: add include=["embeddings", "documents", "metadatas", "distances"]
to your query to return all information.
For example:
results = collection.query(
query_texts="hello",
n_results=1,
include=["embeddings", "documents", "metadatas", "distances"],
)
We may change None
to something else to more clearly communicate why they were not returned.
Build error when running pip install chromadb
โ
If you encounter an error like this during setup
Failed to build hnswlib
ERROR: Could not build wheels for hnswlib, which is required to install pyproject.toml-based projects
Try these few tips from the community:
- If you get the error:
clang: error: the clang compiler does not support '-march=native'
, set this ENV variable,export HNSWLIB_NO_NATIVE=1
- If on Mac, install/update xcode dev tools,
xcode-select --install
- If on Windows, try these steps
SQLiteโ
Chroma requires SQLite > 3.35, if you encounter issues with having too low of a SQLite version please try the following.
- Install the latest version of Python 3.10, sometimes lower versions of python are bundled with older versions of SQLite.
- If you are on a Linux system, you can install pysqlite3-binary,
pip install pysqlite3-binary
and then override the default sqlite3 library before running Chroma with the steps here. Alternatively you can compile SQLite from scratch and replace the library in your python installation with the latest version as documented here. - If you are on Windows, you can manually download the latest version of SQLite from https://www.sqlite.org/download.html and
replace the DLL in your python installation's DLLs folder with the latest version. You can find your python installation path by running
os.path.dirname(sys.executable)
in python. - If you are using a Debian based Docker container, older Debian versions do not have an up to date SQLite, please use
bookworm
or higher.
Illegal instruction (core dumped)โ
If you encounter an error like this during setup and are using Docker - you may have built the library on a machine with a different CPU architecture than the one you are running it on. Try rebuilding the Docker image on the machine you are running it on.