-
Notifications
You must be signed in to change notification settings - Fork 522
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
Docker .NET Core Attach: Multiple processes were found matching the process name. Attach by process id instead. #2248
Comments
@MarcusOy This one is not deprecated--the |
In VSCode, creating a new launch config within launch.json with the template name Docker: .NET Core Attach (Preview) will create a config listed in the .NET Core section. I believe the quote saying "previous (Preview)" is deprecated is ambiguous, since the documentation doesn't say that the current version of the config available as a launch config template is still labeled as a preview. This let me to believe that the config I had added within my launch.json was the deprecated implementation. I propose this simple change to clear up my original confusion. See comment: microsoft/vscode-docker#2248 (comment)
@MarcusOy It seems like there must be more than one Do you know why there might be multiple |
@bwateratmsft Huh, that's weird. I checked Portainer to see the running processes on my affected containers and there's three total dotnet processes. My setup is currently a few development containers running on watch mode, so maybe that is the cause. Here's an image from Portainer of the processes: The container is spun up from a dev docker image, last Dockerfile statement is:
I am using docker-compose, but I have no additional additional command going to any services containing any of my dotnet core dev images. Would I need to somehow select the container's PID or is having multiple dotnet processes very wrong in either a dev or prod container? I'm still very new to docker, so I am trying to learn the ropes. Edit: Only 2 dotnet processes, the last one is the dotnet-watch process. |
I wouldn't say wrong, just different. I'm not terribly familiar with Given that this is in a dev container it is may be easier to make use of Remote - Containers, by attaching VSCode to the container and then debugging as if it was locally. The debugging in the Docker extension is a bit more like "production" debugging, in that you're debugging an app as it would run in its runtime container image. The line between these scenarios is definitely blurry though. I found another approach that almost worked; the C# extension offers a substitute for |
@bwateratmsft I've been working on other things and I've revisited this issue. I am able to connect to my container using the following config (from OmniSharp's docs):
Now, since this config is beyond the scope of this issue's repo, I'm gonna go ahead and close it. Now, to figure why my symbols aren't loading properly... |
Yeah, that config with |
@bwateratmsft Reopening. I am going to attach a test project for you to try: test.zip Notice two configs in the Obviously, with the Docker config, when run it prompts you to pick a container, then asks to copy over the debugger. Even when taking out references to Meanwhile, the other config gives more control as I can now pick a process on the remote container. I've noticed that you must select the process with the project's full name. For example: Why am I reopening this issue? One of the first results for debugging a dotnet core docker container using VSCode. I think it's crucial for those just starting to use dotnet with docker and VSCode are able to find the solution/configuration they need without spending a huge amount of research just to get a test project to debug. Perhaps advertise the CoreCLR config using |
@MarcusOy Thre is the special way in docker to handle processes; docker container top. It is someway different that ps inside the container. It shows PIDs of the daemon host system PIDs, the Daemon protects Container's processes in isolation purposes and Container init observers them to avoid ghost and zombie host processes. Hopefully, the Process picker takes this mechanism into account correctly Marcus, could you attach the docker container top output at the time when you try to attach to it to the issue?. |
✋ Also having this issue. I started out with the non-compose way of using a sequence of |
There is always the best practice in the docker is to start all processes from the entry script. It is an immediate child of the docker init process and easily observable by the daemon. It ensures that the container will never see underlying host processes -isolation, and the correct lifecycle management - killed container cleans up. I afraid that dotnet watch may create sibling process which is unknown to the init, i.e. to docker daemon. This situatio should never happen. |
Regarding debugging: what is the debuggee,S tandalone DotNet application or Docker container DotNet application? In the 1st case the corresponding VSCode DotNet debugger plugin should be used. In the second case the application container has to be built from Official Microsoft DotNet DotNet Docker containers documentation . In any case DotNet core wired debugger protocol uses TCP ports 4024 and 4025. Debuggee must expose one of these ports. This port will be exposed via bridge network to the cient applications running on the host or network, debugger for example. |
Thank you for your response @PavelSosin-320. Here's my
I would like to just reiterate: I am able to get debugging to work against a remote container running a dotnet project (WITH and WITHOUT
This config will work assuming you have copied the
BTW, I am using With that being said, it doesn't look like I have to change any docker-compose networking settings, the default bridge seems to be doing ok. |
The comprehensive information about debugging and tools libraries can be
found in Debug adapter protocol home page
<https://microsoft.github.io/debug-adapter-protocol/>. This
umbrella cross-platform and cross-company project summarizes all efforts in
the debugging area. If you need to debug applications, please try to find
proven tools and solutions here before attempting to develop your own. I
believe that very few use-cases are missing.
…On Sat, Sep 5, 2020 at 10:47 PM Marcus Orciuch ***@***.***> wrote:
Thank you for your response @PavelSosin-320
<https://github.com/PavelSosin-320>. Here's my docker top output. For
your references, I've run the command twice:
- The first time is with entry point ENTRYPOINT dotnet run
--urls=http://*:5000 in the Dockerfile for test.API
- The second time is with entry point ENTRYPOINT dotnet watch run
--urls=http://*:5000 in the Dockerfile for test.API
[image: Screen Shot 2020-09-05 at 3 29 29 PM]
<https://user-images.githubusercontent.com/16263577/92312202-3872f180-ef84-11ea-80f6-c248f8f50115.png>
I would like to just reiterate: I am able to get debugging to work against
a remote container running a dotnet project (WITH and WITHOUT watch)
using the CoreCLR attach launch.json config. I will paste it below so
that others can retrieve it without hassle:
{
"name": "Test Attach",
"type":"coreclr",
"request":"attach",
"processId": "${command:pickRemoteProcess}",
"pipeTransport": {
"pipeProgram": "docker",
"pipeArgs": [ "exec", "-i", "testapi" ], // Change to container name
"debuggerPath": "/vsdbg/vsdbg",
"pipeCwd": "${workspaceRoot}/test.API/", // Change to project location
"quoteArgs": false
},
"sourceFileMap": {
"/app/test.API": "${workspaceRoot}/test.API", // Change to project location
}
}
This config will work assuming you have copied the vsdbg into your image
using Dockerfile like this:
...
WORKDIR /vsdbg
RUN apt-get update \
&& apt-get install -y --no-install-recommends \
unzip \
&& rm -rf /var/lib/apt/lists/* \
&& curl -sSL https://aka.ms/getvsdbgsh \
| bash /dev/stdin -v latest -l /vsdbg
...
BTW, I am using mcr.microsoft.com/dotnet/core/sdk:3.1.
With that being said, it doesn't look like I have to change any
docker-compose networking settings, the default bridge seems to be doing ok.
—
You are receiving this because you were mentioned.
Reply to this email directly, view it on GitHub
<#2248 (comment)>,
or unsubscribe
<https://github.com/notifications/unsubscribe-auth/AM7YVKBNVQWTEDKGPTITNWLSEKIWPANCNFSM4QIKMPRQ>
.
|
I've wanted for a long time to have a real debugging experience using |
@MarcusOy I spent some time playing with that test project you provided. I made a few small changes in the Dockerfile:
FROM mcr.microsoft.com/dotnet/core/sdk:3.1
WORKDIR /remote_debugger # Changed from /vsdbg
RUN apt-get update \
&& apt-get install -y --no-install-recommends \
unzip \
&& rm -rf /var/lib/apt/lists/* \
&& curl -sSL https://aka.ms/getvsdbgsh \
| bash /dev/stdin -v latest -l /remote_debugger # Changed from /vsdbg
WORKDIR /app
COPY ./test.sln ./
# COPY ./test.API/ ./test.API/
ENV DOTNET_USE_POLLING_FILE_WATCHER 1
ENV DOTNET_CLI_TELEMETRY_OPTOUT 1
WORKDIR /app/test.API
# ENTRYPOINT dotnet watch run --urls=http://*:5000
ENTRYPOINT ["dotnet", "run", "--urls=http://*:5000"] # Changed from line like above
# ---------------------------------------------------------- After launching and resolving the Docker attach configuration, this is what it resolves to: {
"name": "Docker .NET Core Attach (Preview)",
"type": "coreclr",
"request": "attach",
"platform": "netCore",
"sourceFileMap": {
"/app/test/API": "${workspaceRoot}/test.API"
},
"justMyCode": false,
"processName": "dotnet",
"pipeTransport": {
"pipeProgram": "docker",
"pipeArgs": [
"exec",
"-i",
"testapi"
],
"pipeCwd": "${workspaceFolder}",
"debuggerPath": "/remote_debugger/vsdbg",
"quoteArgs": false
}
} The only significant difference between this config and the {
"name": "Docker .NET Core Attach (Preview)",
"type": "docker",
"request": "attach",
"platform": "netCore",
"processName": "test.API",
"sourceFileMap": {
"/app/test/API": "${workspaceRoot}/test.API"
}
}, Ultimately though, what is really needed here is #840. I'll use this issue to track fixing the |
Hi there,
I am trying to use the templated "Docker .NET Core Attach (Preview)" launch config, however, it is not working correctly after pressing run and selecting a running container (for any of my .NET Core projects); it results in the error: "Multiple processes were found matching the process name. Attach by process id instead." The logical next step was to use a process id picker, which resulted in asking me for both a container name and process id but still resulted in an error: "Must specify either processId or processName." I'm not really sure what to do, as I've followed many tutorials to try and get debugging to work on my .NET Core containers but this launch config seemed to be the closest to actually working. Below is the launch config just in case:
I've also heard from the docs that this launch config may be deprecated already, and in that case, what is listed on the docs also doesn't work for me (something about it not finding the listed task on the docs). Many thanks in advance for advice.
Best regards,
Marcus
Version: 1.5.0
OS: ubuntu
OS Release: 20.04 LTS
Product: Visual Studio Code
Product Version: 1.48.1
Language: en
The text was updated successfully, but these errors were encountered: