[Local GPTs] Off the Grid, On Your Machine
Are you tired of the tech giants having access to your personal data? Are you concerned about snooping and telemetry? Then it’s time to take matters into your own hands by running a fully offline GPT model on your own local machine! By doing so, you can have privacy and security, as all processing will occur locally without any third-party involvement. Say goodbye to companies profiting from your personal information and take back control with a completely offline GPT model!
First things first, this post makes use of a configuration that I have access to (i.e. my laptop) but should work for anyone else too (with little tweaks). Below is my machine specs:
- Macbook Pro, M2 Pro Apple Silicon
- 16 Gb RAM
- 512 Gb SDD
- macOS Sonoma 14.3.1
Now, let us dive into setting up an offline, private and local GPT like ChatGPT but using an open source model.
Oh Lama π¦: Setup Ollama
<p>Note: Github project for Ollama can be found <a href="https://github.com/jmorganca/ollama" target="_blank" rel="noopener">here</a></p>
Ollama is a frontend built so you can easily get up and running with large language models on your local machine. You can run pre-trained models like Llama 2 and Code Llama, as well as customize and create your own models offline in a private and local environment. This allows you to have full control over your data and models, ensuring that they remain secure and confidential.
To begin with, install Ollama App + CLI using homebrew:
brew install --cask ollama
Once downloaded, open the application from Application Launchpad in macOS.
<p>If prompted, just select “Open” <img src="sc_11.png" alt="Screenshot" loading="lazy" /></p>
It will run a wizard to set everything up including running Ollama in the background. You can see Ollama running as an icon of lama in your menu bar π
After installing Ollama, verify that Ollama is running by accessing the following link in your web browser: http://127.0.0.1:11434/
Pull in Large Language Model(LLM)
Ollama is just the front end for interfacing with LLM models. You will need to download a model to work with.
<p>Note: These models are usualy quite big ranging from 3Gb to upwards of 60Gb, based on trillions of tokens they are trained on. You would need to have free disk space to download the model.</p>
Download one of the models mentioned here, by running the pull
command in Terminal:
ollama pull <name_of_model>
<p>where <code><name_of_model></code> is to be replaced with a valid name of model picked from the <a href="https://ollama.ai/library" target="_blank" rel="noopener">Ollama Model Library</a>.</p>
For demonstration purpose, let us download the llama2
model.
ollama pull llama2
You can use Ollama right away with the model you have downloaded, in a Chat style within the terminal by using the run
command
ollama run llama2
However, it would be much nicer if you could use a UI like ChatGPT and not have to work with Terminal, right?
That is what you will setup next π€
Setup Docker Desktop
To begin with, install Docker using homebrew:
brew install --cask docker
Once downloaded, open the application and it will run a wizard to set everything up including running Docker in background. You can see Docker running as an icon in your menu bar π
<p>Note: You do not need to sign in/sign up anything for using any funtionality mentioned in this post.</p>
Setup Open WebUI
Open WebUI is a user-friendly ChatGPT-Style Web Interface for LLMs (formerly known as Ollama WebUI). This will make it easier for you to talk to your GPT like you are used to, ChatGPT-Style.
To start it up, open Terminal app and run the below command
docker run -d -p 3000:8080 \
--add-host=host.docker.internal:host-gateway \
-v open-webui:/app/backend/data \
--name open-webui \
--restart always \
ghcr.io/open-webui/open-webui:main
This command starts the docker container and makes the Ollama Web UI available at port 3000 of localhost.
If you want to verify this, open Docker Desktop dashboard and you will see
Note: To upgrade your local docker image for open-webui to latest version, run
docker pull ghcr.io/open-webui/open-webui:main
echo "β
Pull the latest image tagged main of open webui"
docker container stop open-webui
echo "β
Stop existing open webui container"
docker container rm open-webui
echo "β
Remove existing open webui container"
docker run -d -p 3000:8080 \
--add-host=host.docker.internal:host-gateway \
-v open-webui:/app/backend/data \
--name open-webui \
--restart always \
ghcr.io/open-webui/open-webui:main
echo "β
Create and run the new container using the latest image of open webui"
At this point, you are done with the setup π
You can now access the Ollama Web UI Chat interface at http://localhost:3000.
<p>You might need to sign up as an Admin user for your first run. Simply create a username and password.</p>
Bonus: Adding more models
Ollama Model Library provides more than one variation of each model. You can find the other variations under the Tags tab on the model’s page. Also note the size of the model mentioned, to access if the model is not too big in size for your machine’s storage space.
ollama pull llama2:13b
Then go back to the Chat interface at http://localhost:3000 and select the model from drop down