2024-10-08 17:29:29 +02:00
|
|
|
_: {
|
|
|
|
microvm.autostart = [ "ml01" ];
|
|
|
|
microvm.vms.ml01 = {
|
2024-10-08 17:36:31 +02:00
|
|
|
config =
|
|
|
|
{ config, ... }:
|
|
|
|
{
|
|
|
|
nixpkgs.config.cudaSupport = true;
|
|
|
|
nixpkgs.config.nvidia.acceptLicense = true;
|
|
|
|
# Tesla K80 is not supported by the latest driver.
|
|
|
|
hardware.nvidia.package = config.boot.kernelPackages.nvidia_x11_legacy470;
|
|
|
|
# Don't ask.
|
|
|
|
services.xserver.videoDrivers = [ "nvidia" ];
|
|
|
|
networking.hostName = "ml01";
|
|
|
|
services.ollama = {
|
|
|
|
enable = true;
|
|
|
|
listenAddress = "0.0.0.0:11434";
|
|
|
|
sandbox = true;
|
|
|
|
acceleration = "cuda";
|
|
|
|
};
|
|
|
|
|
|
|
|
microvm = {
|
|
|
|
hypervisor = "cloud-hypervisor";
|
|
|
|
vcpu = 4;
|
|
|
|
mem = 4096;
|
|
|
|
balloonMem = 2048;
|
|
|
|
devices = [
|
|
|
|
# The nVidia Tesla K80
|
|
|
|
{
|
|
|
|
bus = "pci";
|
|
|
|
path = "0000:44:00.0";
|
|
|
|
}
|
|
|
|
{
|
|
|
|
bus = "pci";
|
|
|
|
path = "0000:45:00.0";
|
|
|
|
}
|
|
|
|
];
|
|
|
|
shares = [
|
|
|
|
{
|
|
|
|
source = "/nix/store";
|
|
|
|
mountPoint = "/nix/.ro-store";
|
|
|
|
tag = "ro-store";
|
|
|
|
proto = "virtiofs";
|
|
|
|
}
|
|
|
|
];
|
|
|
|
};
|
2024-10-08 17:29:29 +02:00
|
|
|
};
|
|
|
|
};
|
|
|
|
}
|