-
Notifications
You must be signed in to change notification settings - Fork 12
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
Make Java dev workflow robust to concurrent target executions #564
Comments
@tinesoft I looked into another plugin for Nx and Spring Boot called @jnxplus/nx-boot-maven. One approach they are taking is to install the Maven of Gradle wrapper in the workspace folder and then have projects use it. This approach has the advantage of avoiding duplicated code, though in some cases the isolation that comes with being able to use different Maven wrapper in different projects may be more beneficial. Is it currently possible to configure @nxrocks/nx-spring-boot to look for the Maven wrapper inside a specified folder instead? |
Running $ yarn nx run-many --target=prepare-java --parallel=1
yarn run v1.22.19
$ /workspaces/challenge-registry/node_modules/.bin/nx run-many --target=prepare-java --parallel=1
✔ nx run challenge-api-gateway:prepare-java (2s)
✔ nx run challenge-auth-service:prepare-java (2s)
✔ nx run challenge-config-service:prepare-java (2s)
✔ nx run challenge-core-service:prepare-java (2s)
✔ nx run challenge-service-registry:prepare-java (2s)
✔ nx run challenge-user-service:prepare-java (3s)
✔ nx run shared-java-challenge-util:prepare-java (2s)
—————————————————————————————————————————————————————————————————————————————————————————————————————————————————————————————————————————————————————————————————————————————————————————————————————————————————————————
> NX Successfully ran target prepare-java for 7 projects (17s)
See Nx Cloud run details at https://nx.app/runs/twmkX9NoxZH
Done in 17.97s. This operation could be faster using Nx cache. How big is the folder that contains the Maven dependencies? $ du -h --max-depth=0 ~/.m2/
411M /home/vscode/.m2/ But it would actually be a bad idea to cache an output folder shared by multiple Nx projects, so let's not do that. |
To answer your question, right now, this is not possible with my plugin, as the wrapper (maven or gradle), comes from what Spring Initializr generates. |
That's good to know. I think that these files should stay. Here are some elements that are on top of my head:
About the wrapper specifically, I'm fine with it being shipped with each project folder. |
This issue has been solved for CI workflow in #503, but developers who run concurrent Java-Maven targets may bump into random errors. A secondary goal is to centralize Maven configuration so that multiple projects can be updated at the same time.
Set of solutions considered:
The text was updated successfully, but these errors were encountered: