Skip to content

Commit

Permalink
Implement ramalama run/serve
Browse files Browse the repository at this point in the history
Now we can run "ramalama run/serve granite-code", if not using
container, one must at least build/install llama.cpp

Signed-off-by: Eric Curtin <[email protected]>
  • Loading branch information
ericcurtin committed Jul 30, 2024
1 parent 3be60ba commit 87d7f04
Showing 1 changed file with 60 additions and 29 deletions.
89 changes: 60 additions & 29 deletions ramalama
Original file line number Diff line number Diff line change
Expand Up @@ -68,9 +68,9 @@ def run_curl_command(args, filename):
sys.exit(e.returncode)


def pull_ollama_manifest(ramalama_store, manifests, accept, registry_head, model_tag):
def pull_ollama_manifest(repos_ollama, manifests, accept, registry_head, model_tag):
os.makedirs(os.path.dirname(manifests), exist_ok=True)
os.makedirs(os.path.join(ramalama_store, "blobs"), exist_ok=True)
os.makedirs(os.path.join(repos_ollama, "blobs"), exist_ok=True)
curl_command = [
"curl", "-f", "-s", "--header", accept,
"-o", manifests,
Expand All @@ -79,9 +79,9 @@ def pull_ollama_manifest(ramalama_store, manifests, accept, registry_head, model
run_command(curl_command)


def pull_ollama_config_blob(ramalama_store, accept, registry_head, manifest_data):
def pull_ollama_config_blob(repos_ollama, accept, registry_head, manifest_data):
cfg_hash = manifest_data["config"]["digest"]
config_blob_path = os.path.join(ramalama_store, "blobs", cfg_hash)
config_blob_path = os.path.join(repos_ollama, "blobs", cfg_hash)
curl_command = [
"curl", "-f", "-s", "-L", "-C", "-", "--header", accept,
"-o", config_blob_path,
Expand All @@ -90,8 +90,8 @@ def pull_ollama_config_blob(ramalama_store, accept, registry_head, manifest_data
run_curl_command(curl_command, config_blob_path)


def pull_ollama_blob(ramalama_store, layer_digest, accept, registry_head, ramalama_models, model_name, model_tag, symlink_path):
layer_blob_path = os.path.join(ramalama_store, "blobs", layer_digest)
def pull_ollama_blob(repos_ollama, layer_digest, accept, registry_head, ramalama_models, model_name, model_tag, symlink_path):
layer_blob_path = os.path.join(repos_ollama, "blobs", layer_digest)
curl_command = ["curl", "-f", "-L", "-C", "-", "--progress-bar", "--header",
accept, "-o", layer_blob_path, f"{registry_head}/blobs/{layer_digest}"]
run_curl_command(curl_command, layer_blob_path)
Expand All @@ -105,7 +105,33 @@ def pull_ollama_blob(ramalama_store, layer_digest, accept, registry_head, ramala
sys.exit(e.returncode)


def pull_cli(ramalama_store, ramalama_models, model):
def init_pull(repos_ollama, manifests, accept, registry_head, model_name, model_tag, ramalama_models, symlink_path):
try:
pull_ollama_manifest(repos_ollama, manifests,
accept, registry_head, model_tag)
with open(manifests, 'r') as f:
manifest_data = json.load(f)
except subprocess.CalledProcessError as e:
if e.returncode == 22:
print_error(model_name + ":" + model_tag + " not found")
sys.exit(e.returncode)

pull_ollama_config_blob(repos_ollama, accept,
registry_head, manifest_data)
for layer in manifest_data["layers"]:
layer_digest = layer["digest"]
if layer["mediaType"] != 'application/vnd.ollama.image.model':
continue

pull_ollama_blob(repos_ollama, layer_digest, accept,
registry_head, ramalama_models, model_name, model_tag, symlink_path)

return symlink_path


def pull_cli(ramalama_store, model):
repos_ollama = ramalama_store + "/repos/ollama"
ramalama_models = ramalama_store + "/models/ollama"
registry_scheme = "https"
registry = "registry.ollama.ai"
model = "library/" + model
Expand All @@ -119,30 +145,23 @@ def pull_cli(ramalama_store, ramalama_models, model):
model_base = os.path.basename(model_name)
symlink_path = os.path.join(ramalama_models, f"{model_base}:{model_tag}")
if os.path.exists(symlink_path):
return
return symlink_path

manifests = os.path.join(ramalama_store, "manifests",
manifests = os.path.join(repos_ollama, "manifests",
registry, model_name, model_tag)
registry_head = f"{registry_scheme}://{registry}/v2/{model_name}"
try:
pull_ollama_manifest(ramalama_store, manifests,
accept, registry_head, model_tag)
with open(manifests, 'r') as f:
manifest_data = json.load(f)
except subprocess.CalledProcessError as e:
if e.returncode == 22:
print_error(model_name + ":" + model_tag + " not found")
sys.exit(e.returncode)
return init_pull(repos_ollama, manifests, accept, registry_head, model_name, model_tag, ramalama_models, symlink_path)

pull_ollama_config_blob(ramalama_store, accept,
registry_head, manifest_data)
for layer in manifest_data["layers"]:
layer_digest = layer["digest"]
if layer["mediaType"] != 'application/vnd.ollama.image.model':
continue

pull_ollama_blob(ramalama_store, layer_digest, accept,
registry_head, ramalama_models, model_name, model_tag, symlink_path)
def run_cli(ramalama_store, model):
symlink_path = pull_cli(ramalama_store, model)
os.execlp("llama-main", "llama-main", "-m",
symlink_path, "--log-disable", "--instruct")


def serve_cli(ramalama_store, model):
symlink_path = pull_cli(ramalama_store, model)
os.execlp("llama-server", "llama-server", "-m", symlink_path)


def usage():
Expand Down Expand Up @@ -183,14 +202,26 @@ def select_container_manager():


def main():
conman = select_container_manager()
ramalama_store = get_ramalama_store()

if conman:
args = sys.argv
args.pop(0)
conman_args = [conman, "run", "--rm", "-it", "--security-opt=label=disable", f"-v{ramalama_store}:/var/lib/ramalama", f"-v{os.path.expanduser('~')}:{os.path.expanduser('~')}", "-v/tmp:/tmp",
f"-v{__file__}:{__file__}", "quay.io/ramalama/ramalama:latest", __file__] + args
os.execvp(conman, conman_args)

if len(sys.argv) < 2:
usage()

ramalama_store = get_ramalama_store()
command = sys.argv[1]
if command == "pull" and len(sys.argv) > 2:
pull_cli(ramalama_store + "/repos/ollama",
ramalama_store + "/models/ollama", sys.argv[2])
pull_cli(ramalama_store, sys.argv[2])
elif command == "run" and len(sys.argv) > 2:
run_cli(ramalama_store, sys.argv[2])
elif command == "serve" and len(sys.argv) > 2:
serve_cli(ramalama_store, sys.argv[2])
else:
usage()

Expand Down

0 comments on commit 87d7f04

Please sign in to comment.