-
-
Notifications
You must be signed in to change notification settings - Fork 14.8k
New issue
Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.
By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.
Already on GitHub? Sign in to your account
nixos/vpp: init module #347797
base: master
Are you sure you want to change the base?
nixos/vpp: init module #347797
Conversation
3cad8ad
to
e0dc519
Compare
8a3d670
to
35dd879
Compare
This pull request has been mentioned on NixOS Discourse. There might be relevant details there: https://discourse.nixos.org/t/prs-ready-for-review/3032/4668 |
35dd879
to
b38f26f
Compare
ef5b42f
to
c93df1d
Compare
c93df1d
to
714f7cf
Compare
9da97c6
to
047ca1c
Compare
047ca1c
to
1f33c2e
Compare
1f33c2e
to
339293e
Compare
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
Some initial food for thought. I'll have to revisit this on my laptop so I can make some further suggestions, there's some stuff I need to take a closer look at.
|
||
# make sure VPP initialized correctly | ||
# the sleep is necessary since startupConfig executes *after* the service starts | ||
router.sleep(2) |
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
This could easily fail on hydra. Is it not enough to wait for the socket above?
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
VPP reads startupConfig
right after actually starting up, the 4 commands should execute near-instantaneously so I don't think it'll be an issue with 2s. It does feel like a bit of a hack, but I can't come up with any better solution.
gid = config.services.vpp.instances.\${name}.group; | ||
}; | ||
''; | ||
example = lib.literalExpression '' |
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
We should try to condense this, too.
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
Removed a bunch of unnecessary options, is this short enough? I'd prefer keeping the comment in there since I think it's pretty useful.
autoSetup = mkOption { | ||
default = false; | ||
example = true; | ||
description = '' | ||
Whether to automatically setup hugepages for use with FD.io's Vector Packet Processor. | ||
|
||
If any programs other than VPP use hugepages or you want to use 1GB hugepages, it's recommended | ||
to keep this `false` and set them up manually using {option}`boot.kernel.sysctl` or {option}`boot.kernelParams`. | ||
''; | ||
}; |
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
For example redis sets this up. Would this work together to make things easy for end users?
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
That I don't know, depends on how exactly VPP and redis use explicit hugepages. The autosetup is only here since VPP requires hugepages to even start up properly, and using it is significantly easier than having to add all the sysctls for a trivial deployment. More complicated setups like having 2 services that use hugepages are out of scope for this option & indicated as such in the description.
339293e
to
3cf1645
Compare
@TheRealGramdalf @SuperSandro2000 Thanks for the reviews! Integrated most of the suggestions, commented on the rest. |
No problem! I still have some thoughts but I'm busy for a while, I'll have to take a look at the end of today or possibly tomorrow. |
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
Mostly some more nitpicks about with
, I think the descriptions are much more concise now. I would be content to leave the descriptions as is for now and see how they look rendered on search/in the manual, making further adjustments if necessary - I'm not sure how or if you could render those locally for testing.
I'm mostly trying to make things as clean as possible, since having readable code makes it much easier to debug and wrap your head around, since most repeated data is redundant - if I have an option with type = types.str
, the types.
doesn't convey any more valuable information. And since it's using inherit
, it's still easy enough to tell where str
came from since it's defined explicitly at the top of the file.
Sorry it took me a while to get to this review, I've been fairly busy recently. Given that, don't feel the need to wait for further review/hold up this PR on my account. |
3cf1645
to
8893101
Compare
1c707ec
to
d505396
Compare
d505396
to
e273f6e
Compare
Description of changes
Module & associated tests for #346281.
Includes an RFC42
settings
option using a custom parser based on znc's and support for multiple instances similar to authelia's module. The test is pretty basic and verifies routing functionality between 2 hosts with VPP acting as the router.Things done
nix.conf
? (See Nix manual)sandbox = relaxed
sandbox = true
nix-shell -p nixpkgs-review --run "nixpkgs-review rev HEAD"
. Note: all changes have to be committed, also see nixpkgs-review usage./result/bin/
)Add a 👍 reaction to pull requests you find important.