NixOS profiles for servers [maintainer=@numtide]
Go to file
zowoq d725309c96
treewide: update URLs, .github/settings.yml: update team (#284)
* treewide: update URLs

* .github/settings.yml: update team
2023-11-04 10:17:06 +01:00
.github treewide: update URLs, .github/settings.yml: update team (#284) 2023-11-04 10:17:06 +01:00
dev flake.lock: Update 2023-11-02 01:23:43 +00:00
docs treewide: update URLs, .github/settings.yml: update team (#284) 2023-11-04 10:17:06 +01:00
nixos Allow GitHub runner role to be included in nixosModules.default (#279) 2023-11-03 23:03:28 +01:00
.envrc introduce dev flake 2023-04-03 16:10:38 +02:00
.gitignore predictable module locations 2023-02-24 11:47:49 +01:00
.mergify.yml add mergify 2023-07-06 06:51:35 +02:00
bors.toml ci: add aarch64-darwin 2023-06-19 15:41:21 +02:00
default.nix introduce dev flake 2023-04-03 16:10:38 +02:00
flake.lock flake.lock: Update 2023-11-02 00:04:42 +00:00
flake.nix apply deadnix (#224) 2023-08-24 10:31:22 +02:00
LICENSE Create LICENSE 2023-01-16 23:39:46 +01:00
mkdocs.yml treewide: update URLs, .github/settings.yml: update team (#284) 2023-11-04 10:17:06 +01:00
README.md treewide: update URLs, .github/settings.yml: update team (#284) 2023-11-04 10:17:06 +01:00
shell.nix introduce dev flake 2023-04-03 16:10:38 +02:00

SrvOS - NixOS profiles for servers

STATUS: stable

SrvOS is a collection of opinionated and sharable NixOS configurations.

As we learn more about NixOS in various deployments, we end up re-writing the same modules and configs. This is a way for us to speed up and share our setups.

Instead of supporting everything, our goal is to target certain verticals and make the support super smooth there.

Quick Usage

Add srvos to your flake.nix to augment your NixOS configuration. For example to deploy a GitHub Action runner on Hetzner:

{
  description = "My machines flakes";
  inputs = {
    srvos.url = "github:nix-community/srvos";
    # Use the version of nixpkgs that has been tested to work with SrvOS
    # Alternativly we also support the latest nixos release and unstable
    nixpkgs.follows = "srvos/nixpkgs";
  };
  outputs = { self, nixpkgs, srvos }: {
    nixosConfigurations.myHost = nixpkgs.lib.nixosSystem {
      system = "x86_64-linux";
      modules = [
        # This machine is a server
        srvos.nixosModules.server
        # Deployed on the AMD Hetzner hardware
        srvos.nixosModules.hardware-hetzner-amd
        # Configured with extra terminfos
        srvos.nixosModules.mixins-terminfo
        # And designed to run the GitHub Actions runners
        srvos.nixosModules.roles-github-actions-runner
        # Finally add your configuration here
        ./myHost.nix
      ];
    };
  };
}

Documentation

The Documentation website shows more general usage, how to install SrvOS, etc...

To improve the documentation, take a look at the ./docs folder. You can also run nix run .#docs.serve to start a preview server on http://localhost:3000.

Contributing

Contributions are always welcome!

Commercial support

Looking for help or customization?

Get in touch with Numtide to get a quote. We make it easy for companies to work with Open Source projects: https://numtide.com/contact

License

MIT