-
Notifications
You must be signed in to change notification settings - Fork 1.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
Implement defaultuserquota/defaultgroupquota #16283
base: master
Are you sure you want to change the base?
Implement defaultuserquota/defaultgroupquota #16283
Conversation
If anyone can point me at some docs on how to correctly incorporate these changes into a FreeBSD source tree, I'll happily work on making this work on that as well. |
@seidelma sorry no one has had a chance to take a look at this yet. I'll try to take a look at it early next week. In the meantime you may want to rebase it on master since there have been some important ZTS fixes that have gone in recently. |
@seidelma would you mind re-basing your commits on top of master? We've had some test suite fixes go in recently that should fix some of the failures on Fedora 39-40. |
b4c6c6e
to
6f20f8c
Compare
Hmm... checkstyle isn't happy with something ABI related. Can you try removing your ABI changes, let checkstyle run in the PR runner, and then download the new ABI files, and then include them in your commits? |
Actually, looks like the newly generated ABI files are here: Would you mind including them in your commits? |
To apply these sames changes to FreeBSD, from reviewing the diff, it looks like all you'll need to do is replicate the changes you made to |
6f20f8c
to
91b5c44
Compare
I've tested the FreeBSD changes against 15-CURRENT (specifically, freebsd/freebsd-src@2b4aa2816). It appears to function with the manual testing I've done, so I'm working on getting the new test cases working with the automated testing framework. |
0426a40
to
8889165
Compare
Would it be useful to implement object quota defaults (userobjquota, groupobjquota and projectobjquota) as well? |
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.
Do we really need another ZAP to store just two quota values? Can't we just store them as a regular dataset properties? Or as alternative, store it in normal quota ZAPs, just with a special key value, since it seems we use string key there for some reason?
While there, wouldn't it be good for completeness to also add default project quotas?
And could you please rebase it to resolve the conflicts.
8889165
to
d62d34c
Compare
Rebased onto master. With respect to ZAP vs a magic key value, I can re-submit with the latter if there's a consensus that's a better practice, and add However, I do note that Solaris ZFS doesn't support |
@seidelma Thanks for rebasing, but now it fails plenty of tests. You'd need to fix them. What's about consensus, I already voiced my concerns and open to hear other opinions. |
This change adds the 'defaultuserquota' and 'defaultgroupquota' properties to ZFS datasets to apply a quota to users and groups that do not have a specific quota assigned. The default quota checking mechanism works alongside the existing 'userquota' and 'groupquota' checks, only taking effect if no quota is assigned for a particular user/group. This means that it's possible to exceed a default quota by quite a lot before the user/groupused property is updated and further writes are denied, which was already the case for user/groupquota. Default quotas are implemented similarly to 'normal' user quotas, but instead of being user properties that are preserved across snapshots, they default back to none. NB: this is different from the observed Solaris behavior, which is to preserve default quotas across snapshot/clone/promote. For instance, Solaris has: # zfs set defaultuserquota=100M tank/fs # zfs snap tank/fs@snap # zfs clone tank/fs@snap tank/fs-clone # zfs get -H defaultuserquota tank/fs-clone tank/fs-clone defaultuserquota 100M - Whereas this commit does: # zfs set defaultuserquota=100M tank/fs # zfs snap tank/fs@snap # zfs clone tank/fs@snap tank/fs-clone # zfs get -H defaultuserquota tank/fs-clone tank/fs-clone defaultuserquota none default It should also be possible to implement a default project quota using an analogous process, if doing so makes sense. Signed-off-by: Todd Seidelmann <[email protected]>
These are based on the existing userquota tests. Note that because the default{user|group}quota behavior differs from Solaris during snapshot/clone/promote, some of the tests fail by design. Signed-off-by: Todd Seidelmann <[email protected]>
Add defaultuserquota and defaultgroupquota dataset properties to the zfsprops.7 manpage. Signed-off-by: Todd Seidelmann <[email protected]>
Signed-off-by: Todd Seidelmann <[email protected]>
Signed-off-by: Todd Seidelmann <[email protected]>
d62d34c
to
0a9157b
Compare
@seidelma In a lack of other opinions, do you plan working on simplifying the patch one of the ways I proposed? We've also received request for such functionality, but would be happy to not duplicate the work. |
Motivation and Context
This change implements default user and group quotas on Linux, an oft-requested feature present in Solaris 11.3.
#5431
Description
This change adds the 'defaultuserquota' and 'defaultgroupquota' properties to ZFS datasets, which apply a quota to users or groups that don't have a specific quota assigned:
It includes tests (some of which fail by design since the behavior is slightly different from Oracle's) and manpage changes.
How Has This Been Tested?
The code changes were tested on Rocky Linux 9 (x86_64 and aarch64) and Ubuntu 24.04 (aarch64) using the zfs-test suite, as well as a comparative behavior analysis between OpenZFS and ZFS on Oracle Solaris 11.4 (x86_64).
In addition, upgrading OpenZFS from 2.1.15 as well as current master/HEAD to my branch was also tested on Rocky 9.
Types of changes
Checklist:
Signed-off-by
.