Ecosyste.ms: Awesome
An open API service indexing awesome lists of open source software.
https://github.com/nlewo/comin
GitOps For NixOS Machines
https://github.com/nlewo/comin
cicd continuous-deployment deployment gitops nix nixos
Last synced: about 20 hours ago
JSON representation
GitOps For NixOS Machines
- Host: GitHub
- URL: https://github.com/nlewo/comin
- Owner: nlewo
- License: mit
- Created: 2022-12-10T09:13:26.000Z (about 2 years ago)
- Default Branch: main
- Last Pushed: 2024-10-18T07:14:47.000Z (3 months ago)
- Last Synced: 2024-10-30T08:17:08.092Z (2 months ago)
- Topics: cicd, continuous-deployment, deployment, gitops, nix, nixos
- Language: Go
- Homepage:
- Size: 362 KB
- Stars: 387
- Watchers: 6
- Forks: 14
- Open Issues: 21
-
Metadata Files:
- Readme: readme.md
- License: LICENSE
Awesome Lists containing this project
- awesome-nix - comin - A deployment tool to continuously pull from Git repositories. (Deployment Tools / Discovery)
- awesome-starred - nlewo/comin - GitOps For NixOS Machines (Go)
- awesome-starred - nlewo/comin - GitOps For NixOS Machines (Go)
README
# comin - GitOps for NixOS Machines
**comin** is a NixOS deployment tool operating in pull mode. Running
on a machine, it periodically polls Git repositories and deploys the
NixOS configuration associated to the machine.## Features
- :snowflake: Git push to deploy NixOS configurations
- :construction: Support testing branches to [try changes](./docs/howtos.md#how-to-test-a-nixos-configuration-change)
- :rocket: Poll [multiple Git remotes](./docs/generated-module-options.md#servicescominremotes) to avoid SPOF
- :postbox: Support [machines migrations](./docs/howtos.md#how-to-migrate-a-configuration-from-a-machine-to-another-one)
- :fast_forward: Fast iterations with [local remotes](./docs/howtos.md#iterate-faster-with-local-repository)
- :satellite: Observable via [Prometheus metrics](./docs/generated-module-options.md#servicescominexporter)
- :pushpin: Create and delete system profiles## Quick start
This is a basic `flake.nix` example:
```nix
{
inputs = {
nixpkgs.url = "github:nixOS/nixpkgs";
comin = {
url = "github:nlewo/comin";
inputs.nixpkgs.follows = "nixpkgs";
};
};
outputs = { self, nixpkgs, comin }: {
nixosConfigurations = {
myMachine = nixpkgs.lib.nixosSystem {
system = "x86_64-linux";
modules = [
comin.nixosModules.comin
({...}: {
services.comin = {
enable = true;
remotes = [{
name = "origin";
url = "https://gitlab.com/your/infra.git";
branches.main.name = "main";
}];
};
})
];
};
};
};
}
```This enables a systemd service, which periodically pulls the `main`
branch of the repository `https://gitlab.com/your/infra.git` and
deploys the NixOS configuration corresponding to the machine hostname
`myMachine`.A new commit in the `main` branch of the repository
`https://gitlab.com/your/infra.git` is then deployed in the next 60
seconds.## Documentation
- [Howtos](./docs/howtos.md)
- [Advanced Configuraion](./docs/advanced-config.md)
- [Authentication](./docs/authentication.md)
- [Comin module options](./docs/generated-module-options.md)
- [Design](./docs/design.md)