Spaces:
Runtime error
Runtime error
# Mac Installation Guide | |
## **Recommended : [Docker Install](docker_install.md)** | |
--- | |
## **Manual Installation** | |
## Install the prerequisites: | |
- Install Homebrew (if not already installed) by following the instructions on https://brew.sh/ | |
- Install Node.js and npm by running `brew install node` | |
- Install MongoDB (if not using Docker) by running `brew tap mongodb/brew` and `brew install mongodb-community` | |
## Instructions: | |
- Open Terminal and clone the repository by running `git clone https://github.com/danny-avila/LibreChat.git` | |
- Change into the cloned directory by running cd LibreChat | |
- If using MongoDB Atlas, remove &w=majority from the default connection string | |
Follow the instructions for setting up proxies, access tokens, and user system: | |
## [Create a MongoDB database](mongodb.md) (Required) | |
## [Get Your API keys and Tokens](apis_and_tokens.md) (Required) | |
- You must set up at least one of these tokens or APIs to run the app. | |
## [User/Auth System](../install/user_auth_system.md) (Optional) | |
- How to set up the user/auth system and Google login. | |
## Setup Instruction | |
- Create a .env file in the api directory by running `cp .env.example .env` and edit the file with your preferred text editor, adding the required API keys, access tokens, and MongoDB connection string | |
- Run npm ci from root directory `npm ci` | |
- Build the client by running `npm run frontend` | |
### **Download MeiliSearch for macOS (optional):** | |
- You can download the latest MeiliSearch binary for macOS from their GitHub releases page: https://github.com/meilisearch/MeiliSearch/releases. Look for the file named meilisearch-macos-amd64 (or the equivalent for your system architecture) and download it. | |
### **Make the binary executable:** | |
- Open Terminal and navigate to the directory where you downloaded the MeiliSearch binary. Run the following command to make it executable: | |
``` | |
chmod +x meilisearch-macos-amd64 | |
``` | |
### **Run MeiliSearch:** | |
- Now that the binary is executable, you can start MeiliSearch by running the following command, replacing your_master_key_goes_here with your desired master key: | |
``` | |
./meilisearch-macos-amd64 --master-key your_master_key_goes_here | |
``` | |
- MeiliSearch will start running on the default port, which is 7700. You can now use MeiliSearch in your LibreChat project. | |
- Remember to include the MeiliSearch URL and Master Key in your .env file in the api directory. Your .env file should include the following lines: | |
``` | |
MEILISEARCH_URL=http://127.0.0.1:7700 | |
MEILISEARCH_KEY=your_master_key_goes_here | |
``` | |
- With MeiliSearch running and configured, the LibreChat project should now have the Conversation search feature enabled. | |
- In the LibreChat directory, start the application by running `npm run backend` | |
Visit http://localhost:3080 (default port) & enjoy | |
## Optional but recommended: | |
- Create a script to automate the starting process by creating a new file named start_chatgpt.sh in the LibreChat directory and pasting the following code: | |
``` bash title="LibreChat.sh" | |
#!/bin/bash | |
# Replace "your_master_key_goes_here" with your MeiliSearch Master Key | |
if [ -x "$(command -v ./meilisearch)" ]; then | |
./meilisearch --master-key your_master_key_goes_here & | |
fi | |
npm run backend | |
``` | |
### **Make the script executable by running** | |
``` | |
chmod +x start_chatgpt.sh | |
``` | |
### **Start LibreChat by running** | |
``` | |
./start_chatgpt.sh | |
``` | |
## **Update** | |
- run `git pull` from the root dir | |
- Run npm ci from root directory `npm ci` | |
- Build the client by running `npm run frontend` | |
--- | |
### Note: If you're still having trouble, before creating a new issue, please search for similar ones on our [#issues thread on our discord](https://discord.gg/weqZFtD9C4) or our [troubleshooting discussion](https://github.com/danny-avila/LibreChat/discussions/categories/troubleshooting) on our Discussions page. If you don't find a relevant issue, feel free to create a new one and provide as much detail as possible. | |