Compare commits
No commits in common. "373e2dd38646ecad2078bcfe91d71f6702ccc838" and "f5be56222f4f031de14e52853ba9050c404c93f5" have entirely different histories.
373e2dd386
...
f5be56222f
6 changed files with 90 additions and 97 deletions
|
@ -1,3 +1,4 @@
|
|||
{ ... }:
|
||||
{
|
||||
services.immich = {
|
||||
enable = true;
|
||||
|
|
|
@ -24,53 +24,51 @@ in
|
|||
};
|
||||
};
|
||||
|
||||
services = {
|
||||
grafana = {
|
||||
enable = true;
|
||||
settings = {
|
||||
server = {
|
||||
http_port = 2432;
|
||||
root_url = "https://grafana.uku3lig.net";
|
||||
};
|
||||
services.grafana = {
|
||||
enable = true;
|
||||
settings = {
|
||||
server = {
|
||||
http_port = 2432;
|
||||
root_url = "https://grafana.uku3lig.net";
|
||||
};
|
||||
};
|
||||
};
|
||||
|
||||
victoriametrics = {
|
||||
enable = true;
|
||||
listenAddress = "127.0.0.1:9090";
|
||||
retentionPeriod = "5y";
|
||||
};
|
||||
services.victoriametrics = {
|
||||
enable = true;
|
||||
listenAddress = "127.0.0.1:9090";
|
||||
retentionPeriod = "5y";
|
||||
};
|
||||
|
||||
vmagent = {
|
||||
enable = true;
|
||||
prometheusConfig = {
|
||||
global.scrape_interval = "15s";
|
||||
services.vmagent = {
|
||||
enable = true;
|
||||
prometheusConfig = {
|
||||
global.scrape_interval = "15s";
|
||||
|
||||
# node scraping is sent to vm directly via vmauth
|
||||
scrape_configs = [
|
||||
{
|
||||
job_name = "victoriametrics";
|
||||
static_configs = [ { targets = [ "${builtins.toString vmcfg.listenAddress}" ]; } ];
|
||||
}
|
||||
|
||||
{
|
||||
job_name = "api-rs";
|
||||
static_configs = [ { targets = [ "localhost:5001" ]; } ];
|
||||
}
|
||||
];
|
||||
};
|
||||
};
|
||||
|
||||
vmauth = {
|
||||
enable = true;
|
||||
listenAddress = "127.0.0.1:9089";
|
||||
environmentFile = vmauthEnv.path;
|
||||
authConfig.users = [
|
||||
# node scraping is sent to vm directly via vmauth
|
||||
scrape_configs = [
|
||||
{
|
||||
bearer_token = "%{VM_AUTH_TOKEN}";
|
||||
url_prefix = "http://${vmcfg.listenAddress}";
|
||||
job_name = "victoriametrics";
|
||||
static_configs = [ { targets = [ "${builtins.toString vmcfg.listenAddress}" ]; } ];
|
||||
}
|
||||
|
||||
{
|
||||
job_name = "api-rs";
|
||||
static_configs = [ { targets = [ "localhost:5001" ]; } ];
|
||||
}
|
||||
];
|
||||
};
|
||||
};
|
||||
|
||||
services.vmauth = {
|
||||
enable = true;
|
||||
listenAddress = "127.0.0.1:9089";
|
||||
environmentFile = vmauthEnv.path;
|
||||
authConfig.users = [
|
||||
{
|
||||
bearer_token = "%{VM_AUTH_TOKEN}";
|
||||
url_prefix = "http://${vmcfg.listenAddress}";
|
||||
}
|
||||
];
|
||||
};
|
||||
}
|
||||
|
|
|
@ -43,7 +43,7 @@
|
|||
replacements = [
|
||||
{
|
||||
oldDependency = pkgs.ffmpeg-full;
|
||||
newDependency = pkgs.ffmpeg-full.override { withUnfree = true; };
|
||||
newDependency = (pkgs.ffmpeg-full.override { withUnfree = true; });
|
||||
}
|
||||
];
|
||||
};
|
||||
|
|
|
@ -1,17 +1,60 @@
|
|||
{ pkgs, ... }:
|
||||
{
|
||||
imports = [
|
||||
./frp.nix
|
||||
./hetzner.nix
|
||||
];
|
||||
pkgs,
|
||||
config,
|
||||
_utils,
|
||||
...
|
||||
}:
|
||||
let
|
||||
secrets = _utils.setupSharedSecrets config { secrets = [ "frpToken" ]; };
|
||||
in
|
||||
{
|
||||
imports = [ secrets.generate ];
|
||||
|
||||
zramSwap.enable = true;
|
||||
|
||||
environment.systemPackages = with pkgs; [
|
||||
dig
|
||||
traceroute
|
||||
];
|
||||
|
||||
services.openssh = {
|
||||
ports = [ 4269 ];
|
||||
openFirewall = true;
|
||||
services = {
|
||||
openssh.ports = [ 4269 ];
|
||||
|
||||
# Needed by the Hetzner Cloud password reset feature.
|
||||
qemuGuest.enable = true;
|
||||
|
||||
resolved = {
|
||||
dnssec = "allow-downgrade";
|
||||
dnsovertls = "false";
|
||||
};
|
||||
|
||||
frp = {
|
||||
enable = true;
|
||||
role = "server";
|
||||
settings = {
|
||||
bindPort = 7000;
|
||||
auth = {
|
||||
method = "token";
|
||||
token = "{{ .Envs.FRP_TOKEN }}";
|
||||
};
|
||||
};
|
||||
};
|
||||
};
|
||||
|
||||
systemd.services = {
|
||||
frp.serviceConfig.EnvironmentFile = secrets.get "frpToken";
|
||||
|
||||
# https://discourse.nixos.org/t/qemu-guest-agent-on-hetzner-cloud-doesnt-work/8864/2
|
||||
qemu-guest-agent.path = [ pkgs.shadow ];
|
||||
};
|
||||
|
||||
networking.firewall = {
|
||||
allowedTCPPorts = [ 22 ]; # forgejo-ssh
|
||||
allowedTCPPortRanges = [
|
||||
{
|
||||
from = 6000;
|
||||
to = 7000;
|
||||
}
|
||||
];
|
||||
};
|
||||
}
|
||||
|
|
|
@ -1,31 +0,0 @@
|
|||
{ config, _utils, ... }:
|
||||
let
|
||||
secrets = _utils.setupSharedSecrets config { secrets = [ "frpToken" ]; };
|
||||
in
|
||||
{
|
||||
imports = [ secrets.generate ];
|
||||
|
||||
services.frp = {
|
||||
enable = true;
|
||||
role = "server";
|
||||
settings = {
|
||||
bindPort = 7000;
|
||||
auth = {
|
||||
method = "token";
|
||||
token = "{{ .Envs.FRP_TOKEN }}";
|
||||
};
|
||||
};
|
||||
};
|
||||
|
||||
networking.firewall = {
|
||||
allowedTCPPorts = [ 22 ]; # forgejo-ssh
|
||||
allowedTCPPortRanges = [
|
||||
{
|
||||
from = 6000;
|
||||
to = 7000;
|
||||
}
|
||||
];
|
||||
};
|
||||
|
||||
systemd.services.frp.serviceConfig.EnvironmentFile = secrets.get "frpToken";
|
||||
}
|
|
@ -1,18 +0,0 @@
|
|||
{ pkgs, ... }:
|
||||
{
|
||||
services = {
|
||||
# Needed by the Hetzner Cloud password reset feature.
|
||||
qemuGuest.enable = true;
|
||||
|
||||
# Hetzner DNS does not work with DoT
|
||||
resolved = {
|
||||
dnssec = "allow-downgrade";
|
||||
dnsovertls = "false";
|
||||
};
|
||||
};
|
||||
|
||||
# https://discourse.nixos.org/t/qemu-guest-agent-on-hetzner-cloud-doesnt-work/8864/2
|
||||
systemd.services.qemu-guest-agent.path = [ pkgs.shadow ];
|
||||
|
||||
zramSwap.enable = true;
|
||||
}
|
Loading…
Add table
Add a link
Reference in a new issue