disko | 357 Members | |
| disko - declarative disk partitioning - https://github.com/nix-community/disko | 89 Servers |
| Sender | Message | Time |
|---|---|---|
| 10 Feb 2025 | ||
| Does anyone have an explanation on how the disk type and dependencies get tracked? Similar to how for mdadm and mdraid, mdraid runs before mdadm as that is a prereq. I am trying to do something similar but running into issues | 13:31:25 | |
| there is deviceDependencies in _meta which gets exported and toposorted later | 13:36:10 | |
| or later in that case when it's used | 13:36:26 | |
| Hmm, I think I'm using that correctly. I am noticing one type's create method isn't executing at all. I added some debug statements to the shell script, and that's where I noticed my issue. Not at my computer atm, but I can send the example in a few | 13:54:18 | |
| https://github.com/ProjectInitiative/disko/blob/feat/bcachefs-as-member/lib/types/bcachefs_member.nix#L57 | 14:33:37 | |
| 11 Feb 2025 | ||
| Are there any good examples of how to use the topsorted function? Doing some digging in nix repl for the mdadm example, I see this behavior:
Seems a bit odd only one element is in the list. And I wonder if this is why my new types are not getting ordered properly, because they follow the same structure as mdadm/mdraid. | 14:16:26 | |
| * Are there any good examples of how to use the topsorted function? Doing some digging in nix repl for the mdadm example, I see this behavior:
Seems a bit odd only one element is in the list. And I wonder if this is why my new types are not getting ordered properly, because they follow the same structure as mdadm/mdraid. | 14:16:59 | |
| * Are there any good examples of how to use the topsorted function? Doing some digging in nix repl for the mdadm example, I see this behavior:
Seems a bit odd only one element is in the list. And I wonder if this is why my new types are not getting ordered properly, because they follow the same structure as mdadm/mdraid. | 14:17:08 | |
| * Are there any good examples of how to use the sortDevicesByDependencies function? Doing some digging in nix repl for the mdadm example, I see this behavior:
Seems a bit odd only one element is in the list. And I wonder if this is why my new types are not getting ordered properly, because they follow the same structure as mdadm/mdraid. | 14:18:06 | |
| it should just be the attribute you depend on, so in this case disko.devices.mdadm.raid1 depends on disko.devices.disk."/dev/my-disk" | 14:19:49 | |
| and the toposort then sorts the snippet for disk."/dev/my-disk" before the snipper for mdadm.raid1 | 14:21:03 | |
| but if your raid depends on multiple disks, there should be multiple disks in there | 14:23:18 | |
| looking at example/mdadm.nix, two disks are defined with mdadm and then mdraid as the content, shouldn't both be included? I guess ultimately I am trying to figure out why my types that are modeled after the zfs and mdadm patterns are not respecting the same order when they get combined in the final _create. i.e. the mdraid equivalent bcachefs_member type (for members of the pool) needs to come first, yet it gets put after the bachefs type I made. Both types are nearly identical in structure | 14:23:25 | |
| I will note I also tried with the zfs-with-vdevs example adding it to the test machine config, and it also only has one disk listed under dependencies despite having several listed in the example file under zroot | 14:24:54 | |
| hmm, maybe there is indeed a bug | 14:25:56 | |
| which didn't get triggered yet, but I thought the complex example would take care of that | 14:26:17 | |
| reproduction steps:
| 14:27:29 | |
| * reproduction steps:
| 14:27:59 | |
| I will try to add that to my thaigersprint todo list tomorrow :D | 14:28:16 | |
| Obligatory: I wish nix had better testing/debugging tools, this is taking way longer to nail down my overall issue haha... | 14:30:10 | |
In reply to @lassulus:lassul.usYou want issues for your sprint? Haha | 20:09:11 | |
| 12 Feb 2025 | ||
| You have more? :D | 01:38:19 | |
In reply to @lassulus:lassul.usI looked up that thaigersprint was, that seems unique. Talk about a cool experience | 03:48:41 | |
| * I looked up what thaigersprint was, that seems unique. Talk about a cool experience | 03:48:49 | |
| ok, deepMergeMap actually doesn't merge lists, since recursiveUpdate doesn't take care of that | 05:31:21 | |
| projectinitiative: https://github.com/nix-community/disko/pull/963 | 10:21:50 | |
| looks like this fixed the deviceDendencies list not showing up! I now just have to figure out why my type ordering is not working correctly. | 14:49:36 | |
| If you have a PR with the current state I could take a look tomorrowish | 15:17:11 | |
| Thanks for the comments on the binfmt PR. I'm still working on it | 17:27:57 | |
| Current state of my attempt: https://github.com/nix-community/disko/pull/961 | 18:42:48 | |