mirror of
https://github.com/hwchase17/langchain.git
synced 2026-04-04 11:25:11 +00:00
Use docusaurus versioning with a callout, merged master as well @hwchase17 @baskaryan --------- Signed-off-by: Weichen Xu <weichen.xu@databricks.com> Signed-off-by: Rahul Tripathi <rauhl.psit.ec@gmail.com> Co-authored-by: Leonid Ganeline <leo.gan.57@gmail.com> Co-authored-by: Leonid Kuligin <lkuligin@yandex.ru> Co-authored-by: Averi Kitsch <akitsch@google.com> Co-authored-by: Erick Friis <erick@langchain.dev> Co-authored-by: Nuno Campos <nuno@langchain.dev> Co-authored-by: Nuno Campos <nuno@boringbits.io> Co-authored-by: Bagatur <22008038+baskaryan@users.noreply.github.com> Co-authored-by: Eugene Yurtsev <eyurtsev@gmail.com> Co-authored-by: Martín Gotelli Ferenaz <martingotelliferenaz@gmail.com> Co-authored-by: Fayfox <admin@fayfox.com> Co-authored-by: Eugene Yurtsev <eugene@langchain.dev> Co-authored-by: Dawson Bauer <105886620+djbauer2@users.noreply.github.com> Co-authored-by: Ravindu Somawansa <ravindu.somawansa@gmail.com> Co-authored-by: Dhruv Chawla <43818888+Dominastorm@users.noreply.github.com> Co-authored-by: ccurme <chester.curme@gmail.com> Co-authored-by: Bagatur <baskaryan@gmail.com> Co-authored-by: WeichenXu <weichen.xu@databricks.com> Co-authored-by: Benito Geordie <89472452+benitoThree@users.noreply.github.com> Co-authored-by: kartikTAI <129414343+kartikTAI@users.noreply.github.com> Co-authored-by: Kartik Sarangmath <kartik@thirdai.com> Co-authored-by: Sevin F. Varoglu <sfvaroglu@octoml.ai> Co-authored-by: MacanPN <martin.triska@gmail.com> Co-authored-by: Prashanth Rao <35005448+prrao87@users.noreply.github.com> Co-authored-by: Hyeongchan Kim <kozistr@gmail.com> Co-authored-by: sdan <git@sdan.io> Co-authored-by: Guangdong Liu <liugddx@gmail.com> Co-authored-by: Rahul Triptahi <rahul.psit.ec@gmail.com> Co-authored-by: Rahul Tripathi <rauhl.psit.ec@gmail.com> Co-authored-by: pjb157 <84070455+pjb157@users.noreply.github.com> Co-authored-by: Eun Hye Kim <ehkim1440@gmail.com> Co-authored-by: kaijietti <43436010+kaijietti@users.noreply.github.com> Co-authored-by: Pengcheng Liu <pcliu.fd@gmail.com> Co-authored-by: Tomer Cagan <tomer@tomercagan.com> Co-authored-by: Christophe Bornet <cbornet@hotmail.com>
102 lines
2.5 KiB
Plaintext
102 lines
2.5 KiB
Plaintext
# Xorbits Inference (Xinference)
|
|
|
|
This page demonstrates how to use [Xinference](https://github.com/xorbitsai/inference)
|
|
with LangChain.
|
|
|
|
`Xinference` is a powerful and versatile library designed to serve LLMs,
|
|
speech recognition models, and multimodal models, even on your laptop.
|
|
With Xorbits Inference, you can effortlessly deploy and serve your or
|
|
state-of-the-art built-in models using just a single command.
|
|
|
|
## Installation and Setup
|
|
|
|
Xinference can be installed via pip from PyPI:
|
|
|
|
```bash
|
|
pip install "xinference[all]"
|
|
```
|
|
|
|
## LLM
|
|
|
|
Xinference supports various models compatible with GGML, including chatglm, baichuan, whisper,
|
|
vicuna, and orca. To view the builtin models, run the command:
|
|
|
|
```bash
|
|
xinference list --all
|
|
```
|
|
|
|
|
|
### Wrapper for Xinference
|
|
|
|
You can start a local instance of Xinference by running:
|
|
|
|
```bash
|
|
xinference
|
|
```
|
|
|
|
You can also deploy Xinference in a distributed cluster. To do so, first start an Xinference supervisor
|
|
on the server you want to run it:
|
|
|
|
```bash
|
|
xinference-supervisor -H "${supervisor_host}"
|
|
```
|
|
|
|
|
|
Then, start the Xinference workers on each of the other servers where you want to run them on:
|
|
|
|
```bash
|
|
xinference-worker -e "http://${supervisor_host}:9997"
|
|
```
|
|
|
|
You can also start a local instance of Xinference by running:
|
|
|
|
```bash
|
|
xinference
|
|
```
|
|
|
|
Once Xinference is running, an endpoint will be accessible for model management via CLI or
|
|
Xinference client.
|
|
|
|
For local deployment, the endpoint will be http://localhost:9997.
|
|
|
|
|
|
For cluster deployment, the endpoint will be http://${supervisor_host}:9997.
|
|
|
|
|
|
Then, you need to launch a model. You can specify the model names and other attributes
|
|
including model_size_in_billions and quantization. You can use command line interface (CLI) to
|
|
do it. For example,
|
|
|
|
```bash
|
|
xinference launch -n orca -s 3 -q q4_0
|
|
```
|
|
|
|
A model uid will be returned.
|
|
|
|
Example usage:
|
|
|
|
```python
|
|
from langchain_community.llms import Xinference
|
|
|
|
llm = Xinference(
|
|
server_url="http://0.0.0.0:9997",
|
|
model_uid = {model_uid} # replace model_uid with the model UID return from launching the model
|
|
)
|
|
|
|
llm(
|
|
prompt="Q: where can we visit in the capital of France? A:",
|
|
generate_config={"max_tokens": 1024, "stream": True},
|
|
)
|
|
|
|
```
|
|
|
|
### Usage
|
|
|
|
For more information and detailed examples, refer to the
|
|
[example for xinference LLMs](/docs/integrations/llms/xinference)
|
|
|
|
### Embeddings
|
|
|
|
Xinference also supports embedding queries and documents. See
|
|
[example for xinference embeddings](/docs/integrations/text_embedding/xinference)
|
|
for a more detailed demo. |