-
Notifications
You must be signed in to change notification settings - Fork 574
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
Feature: Re-enable symlinking models downloaded from Hub by default #2548
Comments
Hi @davidbenton, thanks for the kind words! Regarding #2223, this feature has been heavily discussed before been released and I don't think we'll ever change that back. There are mostly 2 types of tools that are using
When we implemented the feature to download to a local directory, we didn't know its usage without symlinks (i.e. explicitly asking not to use symlinks) would be that high. In the end, downloading to a local dir with symlinks was causing all sorts of problems (copies between hard-drives, incompatibilities, etc.) and without symlinks was not using a cache at all. The solution implemented in #2223 tries to circumvent these issues and acknowledge the fact when users want to download weights to a local folder -and explicitly not used the shared cached-, it is their responsibility to optimize the downloads. |
Thanks for the quick response @Wauplin. Yes, you've identified exactly how I ended up here! I have been using both local LLM and diffusion image generation tools this year. I'm an engineer and those communities aren't following best practices (to put it mildly), but this is what happens when new people get excited to use a technology. That's a good thing, and it's going to continue. If HF wants the Hub to be the internet repository of models and datasets, there's a significant internet-scale cost to having a no-cache default when storing models within their project file structure, as most will do naively. In the discussion at #1738, @julien-c seemed to raise this concern. This cost will only increase as these non-HF (i.e., not based on
Users don't want to do this, they're using tools that do it. This week, I'm here because I'm trying to tame the ComfyUI ecosystem, but hundred of other projects will become popular and find their way onto users' computers in the coming years. Third-party software developers aren't aware of the cache (or incentivized to save the bandwidth for HF or end users by using it). This is a systems problem that the Hub is uniquely positioned to solved. That's why the cache was created in the first place, right? I hope you'll give it some more thought. Otherwise, in a few years we'll all have 8 copies of |
As a user, I want to download a multi-GB model one time, at most. :)
We've entered a new era where many casual software projects weigh in at tens or even hundreds of gigabytes. The Hugging Face Hub is the de facto public store for large models. (Congrats and thank you for that! I remember what it was like hunting for models before.) The cache is a huge value-add for projects using the hub, but disabling symlinks circumvents this value for many existing codebases, and the new default means many new projects will naively miss the cache. I personally have unnecessarily downloaded at least 90GB of duplicate model weights on my laptop since this default was changed, by running third-party software that uses the Hub.
I understand the reasoning behind the changes in #2223, and I also think there is an opportunity now to save a massive amount of bandwidth for the millions of users that use the Hub. There isn't currently an easy way to take advantage of the cache when storing the model in multiple places. This is a very common situation when using third-party software that uses transformers or diffusers, and they are creeping into everything.
Can we re-enable symlinks, and make that the default?
The text was updated successfully, but these errors were encountered: