Skip to content

Commit

Permalink
devhost: Add VM operation mode
Browse files Browse the repository at this point in the history
- Add new image `dev-vm`
- Add new infrastructure mode `dev-vm`
- Add feature switch in devhost role to switch between vms and container (while preserving default)
  • Loading branch information
leona-ya committed Dec 8, 2023
1 parent f8fa627 commit c042ebb
Show file tree
Hide file tree
Showing 10 changed files with 848 additions and 334 deletions.
2 changes: 1 addition & 1 deletion .pre-commit-config-local.yaml
Original file line number Diff line number Diff line change
@@ -1 +1 @@
exclude: "pkgs/fc/sensusyntax/fixtures/(syntaxerror|empty).json|(nixos/infrastructure/container.nix|tests/testlib.nix)"
exclude: "pkgs/fc/sensusyntax/fixtures/(syntaxerror|empty).json|(nixos/infrastructure/container.nix|tests/testlib.nix|nixos/roles/devhost/vm.nix)"
3 changes: 2 additions & 1 deletion nixos/infrastructure/default.nix
Original file line number Diff line number Diff line change
Expand Up @@ -4,6 +4,7 @@

imports = [
./container.nix
./dev-vm.nix
./testing.nix
./flyingcircus-physical.nix
./flyingcircus-virtual.nix
Expand All @@ -12,7 +13,7 @@

options = with lib; {
flyingcircus.infrastructureModule = mkOption {
type = types.enum [ "testing" "flyingcircus" "flyingcircus-physical" "virtualbox" "container" ];
type = types.enum [ "testing" "flyingcircus" "flyingcircus-physical" "virtualbox" "container" "dev-vm" ];
default = "testing";
example = "flyingcircus";
description = "Load config module for specific infrastructure.";
Expand Down
196 changes: 196 additions & 0 deletions nixos/infrastructure/dev-vm.nix
Original file line number Diff line number Diff line change
@@ -0,0 +1,196 @@
{ config, lib, ... }:

let
fclib = config.fclib;

# Only check "visible" roles, skipping roles that are marked as removed by
# `mkRemovedOptionModule` or manually set to `visible = false`.
# The `tryEval` is needed because visiting the role option throws an error if
# the option is declared by `mkRemovedOptionModule`.
visibleFCRoles = (lib.filterAttrs
(n: v: (builtins.tryEval v.enable.visible or true).value)
config.flyingcircus.roles);
in
{
config = lib.mkMerge [
(lib.mkIf (config.flyingcircus.infrastructureModule == "dev-vm") {
boot = {
initrd.kernelModules = [
"virtio_blk"
"virtio_console"
"virtio_net"
"virtio_pci"
"virtio_rng"
"virtio_scsi"
"i6300esb"
];

kernelParams = [
"console=ttyS0"
"nosetmode"
];

loader.grub = {
device = "/dev/disk/device-by-alias/root";
fsIdentifier = "provided";
gfxmodeBios = "text";
};
};

fileSystems."/" = {
device = "/dev/disk/by-label/root";
fsType = "xfs";
};

services.udev.extraRules = ''
# GRUB boot device should be device-by-alias/root
SUBSYSTEM=="block", KERNEL=="vda", SYMLINK+="disk/device-by-alias/root"
# static/bootstrap fallback rules for VMs
SUBSYSTEM=="net", ATTR{address}=="02:02:??:??:??:??", NAME="ethfe"
SUBSYSTEM=="net", ATTR{address}=="02:03:??:??:??:??", NAME="ethsrv"
'';

networking = {
hostName = fclib.mkPlatform config.flyingcircus.enc.name;
useDHCP = true;

firewall.allowedTCPPorts = [ 80 ];
firewall.allowPing = true;
};

flyingcircus.agent.enable = false;
# FIXME: How do we want to handle garbage collection?
# Should probably be aggressive at least against old system generations to not blow up storage
flyingcircus.agent.collect-garbage = lib.mkForce false;

services.timesyncd.servers = [ "pool.ntp.org" ];
services.telegraf.enable = false;

systemd.services."network-addresses-ethsrv" = {
wantedBy = [ "multi-user.target" ];
script = ''
echo "Ready."
'';
serviceConfig = {
Type = "oneshot";
RemainAfterExit = true;
};
};

environment.sessionVariables = { NIX_REMOTE = "daemon"; };

services.mongodb.bind_ip = "[::]";

systemd.services.postgresql.bindsTo = lib.mkForce [ ];
services.postgresql.settings.listen_addresses = lib.mkOverride 20 "0.0.0.0,::";
services.postgresql.settings.fsync = "off";
services.postgresql.settings.full_page_writes = "off";
services.postgresql.settings.synchronous_commit = "off";

flyingcircus.roles.antivirus.listenAddresses = [ "[::]" ];

flyingcircus.roles.coturn.hostName = config.networking.hostName;
flyingcircus.roles.coturn.config.listening-ips = [ "[::]" ];

flyingcircus.roles.memcached.listenAddresses = [ "0.0.0.0" "[::]" ];

flyingcircus.roles.mailserver.smtpBind4 = [ "127.0.0.1" ];
flyingcircus.roles.mailserver.smtpBind6 = [ "::1" ];
flyingcircus.roles.mailserver.explicitSmtpBind = false;

flyingcircus.roles.mysql.listenAddresses = [ "::" ];

flyingcircus.roles.webproxy.listenAddresses = [ "[::]" ];

flyingcircus.services.nginx.defaultListenAddresses = [ "0.0.0.0" "[::]" ];
flyingcircus.services.redis.listenAddresses = [ "[::]" ];
flyingcircus.services.rabbitmq.listenAddress = "::";

services.mysql.settings.mysqld = {
# We don't really care about the data and this speeds up things.
innodb_flush_method = "nosync";

innodb_buffer_pool_size = "200M";
innodb_log_buffer_size = "64M";
innodb_file_per_table = 1;
innodb_read_io_threads = 1;
innodb_write_io_threads = 1;
# Percentage. Probably needs local tuning depending on the workload.
innodb_change_buffer_max_size = 50;
innodb_doublewrite = 1;
innodb_log_file_size = "64M";
innodb_log_files_in_group = 2;
};

services.redis.bind = lib.mkForce "0.0.0.0 ::";

users.users.root.password = "";

time.timeZone = fclib.mkPlatformOverride "Europe/Berlin";

flyingcircus.users.userData = [
{ class = "human";
gid = 100;
home_directory = "/home/developer";
id = 1000;
login_shell = "/bin/bash";
name = "Developer";
# password: vagrant
password = "$5$xS9kX8R5VNC0g$ZS7QkUYTk/61dUyUgq9r0jLAX1NbiScBT5v1PODz4UC";
permissions = { container = [ "admins" "login" "manager" "sudo-srv" ]; };
ssh_pubkey = [
"ssh-ed25519 AAAAC3NzaC1lZDI1NTE5AAAAIGc7V2c2zFPRMl8/gmBv1/MEldEuJau8jHjhx+2qziYs root@ct-dir-dev2"
];
uid = "developer";}
{ class = "service";
gid = 100;
home_directory = "/srv/s-dev";
id = 1001;
login_shell = "/bin/bash";
password = "*";
name = "s-dev";
ssh_pubkey = [] ;
permissions = { container = []; };
uid = "s-dev"; } ];

flyingcircus.users.permissions = [
{ description = "commit to VCS repository";
id = 2029;
name = "code"; }
{ description = "perform interactive or web logins (e.g., ssh, monitoring)";
id = 502;
name = "login"; }
{ description = "access web statistics";
id = 2046;
name = "stats"; }
{ description = "sudo to service user";
id = 2028;
name = "sudo-srv"; }
{ description = "sudo to root";
id = 10;
name = "wheel"; }
{ description = "Manage users of RG";
id = 2272;
name = "manager"; } ];

users.users.developer = {
# Make the human user a service user, too so that we can place stuff in
# /etc/local/nixos for provisioning.
extraGroups = [ "service" "login" ];
};

flyingcircus.passwordlessSudoRules = [
{ # Grant unrestricted access to developer
commands = [ "ALL" ];
users = [ "developer" ];
}
];

system.activationScripts.relaxHomePermissions = lib.stringAfter [ "users" ] ''
mkdir -p /nix/var/nix/profiles/per-user/s-dev
chown s-dev: /nix/var/nix/profiles/per-user/s-dev
'';
}) ];

}
4 changes: 3 additions & 1 deletion nixos/platform/default.nix
Original file line number Diff line number Diff line change
Expand Up @@ -42,7 +42,9 @@ in {
./users.nix
] ++
(additionalModules "/etc/nixos/enc-configs") ++
(additionalModules "/etc/local/nixos");
(additionalModules "/etc/local/nixos") ++
### XXX: Think about the directory name, also imported even when devhost not activated
(additionalModules "/etc/devhost/vm-configs");

options = with lib.types; {

Expand Down
Loading

0 comments on commit c042ebb

Please sign in to comment.