-
Notifications
You must be signed in to change notification settings - Fork 22
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
Visual Studio 2022 17.3.5: Docker-Compose needs rebuild to debug new changes #358
Comments
Do you use depends_on declarations for services in your docker-compose.yml or docker-compose.override.yml? We've identified a bug related to how our extension parses the depends_on config that could prevent us from properly registering service projects as build time dependencies. |
Hi @danegsta , thanks for your reply, yes I do use dependencies, here are my docker-compose Files: version: '3.4'
services:
yarp:
image: ${DOCKER_REGISTRY-}yarp
build:
context: .
dockerfile: Yarp/Yarp/Dockerfile
depends_on:
- identityservice.api
- configurationservice.api
- legacyproxyservice.api
yarp-dapr:
image: "daprio/daprd:1.4.2"
depends_on:
- yarp
network_mode: "service:yarp"
configurationservice.api:
image: ${DOCKER_REGISTRY-}configurationserviceapi
build:
context: .
dockerfile: ConfigurationService/ConfigurationService.API/Dockerfile
configurationservice.api-dapr:
image: "daprio/daprd:1.4.2"
depends_on:
- configurationservice.api
- redis
network_mode: "service:configurationservice.api"
identityservice.api:
image: ${DOCKER_REGISTRY-}identityserviceapi
build:
context: .
dockerfile: IdentityService/IdentityService.API/Dockerfile
depends_on:
- configurationservice.api
identityservice.api-dapr:
image: "daprio/daprd:1.4.2"
depends_on:
- identityservice.api
- redis
network_mode: "service:identityservice.api"
legacyproxyservice.api:
image: ${DOCKER_REGISTRY-}legacyproxyserviceapi
build:
context: .
dockerfile: LegacyProxyService/LegacyProxyService.API/Dockerfile
depends_on:
- configurationservice.api
legacyproxyservice.api-dapr:
image: "daprio/daprd:1.4.2"
depends_on:
- legacyproxyservice.api
network_mode: "service:legacyproxyservice.api"
redis:
image: "redis:6.2.6-alpine"
zipkin:
image: openzipkin/zipkin-slim version: '3.4'
services:
yarp:
environment:
- ASPNETCORE_ENVIRONMENT=Development
- ASPNETCORE_URLS=https://+:443;http://+:80
- DAPR_HTTP_PORT=3500
ports:
- "7000:80"
- "7001:443"
- "50001:50001"
volumes:
- ${APPDATA}/Microsoft/UserSecrets:/root/.microsoft/usersecrets:ro
- ${APPDATA}/ASP.NET/Https:/root/.aspnet/https:ro
dns:
- 8.8.8.8
- 127.0.0.11
yarp-dapr:
command: ["./daprd",
"-app-id", "apigateway",
"-app-port", "80",
"-dapr-http-port", "3500",
"-components-path", "/dapr/components",
"-config", "/dapr/dapr-config.yaml",
"-log-level", "info"]
volumes:
- "./dapr-components/docker:/dapr"
identityservice.api:
environment:
- ASPNETCORE_ENVIRONMENT=Development
- ASPNETCORE_URLS=https://+:443;http://+:80
ports:
- "7100:80"
- "7101:443"
- "50002:50001"
volumes:
- ${APPDATA}/Microsoft/UserSecrets:/root/.microsoft/usersecrets:ro
- ${APPDATA}/ASP.NET/Https:/root/.aspnet/https:ro
identityservice.api-dapr:
command: ["./daprd",
"-app-id", "identityservice",
"-app-port", "80",
"-dapr-http-port", "3500",
"-components-path", "/dapr/components",
"-config", "/dapr/dapr-config.yaml",
"-log-level", "info"]
volumes:
- "./dapr-components/docker:/dapr"
configurationservice.api:
environment:
- ASPNETCORE_ENVIRONMENT=Development
- ASPNETCORE_URLS=https://+:443;http://+:80
ports:
- "7200:80"
- "7201:443"
- "50004:50001"
volumes:
- ${APPDATA}/Microsoft/UserSecrets:/root/.microsoft/usersecrets:ro
- ${APPDATA}/ASP.NET/Https:/root/.aspnet/https:ro
configurationservice.api-dapr:
command: ["./daprd",
"-app-id", "configurationservice",
"-app-port", "80",
"-dapr-http-port", "3500",
"-components-path", "/dapr/components",
"-config", "/dapr/dapr-config.yaml",
"-log-level", "info"]
volumes:
- "./dapr-components/docker:/dapr"
legacyproxyservice.api:
environment:
- ASPNETCORE_ENVIRONMENT=Development
- ASPNETCORE_URLS=https://+:443;http://+:80
ports:
- "7300:80"
- "7301:443"
- "50005:50001"
volumes:
- ${APPDATA}/Microsoft/UserSecrets:/root/.microsoft/usersecrets:ro
- ${APPDATA}/ASP.NET/Https:/root/.aspnet/https:ro
legacyproxyservice.api-dapr:
command: ["./daprd",
"-app-id", "legacyproxyservice",
"-app-port", "80",
"-dapr-http-port", "3500",
"-components-path", "/dapr/components",
"-config", "/dapr/dapr-config.yaml",
"-log-level", "debug"]
volumes:
- "./dapr-components/docker:/dapr"
redis:
ports:
- "6379:6379"
zipkin:
ports:
- "9411:9411" Please don't be irritated by some paths / file / project-names, I removed the customer- / product name. |
The issue with depends_on is a bug that is preventing the extension from parsing the short form the the configuration; we've created a fix that will ship with VS 17.4, but you can workaround the issue in the meantime by switching from the short version of the syntax to the long version (see: https://docs.docker.com/compose/compose-file/#depends_on). You would also have to remove the version: '3.4' declaration from the top of your compose yaml files as the long form is only supported in the current compose spec (which no longer uses a version declaration, but is backwards compatible with the earlier 3.x and 2.x specifications). For example,
would become
Making that change for every usage of depends_on should allow the extension to properly track and report the service projects as build dependencies. For the COM error, I'd usually recommend trying to repair your VS install as a first step to see if that fixes the problem; sometimes various component caches get out of sync and a repair can ensure VS is loading all required assemblies at the correct times. |
I've tried to apply your workaround by replacing all of the depends_on statements with the long form, but the problem persists. I still need to manually rebuild to debug / run the newer version of the source after I applied my changes. Is there any other known issue according to project / container mapping? Could my project structure somehow affect this?
Also my VS-Solution is structured like this:
|
@danegsta I also tried this with VS 17.3.0 (Fixed Installer), but the problem also persists. Are there any news on this? If this helps I can offer to debug this together, my Discord-Handle would be Alsc#4353. |
@aschwab would you be able to share your updated docker-compose.yaml and docker-compose.override.yaml files? I can run them through our parser to see if anything else there is causing issues. Which service projects have a ProjectReference to IdentityService.Domain? If you update the service projects, but not not the IdentityService.Domain project, do the changes get picked up during a normal build/F5? |
@danegsta here are my updated Docker-Compose files: services:
yarp:
image: ${DOCKER_REGISTRY-}yarp
build:
context: .
dockerfile: Yarp/Yarp/Dockerfile
depends_on:
identityservice.api:
condition: service_started
configurationservice.api:
condition: service_started
legacyproxyservice.api:
condition: service_started
yarp-dapr:
image: "daprio/daprd:1.4.2"
depends_on:
yarp:
condition: service_started
network_mode: "service:yarp"
configurationservice.api:
image: ${DOCKER_REGISTRY-}configurationserviceapi
build:
context: .
dockerfile: ConfigurationService/ConfigurationService.API/Dockerfile
configurationservice.api-dapr:
image: "daprio/daprd:1.4.2"
depends_on:
configurationservice.api:
condition: service_started
redis:
condition: service_started
network_mode: "service:configurationservice.api"
identityservice.api:
image: ${DOCKER_REGISTRY-}identityserviceapi
build:
context: .
dockerfile: IdentityService/IdentityService.API/Dockerfile
depends_on:
configurationservice.api:
condition: service_started
identityservice.api-dapr:
image: "daprio/daprd:1.4.2"
depends_on:
identityservice.api:
condition: service_started
redis:
condition: service_started
network_mode: "service:identityservice.api"
legacyproxyservice.api:
image: ${DOCKER_REGISTRY-}legacyproxyserviceapi
build:
context: .
dockerfile: LegacyProxyService/LegacyProxyService.API/Dockerfile
depends_on:
configurationservice.api:
condition: service_started
legacyproxyservice.api-dapr:
image: "daprio/daprd:1.4.2"
depends_on:
legacyproxyservice.api:
condition: service_started
network_mode: "service:legacyproxyservice.api"
redis:
image: "redis:6.2.6-alpine"
zipkin:
image: openzipkin/zipkin-slim services:
yarp:
environment:
- ASPNETCORE_ENVIRONMENT=Development
- ASPNETCORE_URLS=https://+:443;http://+:80
- DAPR_HTTP_PORT=3500
ports:
- "7000:80"
- "7001:443"
- "50001:50001"
volumes:
- ${APPDATA}/Microsoft/UserSecrets:/root/.microsoft/usersecrets:ro
- ${APPDATA}/ASP.NET/Https:/root/.aspnet/https:ro
dns:
- 8.8.8.8
- 127.0.0.11
yarp-dapr:
command: ["./daprd",
"-app-id", "apigateway",
"-app-port", "80",
"-dapr-http-port", "3500",
"-components-path", "/dapr/components",
"-config", "/dapr/dapr-config.yaml",
"-log-level", "info"]
volumes:
- "./dapr-components/docker:/dapr"
identityservice.api:
environment:
- ASPNETCORE_ENVIRONMENT=Development
- ASPNETCORE_URLS=https://+:443;http://+:80
ports:
- "7100:80"
- "7101:443"
- "50002:50001"
volumes:
- ${APPDATA}/Microsoft/UserSecrets:/root/.microsoft/usersecrets:ro
- ${APPDATA}/ASP.NET/Https:/root/.aspnet/https:ro
identityservice.api-dapr:
command: ["./daprd",
"-app-id", "identityservice",
"-app-port", "80",
"-dapr-http-port", "3500",
"-components-path", "/dapr/components",
"-config", "/dapr/dapr-config.yaml",
"-log-level", "info"]
volumes:
- "./dapr-components/docker:/dapr"
configurationservice.api:
environment:
- ASPNETCORE_ENVIRONMENT=Development
- ASPNETCORE_URLS=https://+:443;http://+:80
ports:
- "7200:80"
- "7201:443"
- "50004:50001"
volumes:
- ${APPDATA}/Microsoft/UserSecrets:/root/.microsoft/usersecrets:ro
- ${APPDATA}/ASP.NET/Https:/root/.aspnet/https:ro
configurationservice.api-dapr:
command: ["./daprd",
"-app-id", "configurationservice",
"-app-port", "80",
"-dapr-http-port", "3500",
"-components-path", "/dapr/components",
"-config", "/dapr/dapr-config.yaml",
"-log-level", "info"]
volumes:
- "./dapr-components/docker:/dapr"
legacyproxyservice.api:
environment:
- ASPNETCORE_ENVIRONMENT=Development
- ASPNETCORE_URLS=https://+:443;http://+:80
ports:
- "7300:80"
- "7301:443"
- "50005:50001"
volumes:
- ${APPDATA}/Microsoft/UserSecrets:/root/.microsoft/usersecrets:ro
- ${APPDATA}/ASP.NET/Https:/root/.aspnet/https:ro
legacyproxyservice.api-dapr:
command: ["./daprd",
"-app-id", "legacyproxyservice",
"-app-port", "80",
"-dapr-http-port", "3500",
"-components-path", "/dapr/components",
"-config", "/dapr/dapr-config.yaml",
"-log-level", "debug"]
volumes:
- "./dapr-components/docker:/dapr"
redis:
ports:
- "6379:6379"
zipkin:
ports:
- "9411:9411" The depends_on attribute doesn't change a thing, not even removing it. The only Service-Project referencing IdentityService.Domain is IdentityService.API which is also the Name of the Container (Docker-Compose). It does not help changing anything in the IdentityService.API project, it also does not build when changing something in the "main"-project. |
@aschwab 17.4 Preview 3 which contains our fix for the depends_on parsing issue has been released; can you do a quick test with the latest preview build to see if that helps with the issue. In the meantime, I'll continue to do some additional testing on my end to see if there's something else that's been missed. |
@danegsta I've downloaded the newest VS 17.4 Preview 3 and it still does not work Steps to reproduce:
I can't say if this problem is a container tools problem or a visual studio problem. However as I said im happy to show you my solution in Teams / Discord.. whatever. |
@aschwab if you want to shoot me an email at my username at microsoft.com, I can see about scheduling a Teams meeting with you to try and debug the problem. |
Hi |
@itsoli91 are you using depends_on in any of your docker-compose yaml? |
Yes, I use in docker-compose.override.yml |
Have you had a chance to try with VS 2022 17.4 Preview? https://visualstudio.microsoft.com/vs/preview/ |
Not yet, but tomorrow I will try and let you know if it fixes the issue |
Sounds good; hopefully that gets you unblocked, but I'll keep an eye out for an update if that doesn't work for you. |
Hey, I updated to 17.4 and still the problem was there. |
@itsoli91 that should be a decent workaround for the issue as you're effectively manually setting what our dependency checks should automatically be declaring. I believe there's likely an issue related to parsing some non-standard project type within the VS solution that's causing our dependency check to fail and report no dependencies. I haven't managed to find a project type yet that triggers a failure, but I'm continuing to investigate. |
We have the same issue with our current solution, which heavily relies on dapr. I don't know if this is happenstance or not. I will test with preview for 17.4 as well. |
We've identified what should be the root cause for this issue and have a fix in place that will first release in the upcoming 17.5 Preview 2. I'll update this issue once that release is available. |
I have the version 17.6, and still the problem was there. I test to change compilation order but not work for me. |
@esfernandez when you right click on your docker-compose project and view the Build Dependencies > Project Dependencies dialog, does it let you remove the dependencies on service projects or does it give you a warning that a dependency was added by the Project System? |
Still seems to be a problem for me. I am using the long form of depends_on. |
Whenever I change something in my ASP.NET Microservice, I need to rebuild the Project or everything for the changes to be available for debugging on the container, otherwise It will try to debug outdated source which ends up with failing my breakpoints.
This problem occurs since updating to the latest version of Visual Studio / Docker. I'm using VS 2022 17.3.5 with Docker 4.12.0 and Container Tools 1.17.0.
It seems like like the problem is, that my docker-compose.dcproj (and launchSettings.json) does not rebuild my local projects, this could also be because my changes are in a referenced project.
docker-compose.dcproj
launchSettings.json
I expect my visual studio projects (named like the docker-compose containers) to be rebuilt whenever they're out of date. When I rebuild all manually, breakpoints and debugging work like expected. I guess it actually rebuild the whole solution when building manually causing this to work.
The text was updated successfully, but these errors were encountered: