-
Notifications
You must be signed in to change notification settings - Fork 535
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
Move /deps/node_modules to /data/olympia/node_modules #22955
Conversation
f8c9504
to
097b07d
Compare
a75e58a
to
bea5c38
Compare
f61d7d8
to
b217496
Compare
8e76203
to
e0a90e7
Compare
…ing make up - Replaced the locale compilation script from a shell script to a Python script (compile_locales.py) for better error handling and parallel processing. - Updated the update_assets target in Makefile-docker to use the new update_assets.py script. - Removed the obsolete compile-mo.sh script. - Introduced sync_host_files.py to streamline dependency updates and asset synchronization.
- Removed obsolete file checks and user validation from Makefile-docker. - Updated Nginx configuration to improve static file handling and added headers for better traceability. - Refactored storage management commands in the Python codebase: - Renamed `clean_storage` to `make_storage` for clarity and added a `clean` parameter. - Updated command implementations to use the new `make_storage` method. - Introduced a new system check for Nginx configurations to ensure proper file accessibility and response validation.
- Updated docker-compose.yml to mount dependencies in /data/olympia/deps for better organization. - Modified Dockerfile to set environment variables for dependency directories and ensure proper ownership. - Adjusted Makefile-docker to remove NODE_MODULES variable and streamline npm commands. - Updated documentation to reflect changes in dependency paths. - Refactored install_deps.py to clean up dependency directories and removed obsolete package.json copying logic. - Updated settings_base.py to reference new dependency paths.
- Updated docker-compose.yml to simplify volume mounts by using the current directory for all services. - Removed HOST_MOUNT and HOST_MOUNT_SOURCE environment variables from settings and entrypoint scripts, streamlining the configuration for local and production environments. - Refactored setup.py to eliminate the get_olympia_mount function, replacing it with a more straightforward approach to determine the Docker target. - Adjusted GitHub Actions workflows to remove references to the obsolete mount input, ensuring cleaner CI/CD processes. - Enhanced test cases to reflect changes in Docker configuration and environment variable handling.
import subprocess | ||
|
||
|
||
def main(): |
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.
FYI @diox we discussed this recently. This logic is how we can ensure that the state of the container and host are synced even with mounts and regardless of mode, because on production images we reinstall deps fresh, build locales and assets essentially reflecting the state of the production image (those exact commands are run in the image build)
Running
|
Can you check the container id and the owner of site-static? Can you try make down and make up together? |
I had an old |
That folder was likely created by docker when creating a volume mount in a previous configuration. It does this even when not binding to the host. I'm not totally sure why. But the file permissions are derived from the container user, which starts as root. That is honestly one of the reasons why we should land this patch. There's so much chaos switching between mounted/non-mounted directories. and if we sometimes add files and then don't mount them... confusing. From now on you can always assume that your host and container files should match and the ownership should always be derived from the host user, which is the container user. @diox any other blockers? |
This reverts commit e73c463.
* Make build-docker locally debuggable * Migrate build scripts to python with single script to orchestrate during make up - Replaced the locale compilation script from a shell script to a Python script (compile_locales.py) for better error handling and parallel processing. - Updated the update_assets target in Makefile-docker to use the new update_assets.py script. - Removed the obsolete compile-mo.sh script. - Introduced sync_host_files.py to streamline dependency updates and asset synchronization. * Better checks that static file routing works as expected - Removed obsolete file checks and user validation from Makefile-docker. - Updated Nginx configuration to improve static file handling and added headers for better traceability. - Refactored storage management commands in the Python codebase: - Renamed `clean_storage` to `make_storage` for clarity and added a `clean` parameter. - Updated command implementations to use the new `make_storage` method. - Introduced a new system check for Nginx configurations to ensure proper file accessibility and response validation. * Migrate dependencies to /data/olympia - Updated docker-compose.yml to mount dependencies in /data/olympia/deps for better organization. - Modified Dockerfile to set environment variables for dependency directories and ensure proper ownership. - Adjusted Makefile-docker to remove NODE_MODULES variable and streamline npm commands. - Updated documentation to reflect changes in dependency paths. - Refactored install_deps.py to clean up dependency directories and removed obsolete package.json copying logic. - Updated settings_base.py to reference new dependency paths. * Remove HOST_MOUNT concept and always mount host files - Updated docker-compose.yml to simplify volume mounts by using the current directory for all services. - Removed HOST_MOUNT and HOST_MOUNT_SOURCE environment variables from settings and entrypoint scripts, streamlining the configuration for local and production environments. - Refactored setup.py to eliminate the get_olympia_mount function, replacing it with a more straightforward approach to determine the Docker target. - Adjusted GitHub Actions workflows to remove references to the obsolete mount input, ensuring cleaner CI/CD processes. - Enhanced test cases to reflect changes in Docker configuration and environment variable handling.
Fixes: mozilla/addons#15066
Description
Enhance the reliability and performance of the make up flow, simplifying development and production environments by making debugging easier.
Simplified Docker Setup:
Removed the OLYMPIA_MOUNT concept, always mounting host files.
Moved Python and npm dependencies into the /data/olympia directory.
New Scripts:
sync-host-files.py: Synchronizes host files with container files before starting containers.
compile_locales.py: Replaces the previous compile-mo.sh.
update_assets.py: Manages asset updates.
Nginx Enhancements:
Added headers to nginx locations to indicate the source of static files.
Initialization Improvements:
Ensured storage directories exist during initialization.
GitHub Actions Modifications:
Modified CI workflows to align with the revised setup.
Updated configuration files to reflect new paths for dependencies and static assets.
Testing:
Updated tests to validate static file routing from nginx to olympia.
Ensured file changes in the container reflect on the host and vice versa.
Cleaned up redundant tests in the check_*.
Documentation:
Updated documentation to describe these changes.
Context
The inspiration for this PR was #22957 which introduces
vite
which in turn has a strong preference thatnode_modules
is in the same directory as the root/data/olympia
. The other changes were the result of finding small bugs or inconsistencies after adding vite support. These changes are pre-requisites for adding vite support and generally improve the local development setup.This PR contains a number of improvements to reliability and performance of our make up flow. Some of these could probably be shipped independently but I'm not sure it is really worth it.
The key change is there is now no concept of mounting or not mounting the host directory, it is always mounted. This simplifies the architecture of our docker compose project A WHOLE DANG LOT, because we don't need to decide whether to mount or not and the developer doesn't need to wonder if host changes are going to propagate to the container or not. Additionally the files you see in your local file system are "literally" the files in the container. This makes debugging a lot easier.
The draw back is when you want to run a "true" production version you need to checkout the right code and clean up your local fs.. this can be done either via a script (out of scope) or manually by checking out the right commit and cleaning your files.
Testing
Running make up should work and you should be able to run the application.
Checklist
#ISSUENUM
at the top of your PR to an existing open issue in the mozilla/addons repository.