Ollama-OpenWebUIは、ChatGPTのようなインターフェイスでローカルLLMが使える無料のツールです。
Ollamaを使えば、DeepSeek-R1やLlamaなどの人気LLMをローカル環境で動かすことができます。
この記事では、Ollama-OpenWebUIの環境構築からモデルを使ったテキスト生成の方法まで紹介します。
Ollama-OpenWebUIとは
data:image/s3,"s3://crabby-images/0f124/0f1241b0c6f2825790e933dbe576010a6342a7c9" alt="テキスト生成"
Ollamaは、ローカル環境でLLMモデルを動かすことができる無料のツールです。
DeepSeek-R1やLlamaなど人気モデルをダウンロードして、APIを使わずにLLMをローカルで実行できます。
さらにOpenWebUIを併用することで、ChatGPTのような分かりやすいインターフェイスが利用できます。
OllamaをPythonで使用する方法は?
data:image/s3,"s3://crabby-images/1b0c8/1b0c8674c2d3e0708102cacbb23e9d84386bfed6" alt=""
Ollama-OpenWebUIの実行環境
data:image/s3,"s3://crabby-images/07fc8/07fc8e43c20b1b178a59b91abde04322a11fa26c" alt="見出し画像"
LLMのモデルを使う際に、GPUが必要になります。
この記事では、次のようなGPUを搭載した環境を用意しています。
- GPU:NVIDIA A100
- GPUメモリ(VRAM:80GB)
- OS:Ubuntu 22.04LTS
WindowsにUbuntuをインストールするには?
data:image/s3,"s3://crabby-images/194fe/194fe4d715a04d4f79ee4861aac448bf7d812a2d" alt=""
Ollama-OpenWebUIの環境構築
data:image/s3,"s3://crabby-images/bc4f5/bc4f532cd6bf4c632c5ce7f379ae2f455d26eb46" alt="見出し画像"
この記事では、OllamaとOpenWebUIの2つのDockerコンテナを使って構築します。
Ollamaはモデルによるテキスト生成を行い、OpenWebUIはインターフェースを提供する役割になります。
Dockerの詳しい使い方を解説!
data:image/s3,"s3://crabby-images/fda1e/fda1e29fa1162024faa6c1fd88e7e77c099bb608" alt=""
docker-compose.ymlを作成します。
mkdir ollama
cd ollama
nano docker-compose.yml
開いたdocker-compose.ymlファイルに以下の記述をコピーして貼りつけます。
services:
ollama:
image: ollama/ollama
runtime: nvidia
container_name: ollama
ports:
- "11434:11434"
volumes:
- .:/app/ollama
deploy:
resources:
reservations:
devices:
- driver: nvidia
count: 1
capabilities: [gpu]
open-webui:
image: ghcr.io/open-webui/open-webui:main
ports:
- "8080:8080"
volumes:
- .:/app/open_webui
extra_hosts:
- "host.docker.internal:host-gateway"
volumes:
ollama:
open-webui:
docker-compose.ymlの記述をもとに、Dockerコンテナを構築して起動します。
docker compose up
コンテナが起動したら、ローカルPCの「ブラウザの検索窓」に以下のURLを入力し、Enterを押すとOllamaの画面が表示されます。
http://localhost:8080/
Ollama-OpenWebUIの画面に遷移したら、「Get Started」をクリックします。
data:image/s3,"s3://crabby-images/586df/586df7dad1d9a402830ff8e9463aee66b0686a82" alt="openwebui"
「名前」「メールアドレス」「パスワード」を設定し、「Create Admin Account」をクリックすると、ログインが完了です。
data:image/s3,"s3://crabby-images/5e904/5e9048b696c3ba03cf6875399482ed1cfa259aeb" alt="openwebui"
Ollamaにモデルを設定していきます。
右下の[丸い]アイコンをクリックし、「Settings」を開きます。
data:image/s3,"s3://crabby-images/edc1e/edc1e699bbda4d3316c0426e7cbaf061fd9dae69" alt="openwebui"
サイドバーから「General」を選択し、「Language」のプルダウンから「Japanese(日本語)」を選択します。
data:image/s3,"s3://crabby-images/8da86/8da8694a41c2cd0f1147068d21c796b48e86cf51" alt="openwebui"
「システムプロンプト」に「あなたは日本語で回答するアシスタントです」と入力し、「保存ボタン」を押します。
data:image/s3,"s3://crabby-images/0d82b/0d82b17fe51ed8460db621df581e4ef6d73d4594" alt="openwebui"
ヘッダーの「モデルを選択」をクリックし、検索窓に「モデルID」(例:deepseek-r1:32b)を入力し、「Ollama.comから”モデルID”をプル」をクリックすると、モデルのダウンロードが開始します。
data:image/s3,"s3://crabby-images/5e012/5e012c7915d272dc3ea7fac252391f4241f003a7" alt="openwebui"
モデルIDは、Ollama公式サイトから確認ができます。
- deepseek-r1:1.5b
- deepseek-r1:32b
- llama3.2
- llama3.2:1b
data:image/s3,"s3://crabby-images/b4a02/b4a024cf180ecc791d681c5ac3bf4d959b8025de" alt="openwebui"
ヘッダーの「モデルを選択」をクリックし、ダンロードした「モデルID」(例:deepseek-r1:32b)を選択するとモデルの設定が完了です。
data:image/s3,"s3://crabby-images/c0f19/c0f1949324dbaf7ef24f84c3b51da9d0cc64dec3" alt="openwebui"
Ollama-OpenWebUIで日本語LLMを使うには?
data:image/s3,"s3://crabby-images/29f23/29f23bedcbfb2f0e3004f2b7e9abaa3f11558e92" alt=""
OllamaをPythonで使う方法は?
data:image/s3,"s3://crabby-images/1b0c8/1b0c8674c2d3e0708102cacbb23e9d84386bfed6" alt=""
Ollama-OpenWebUIでテキスト生成
data:image/s3,"s3://crabby-images/69e18/69e184466f8be0689d18b7a3023e39e518874387" alt="見出し画像"
Ollama-OpenWebUIを使ってテキスト生成をしてみます。
「プロンプト」を入力して、「上矢印」ボタンを押すと、LLMが回答を開始します。
data:image/s3,"s3://crabby-images/2bad9/2bad9a559059c6f5d43647473fafbdd8305ec2ee" alt="openwebui"
data:image/s3,"s3://crabby-images/03dec/03dec45b99405358f2f572dce6013bdf737e30d9" alt="openwebui"
Ollama-OpenWebUIで複数のモデルを同時実行する
data:image/s3,"s3://crabby-images/a71c2/a71c2c24db1bae01abb8693c9844cb7821d1ab99" alt="見出し画像"
Ollama-OpenWebUIで複数のモデルを同時に実行してみます。
ヘッダーから「+」ボタンを押し、「モデルを選択」をクリックします。
検索窓に「モデルID」(例deepseek-r1:14b)を入力し、「Ollama.comから”モデルID”をプル」を選択します。
data:image/s3,"s3://crabby-images/1f22f/1f22f076de022db26ae9f82e9846fc8f22506a1f" alt="openwebui"
モデルのダウンロードが完了したら、「モデルを選択」をクリックし、「モデルID」(例deepseek-r1:14b)を選択します。
data:image/s3,"s3://crabby-images/3eea0/3eea0a92c5c10508fe00fe33f9b7e0a061e21662" alt="openwebui"
「プロンプト」を入力し、「上矢印」ボタンを押します。
data:image/s3,"s3://crabby-images/08d73/08d7378b5638f551b3d89e6af7750805b8220626" alt="openwebui"
複数のモデルからテキストが生成されていることが分かります!
data:image/s3,"s3://crabby-images/ce36a/ce36aea69954d6cae5d5d3b3d376264fa81f3a0a" alt="openwebui"
生成AI・LLMのコストでお困りなら
GPUのスペック不足で生成AIの開発が思うように進まないことはありませんか?
そんなときには、高性能なGPUをリーズナブルな価格で使えるGPUクラウドサービスがおすすめです!
data:image/s3,"s3://crabby-images/f6868/f6868900a03e9efc73f1630b5883afb6dfa644b8" alt="GPUSOROBAN"
GPUSOROBANは、高性能GPU「NVIDIA H200」を業界最安級の料金で使用することができます。
NVIDIA H200は、生成AI・LLMの計算にかかる時間を大幅に短縮することが可能です。
クラウドで使えるため、大規模な設備投資の必要がなく、煩雑なサーバー管理からも解放されます。