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

Adds warnings if automounts seem to be required #2667

Open
wants to merge 9 commits into
base: main
Choose a base branch
from

Conversation

freider
Copy link
Contributor

@freider freider commented Dec 16, 2024

Adds a warning when packages from global scope imports haven't been added to an image using .add_local_python_source.

This will be used in a longer transition period towards deprecation of "auto mounting", getting us to a future with the following standard:

  • Auto-mounting of first-party packages is disabled by default, except for the entrypoint package
  • Entrypoint packages are still auto-mounted by default, and now includes all python files in the package
  • Automounting behavior can be specified on a function and/or app level, not just as a config
  • Auto-mounting can be configured to one of three values: first-party (today's value), entrypoint (new default, similar bot not exactly the same as today's automount=0) and off (not even adding entrypoint file/package)

Old brain storming notes:

There are a few things that need to be fixed for this to work well:

  • Iron out the details of how what kind of "entrypoint" mounting we want in both script and module notation modal run/deploy:
    • ~For example, modal deploy my.pak puts my.pak in sys.modules, and it's not 100% clear if we want it to automatically mount everything in my or just the directory structure + init files required to import my.pak. ~
    • Even something like modal run myscript.py will actually put myscript in sys.modules as a top level package which would get automounted (but currently deduplicated)
    • If you have a package but still use a "script path" within that package as your modal entrypoint, you risk getting two copies of that module: one at the top level /root/script.py and one in your module structure: /root/mypak/script.py and side effects on the module level would be different between the two - potentially causing bugs. These files should preferably be deduplicated in favor of the module variant, but that isn't done today.
    • There is currently a bug with mount deduplication when using relative paths to refer to imports, e.g. modal run ../foo/bar.py
  • Add a way to specify automounting behavior on an @function (or app) level, to let users silence this warning without resorting to global config/env vars
  • Should we allow explicit auto-mount = on values in the future as well, with all the foot guns that entails? (at least during a transition period it could be nice to have that as a fallback for users once we turn on auto-off)

Check these boxes or delete any item (or this section) if not relevant for this PR.

  • Client+Server: this change is compatible with old servers
  • Client forward compatibility: this change ensures client can accept data intended for later versions of itself

Note on protobuf: protobuf message changes in one place may have impact to
multiple entities (client, server, worker, database). See points above.


Changelog

@freider freider marked this pull request as ready for review January 10, 2025 15:48
@freider freider changed the title Draft: Adds warnings if automounts seem to be required Adds warnings if automounts seem to be required Jan 13, 2025
@mwaskom
Copy link
Contributor

mwaskom commented Jan 14, 2025

FWIW I think it's fine to keep "automount" as the terminology. As a standalone verb I think it's a little more clear; "add" could mean so many things.

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

Successfully merging this pull request may close these issues.

2 participants