We recommend when deploying Chat LangChain JS, you use Vercel for the frontend & edge API, and GitHub action for the recurring ingestion tasks. This setup provides a simple and effective way to deploy and manage your application.
First, fork chat-langchainjs to your GitHub account.
We'll use Weaviate for our vector store. You can sign up for an account here.
After creating an account click "Create Cluster". Follow the steps to create a new cluster. Once finished wait for the cluster to create, this may take a few minutes.
Once your cluster has been created you should see a few sections on the page. The first is the cluster URL. Save this as your WEAVIATE_URL
environment variable.
Next, click "API Keys" and save the API key in the environment variable WEAVIATE_API_KEY
.
The final Weaviate environment variable is "WEAVIATE_INDEX_NAME". This is the name of the index you want to use. You can name it whatever you want, it must be capitalized for the Weaviate internal schema, for this example, we'll use "Langchain".
After this your vector store will be setup. We can now move onto the record manager.
Visit Supabase to create an account here.
Once you've created an account, click "New project" on the dashboard page. Follow the steps, saving the database password after creating it, we'll need this later.
Once your project is setup (this also takes a few minutes), navigate to the "Settings" tab, then select "Database" under "Configuration".
Here, you should see a "Connection string" section. Copy this string, and insert your database password you saved earlier. This is your RECORD_MANAGER_DB_URL
environment variable.
That's all you need to do for the record manager. The LangChain RecordManager API will handle creating tables for you.
Create a Vercel account for hosting here.
Once you've created your Vercel account, navigate to your dashboard and click the button "Add New..." in the top right. This will open a dropdown. From there select "Project".
On the next screen, search for "chat-langchainjs" (if you did not modify the repo name when forking). Once shown, click "Import".
Here you should only modify the "Environment Variables" section. You should add the following environment variables:
If you have not setup LangSmith, head to the LangSmith doc for instructions.
LANGCHAIN_TRACING_V2=true
LANGCHAIN_ENDPOINT="https://api.smith.langchain.com"
LANGCHAIN_API_KEY=YOUR_API_KEY
LANGCHAIN_PROJECT=YOUR_PROJECT
NEXT_PUBLIC_VERCEL_URL=YOUR_VERCEL_DOMAIN_PUBLIC_URL
WEAVIATE_API_KEY=YOUR_API_KEY
WEAVIATE_URL=YOUR_WEAVIATE_URL
WEAVIATE_INDEX_NAME=Langchain
FORCE_UPDATE=true
RECORD_MANAGER_DB_URL=YOUR_DB_URL
OPENAI_API_KEY=YOUR_OPENAI_KEY
Finally, click "Deploy" and your frontend & edge API will be deployed.
Now, in order for your vector store to be updated with new data, you'll need to setup a recurring ingestion task (this will also populate the vector store for the first time).
Go to your forked repository, and navigate to the "Settings" tab.
Select "Environments" from the left-hand menu, and click "New environment". Enter the name "Indexing" and click "Configure environment".
When configuring, click "Add secret" and add the following secrets:
OPENAI_API_KEY=
RECORD_MANAGER_DB_URL=
WEAVIATE_API_KEY=
WEAVIATE_INDEX_NAME=Langchain
WEAVIATE_URL=
These should be the same secrets as were added to Vercel.
Next, navigate to the "Actions" tab and confirm you understand your workflows, and enable them.
Then, click on the "Update index" workflow, and click "Enable workflow". Finally, click on the "Run workflow" dropdown and click "Run workflow".
Once this has finished you can visit your production URL from Vercel, and start using the app!