Open
Conversation
Create initial package.json for @overleaf/eslint-plugin library to support ESLint plugin development within the Overleaf monorepo workspace structure. This establishes the foundation for custom ESLint rules and configurations that can be shared across services.
Resolve segmentation faults and bus errors during webpack production builds by implementing two key optimizations: 1. Increase Node.js heap size to 12GB (--max-old-space-size=12288) 2. Limit parallel workers in TerserPlugin and CssMinimizerPlugin to 2 Without these changes, webpack's default behavior of spawning workers equal to CPU core count can cause memory exhaustion on high-core-count systems, resulting in build failures with exit codes 135 (bus error) or 139 (segmentation fault). This fix allows successful builds while maintaining reasonable build times.
This file contains hidden or bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Sign up for free
to join this conversation on GitHub.
Already have an account?
Sign in to comment
Add this suggestion to a batch that can be applied as a single commit.This suggestion is invalid because no changes were made to the code.Suggestions cannot be applied while the pull request is closed.Suggestions cannot be applied while viewing a subset of changes.Only one suggestion per line can be applied in a batch.Add this suggestion to a batch that can be applied as a single commit.Applying suggestions on deleted lines is not supported.You must change the existing code in this line in order to create a valid suggestion.Outdated suggestions cannot be applied.This suggestion has been applied or marked resolved.Suggestions cannot be applied from pending reviews.Suggestions cannot be applied on multi-line comments.Suggestions cannot be applied while the pull request is queued to merge.Suggestion cannot be applied right now. Please check back later.
Summary
Resolve segmentation faults and bus errors during webpack production builds by implementing memory optimizations.
Problem
When building the webpack production bundle, developers encounter build failures on high-core-count systems:
npm run webpack:productionRoot Cause: Webpack's TerserPlugin and CssMinimizerPlugin spawn parallel workers equal to CPU core count. On systems with many cores (e.g., 32 cores), this causes memory exhaustion as each worker consumes
significant RAM simultaneously.
Solution
This PR implements two optimizations:
Increase Node.js heap size (
services/web/Dockerfile)--max-old-space-size=12288(12GB heap)Limit parallel workers (
services/web/webpack.config.prod.js)parallel: 2for both TerserPlugin and CssMinimizerPluginTesting
Trade-offs