Skip to content
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

Support DLLPlugin #4036

Closed
andtii opened this issue Aug 25, 2023 · 27 comments
Closed

Support DLLPlugin #4036

andtii opened this issue Aug 25, 2023 · 27 comments
Assignees
Labels
feat New feature or request

Comments

@andtii
Copy link

andtii commented Aug 25, 2023

What problem does this feature solve?

The thing stopping us from use rspack is that we rely heavily on the dllplugin (https://webpack.js.org/plugins/dll-plugin/). Is it possible to add the support in rspack?

What does the proposed API of configuration look like?

https://webpack.js.org/plugins/dll-plugin/

@andtii andtii added feat New feature or request pending triage The issue/PR is currently untouched. labels Aug 25, 2023
@hardfist
Copy link
Contributor

what's your usage of dllplugin?

@hyf0 hyf0 added awaiting more feedback and removed pending triage The issue/PR is currently untouched. labels Aug 25, 2023
@ScriptedAlchemy
Copy link
Contributor

@andtii you could swap out dll plugin with module federation shared modules. This is at runtime and not as unreliable or prone to central failure as dll and externals. Federation is DLL at runtime, more or less. Same effect.

The reason i mention federation is we will likely pick up support for Module Federation in next Q. Would federation module sharing work?

@andtii
Copy link
Author

andtii commented Aug 31, 2023

@hardfist @ScriptedAlchemy We use the dllplugin and dllreference in our custom build system we have created where we are using manifests to specify which resources should end up in which bundles and then are then using this over multiple projects and have built a custom loader that dynamically loads the manifest and bundles based on the load rules specified in the manifests. To make this work we need to do it on build time so im not sure if module federation helps in this case? We basically have our own module fedaration framwork but use the dllplugin as part of the build step

@ScriptedAlchemy
Copy link
Contributor

Federation was founded on DLL. If you look at classes. We have container pkugin and container reference. You can control the at runtime dependency loading or decisioning. As far as I know it can do anything DLL could, plus more - but it's mansifest are baked into the runtime

@sergei-startsev
Copy link

@ScriptedAlchemy while MF can potentially replace DllPlugin and DllReferencePlugin in some scenarios, its distributed nature is a significant limitation for others.

In our world we use DllPlugin and DllReferencePlugin to implement an effective caching strategy for a large multipage app (>300 pages). We use clustering algorithms to build a tree of bundles chains in which parent bundles share their entries with child bundles, so child bundles don't include modules included in parent packages.

image

Essentially, you need to build a tree of bundles that contain shared modules, where leaves of this tree are "applications". It's possible because child bundles "know" about parent ones at build time. MF was designed to not know anything about manifests of dependent bundles at build time. MF key feature is the main limitation in this scenario.

@andtii
Copy link
Author

andtii commented Sep 14, 2023

Thank you @sergei-startsev this is what we use it for also but you explained it in a better way im not familiar with how MF works

@ScriptedAlchemy
Copy link
Contributor

Gotcha. Thanks for the information.

@andtii
Copy link
Author

andtii commented Oct 12, 2023

@hardfist Do you think this will ever happen or else we ne need to start looking for alternatives because our build times is not funny right now :(

@hardfist
Copy link
Contributor

@hardfist Do you think this will ever happen or else we ne need to start looking for alternatives because our build times is not funny right now :(

sorry we are not gonna support dll plugin in the near future,we will revisit it when we have manpower,it is low priority now,we will implement MF this quarter

@andtii
Copy link
Author

andtii commented Jan 3, 2024

Hey @hardfist new year so maybe this could part of upcoming sprint?

@hardfist
Copy link
Contributor

hardfist commented Jan 3, 2024

Hey @hardfist new year so maybe this could part of upcoming sprint?

FYI we already support MF, and I can fully understand your usage about DLLPlugin, but the team doesn't have extra man power to implement this feature due to the complex of this feature, but we're opening for outside contributions for this feature, we may revisit it when we have extra man power

@ScriptedAlchemy
Copy link
Contributor

ScriptedAlchemy commented Jan 4, 2024

Rspack includes v1.5 update of module federation apis.
DLL and DLLReference are very similar to Container and ContainerReference, just the json versions of them, but its still externals.

IF caching is the main concern here, due to federation historically being nondeterministic about "what" it picks from "where" - we have introduced a runtime api which does provide a resolveShare hook, which would let you control where "react" is got from each time.
In this case, you could create a vendor remote of sorts, and all applications will resolve any shared module requests first to the "vendor" container before looking elsewhere for a module.

Might not serve your need, but within the context of wanting predictable cacheable resource loading... you can achieve same via federation.
you could also set shared modules to import:false in MFP config, this would mean those bundles will no include any fallback and be totally dependent on someone else vending it its dependency. Giving you the single point of failure approach that DLL plugin did, which was make eveything externals and dont tree shake those exports out of someone else.

For example, in next.js i use this runtime plugin api to make share always resolve to the host for react or next.js deps.

    resolveShare(args) {
      if (
        args.pkgName !== 'react' &&
        args.pkgName !== 'react-dom' &&
        !args.pkgName.startsWith('next/')
      ) {
        return args;
      }
      const { shareScopeMap, scope, pkgName, version, GlobalFederation } = args;

      const host = GlobalFederation['__INSTANCES__'][0];
      if (!host) {
        return args;
      }
      args.resolver = function () {
       //could also be return window.vendorBundle.options.shared[pkgName]
        shareScopeMap[scope][pkgName][version] = host.options.shared[pkgName]; // replace local share scope manually with desired module
        return shareScopeMap[scope][pkgName][version];
      };
      return args;
    },
    ```

@ScriptedAlchemy
Copy link
Contributor

this would be the same as DLL, if you served the assets together (vendor remote + the bundle), you can control the module routing and force everyone to explicitly load from vendorRemote, thus you can cache it knowing everyone will always prefer it if it exists, but federation could let you provide fallback in event of missing DLL bundle.

const vendorRemote = GlobalFederation.INSTANCES.find((container)=>container.name === 'vendorBundle')

I think thats the closest youll get without someone copying over similar implementation of container and container reference to DLL and DLLReference. Or porting the JS plugin to rust in a PR

Copy link

stale bot commented Apr 22, 2024

This issue has been automatically marked as stale because it has not had recent activity. If this issue is still affecting you, please leave any comment (for example, "bump"). We are sorry that we haven't been able to prioritize it yet. If you have any new additional information, please include it with your comment!

@stale stale bot added the stale label Apr 22, 2024
@andtii
Copy link
Author

andtii commented Apr 22, 2024

@hardfist Any updates? Could this be implemented soon?

@andtii
Copy link
Author

andtii commented Apr 22, 2024

@sergei-startsev Did you find any other solution?

@sergei-startsev
Copy link

@andtii I don't see any other real options for our scenarios other than DLLPlugin & DLLReferencePlugin support.

If Rspack considers compatibility with existing webpack plugins as a competitive advantage, I believe that support of core webpack plugins is crucial. If I have to reinvent my ecosystem from scratch, I don't see why Rspack is better than other options available today.

@stale stale bot removed the stale label Apr 22, 2024
@zackarychapple
Copy link
Contributor

Nuding this one as well, its part of a project migration.

Copy link

stale bot commented Jun 28, 2024

This issue has been automatically marked as stale because it has not had recent activity. If this issue is still affecting you, please leave any comment (for example, "bump"). We are sorry that we haven't been able to prioritize it yet. If you have any new additional information, please include it with your comment!

@stale stale bot added the stale label Jun 28, 2024
@hardfist
Copy link
Contributor

bump

@stale stale bot removed the stale label Jun 30, 2024
@andtii
Copy link
Author

andtii commented Jul 2, 2024

@hardfist I read somewhere that it could be possible to run plugins using the js version of webpack plugins but it will be slower does this mean we can still move to rspack?

@ScriptedAlchemy
Copy link
Contributor

After I finish http import APIs I'll take a look at this plugin and see how hard it would be to port into rust.

Copy link

stale bot commented Aug 31, 2024

This issue has been automatically marked as stale because it has not had recent activity. If this issue is still affecting you, please leave any comment (for example, "bump"). We are sorry that we haven't been able to prioritize it yet. If you have any new additional information, please include it with your comment!

@stale stale bot added the stale label Aug 31, 2024
@hardfist
Copy link
Contributor

hardfist commented Sep 1, 2024

bump

@andtii
Copy link
Author

andtii commented Oct 22, 2024

@ScriptedAlchemy Did you have time to do some investigation?

@GiveMe-A-Name
Copy link
Member

@ScriptedAlchemy Did you have time to do some investigation?

I working on investigation, I will start develop directly or write RFC firstly watch the situation in this week.

@GiveMe-A-Name
Copy link
Member

Implement by #8296

Sign up for free to join this conversation on GitHub. Already have an account? Sign in to comment
Labels
feat New feature or request
Projects
None yet
Development

No branches or pull requests

9 participants