Skip to content
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

[Bug]: HttpRequestException during PostgreSqlContainer.StartAsync() #13

Open
maartenjorens opened this issue Mar 17, 2025 · 16 comments
Open
Labels
bug Something isn't working help wanted Extra attention is needed

Comments

@maartenjorens
Copy link

maartenjorens commented Mar 17, 2025

Testcontainers version

4.3.0

Using the latest Testcontainers version?

Yes

Host OS

Windows

Host arch

x64

.NET version

8.0.405

Docker version

Client:
 Version:           27.5.1-rd
 API version:       1.45 (downgraded from 1.47)
 Go version:        go1.22.11
 Git commit:        0c97515
 Built:             Thu Jan 23 18:14:31 2025
 OS/Arch:           windows/amd64
 Context:           default

Server:
 Engine:
  Version:          26.1.5
  API version:      1.45 (minimum version 1.24)
  Go version:       go1.22.5
  Git commit:       411e817ddf710ff8e08fa193da80cb78af708191
  Built:            Fri Jul 26 17:51:06 2024
  OS/Arch:          linux/amd64
  Experimental:     false
 containerd:
  Version:          v1.7.17
  GitCommit:        3a4de459a68952ffb703bbe7f2290861a75b6b67
 runc:
  Version:          1.1.14
  GitCommit:        2c9f5602f0ba3d9da1c2596322dfc4e156844890
 docker-init:
  Version:          0.19.0
  GitCommit:

Docker info

Client:
 Version:    27.5.1-rd
 Context:    default
 Debug Mode: false
 Plugins:
  buildx: Docker Buildx (Docker Inc.)
    Version:  v0.20.1
    Path:     C:\Program Files\Rancher Desktop\resources\resources\win32\docker-cli-plugins\docker-buildx.exe
  compose: Docker Compose (Docker Inc.)
    Version:  v2.33.0
    Path:     C:\Program Files\Rancher Desktop\resources\resources\win32\docker-cli-plugins\docker-compose.exe
WARNING: Plugin "C:\\Users\\X\\.docker\\cli-plugins\\docker-ai.exe" is not valid: failed to fetch metadata: fork/exec C:\Users\X\.docker\cli-plugins\docker-ai.exe: The system cannot find the path specified.
WARNING: Plugin "C:\\Users\\X\\.docker\\cli-plugins\\docker-debug.exe" is not valid: failed to fetch metadata: fork/exec C:\Users\X\.docker\cli-plugins\docker-debug.exe: The system cannot find the path specified.
WARNING: Plugin "C:\\Users\\X\\.docker\\cli-plugins\\docker-desktop.exe" is not valid: failed to fetch metadata: fork/exec C:\Users\X\.docker\cli-plugins\docker-desktop.exe: The system cannot find the path specified.
WARNING: Plugin "C:\\Users\\X\\.docker\\cli-plugins\\docker-dev.exe" is not valid: failed to fetch metadata: fork/exec C:\Users\X\.docker\cli-plugins\docker-dev.exe: The system cannot find the path specified.
WARNING: Plugin "C:\\Users\\X\\.docker\\cli-plugins\\docker-extension.exe" is not valid: failed to fetch metadata: fork/exec C:\Users\X\.docker\cli-plugins\docker-extension.exe: The system cannot find the path specified.
WARNING: Plugin "C:\\Users\\X\\.docker\\cli-plugins\\docker-feedback.exe" is not valid: failed to fetch metadata: fork/exec C:\Users\X\.docker\cli-plugins\docker-feedback.exe: The system cannot find the path specified.
WARNING: Plugin "C:\\Users\\X\\.docker\\cli-plugins\\docker-init.exe" is not valid: failed to fetch metadata: fork/exec C:\Users\X\.docker\cli-plugins\docker-init.exe: The system cannot find the path specified.
WARNING: Plugin "C:\\Users\\X\\.docker\\cli-plugins\\docker-sbom.exe" is not valid: failed to fetch metadata: fork/exec C:\Users\X\.docker\cli-plugins\docker-sbom.exe: The system cannot find the path specified.
WARNING: Plugin "C:\\Users\\X\\.docker\\cli-plugins\\docker-scout.exe" is not valid: failed to fetch metadata: fork/exec C:\Users\X\.docker\cli-plugins\docker-scout.exe: The system cannot find the path specified.

Server:
 Containers: 28
  Running: 12
  Paused: 0
  Stopped: 16
 Images: 14
 Server Version: 26.1.5
 Storage Driver: overlay2
  Backing Filesystem: extfs
  Supports d_type: true
  Using metacopy: false
  Native Overlay Diff: true
  userxattr: false
 Logging Driver: json-file
 Cgroup Driver: cgroupfs
 Cgroup Version: 1
 Plugins:
  Volume: local
  Network: bridge host ipvlan macvlan null overlay
  Log: awslogs fluentd gcplogs gelf journald json-file local splunk syslog
 Swarm: inactive
 Runtimes: io.containerd.runc.v2 runc
 Default Runtime: runc
 Init Binary: docker-init
 containerd version: 3a4de459a68952ffb703bbe7f2290861a75b6b67
 runc version: 2c9f5602f0ba3d9da1c2596322dfc4e156844890
 init version:
 Security Options:
  seccomp
   Profile: builtin
 Kernel Version: 5.15.167.4-microsoft-standard-WSL2
 Operating System: Rancher Desktop WSL Distribution
 OSType: linux
 Architecture: x86_64
 CPUs: 8
 Total Memory: 15.49GiB
 Name: PRD-RBTX-APP01
 ID: 547b3339-78c0-4d77-b7b8-91d317604ed5
 Docker Root Dir: /var/lib/docker
 Debug Mode: false
 Experimental: false
 Insecure Registries:
  127.0.0.0/8
 Live Restore Enabled: false

WARNING: No blkio throttle.read_bps_device support
WARNING: No blkio throttle.write_bps_device support
WARNING: No blkio throttle.read_iops_device support
WARNING: No blkio throttle.write_iops_device support

What happened?

Executing Testcontainers.PostgreSql: PostgreSqlContainer.StartAsync sometimes fails. This results in a flaky test startup.
We're using Rancher Desktop v 1.18.2 with moby.
Following code is executed during our NUnit OneTimeSetup:

private class DockerHelper
{
      private readonly PostgreSqlContainer _sqlContainer = new PostgreSqlBuilder()
          .WithAutoRemove(true)
          .Build();

      public async Task Start() 
      {
          await _sqlContainer.StartAsync();
      }
}

It's always the same exception: HttpRequestException from ContainerOperations.InspectContainerAsync.

Producing one of the following HttpRequestException
Exception 1 during TestcontainersClient.StartAsync

OneTimeSetUp: System.Net.Http.HttpRequestException : Error while copying content to a stream.
----> System.IO.IOException : Invalid chunk header: Source":"/var/lib/docker/volumes/c96b7eb7687483b283a5d59cd4905cfea059b77fab71121c5e37c0afb0303e4b/_data","Destination":"/var/lib/postgresql/data","Driver":"local","Mode":"","RW":true,"Propagation":""}],"Config":{"Hostname":"b93702419de0","Domainname":"","User":"","AttachStdin":false,"AttachStdout":false,"AttachStderr":false,"ExposedPorts":{"5432/tcp":{}},"Tty":false,"OpenStdin":false,"StdinOnce":false,"Env":["POSTGRES_PASSWORD=postgres","POSTGRES_USER=postgres","POSTGRES_DB=postgres","PATH=/usr/local/sbin:/usr/local/bin:/usr/sbin:/usr/bin:/sbin:/bin:/usr/lib/postgresql/15/bin","GOSU_VERSION=1.16","LANG=en_US.utf8","PG_MAJOR=15","PG_VERSION=15.1-1.pgdg110+1","PGDATA=/var/lib/postgresql/data"],"Cmd":["-c","fsync=off","-c","full_page_writes=off","-c","synchronous_commit=off"],"Image":"postgres:15.1","Volumes":{"/var/lib/postgresql/data":{}},"WorkingDir":"","Entrypoint":["docker-entrypoint.sh"],"OnBuild":null,"Labels":{"org.testcontainers":"true","org.testcontainers.lang":"dotnet","org.testcontainers.resource-reaper-session":"40531ddd-6f4f-4a34-9413-1b8c9cde31e7","org.testcontainers.session-id":"40531ddd-6f4f-4a34-9413-1b8c9cde31e7","org.testcontainers.version":"4.3.0+b53e4f24afc2310b9695a77aa04d07719d964cf1"},"StopSignal":"SIGINT"},"NetworkSettings":{"Bridge":"","SandboxID":"","SandboxKey":"","Ports":{},"HairpinMode":false,"LinkLocalIPv6Address":"","LinkLocalIPv6PrefixLen":0,"SecondaryIPAddresses":null,"SecondaryIPv6Addresses":null,"EndpointID":"","Gateway":"","GlobalIPv6Address":"","GlobalIPv6PrefixLen":0,"IPAddress":"","IPPrefixLen":0,"IPv6Gateway":"","MacAddress":"","Networks":{"bridge":{"IPAMConfig":null,"Links":null,"Aliases":null,"MacAddress":"","NetworkID":"","EndpointID":"","Gateway":"","IPAddress":"","IPPrefixLen":0,"IPv6Gateway":"","GlobalIPv6Address":"","GlobalIPv6PrefixLen":0,"DriverOpts":null,"DNSNames":null}}}}

With Stacktrace:

at System.Net.Http.HttpContent.LoadIntoBufferAsyncCore(Task serializeToStreamTask, MemoryStream tempBuffer)
at System.Net.Http.HttpClient.<SendAsync>g__Core|83_0(HttpRequestMessage request, HttpCompletionOption completionOption, CancellationTokenSource cts, Boolean disposeCts, CancellationTokenSource pendingRequestsCts, CancellationToken originalCancellationToken)
[at Docker.DotNet.DockerClient.PrivateMakeRequestAsync(TimeSpan timeout, HttpCompletionOption completionOption, HttpMethod method, String path, IQueryString queryString, IDictionary`2 headers, IRequestContent data, CancellationToken cancellationToken) in /_/src/Docker.DotNet/DockerClient.cs:line 423](https://dev.azure.com/stow-robotics/stow%20RnD/_git/f046e4b0-956d-416e-b792-836a341d62dd?path=%2F_%2Fsrc%2FDocker.DotNet%2FDockerClient.cs&version=GBdevelopment&_a=contents&line=423&lineEnd=424&lineStartColumn=1&lineEndColumn=1&lineStyle=plain)
[at Docker.DotNet.DockerClient.MakeRequestAsync[T](IEnumerable`1 errorHandlers, HttpMethod method, String path, IQueryString queryString, IRequestContent body, IDictionary`2 headers, TimeSpan timeout, CancellationToken token) in /_/src/Docker.DotNet/DockerClient.cs:line 254](https://dev.azure.com/stow-robotics/stow%20RnD/_git/f046e4b0-956d-416e-b792-836a341d62dd?path=%2F_%2Fsrc%2FDocker.DotNet%2FDockerClient.cs&version=GBdevelopment&_a=contents&line=254&lineEnd=255&lineStartColumn=1&lineEndColumn=1&lineStyle=plain)
[at Docker.DotNet.ContainerOperations.InspectContainerAsync(String id, CancellationToken cancellationToken) in /_/src/Docker.DotNet/Endpoints/ContainerOperations.cs:line 74](https://dev.azure.com/stow-robotics/stow%20RnD/_git/f046e4b0-956d-416e-b792-836a341d62dd?path=%2F_%2Fsrc%2FDocker.DotNet%2FEndpoints%2FContainerOperations.cs&version=GBdevelopment&_a=contents&line=74&lineEnd=75&lineStartColumn=1&lineEndColumn=1&lineStyle=plain)
[at DotNet.Testcontainers.Clients.DockerContainerOperations.ByIdAsync(String id, CancellationToken ct) in /_/src/Testcontainers/Clients/DockerContainerOperations.cs:line 36](https://dev.azure.com/stow-robotics/stow%20RnD/_git/f046e4b0-956d-416e-b792-836a341d62dd?path=%2F_%2Fsrc%2FTestcontainers%2FClients%2FDockerContainerOperations.cs&version=GBdevelopment&_a=contents&line=36&lineEnd=37&lineStartColumn=1&lineEndColumn=1&lineStyle=plain)
[at DotNet.Testcontainers.Clients.DockerContainerOperations.ExistsWithIdAsync(String id, CancellationToken ct) in /_/src/Testcontainers/Clients/DockerContainerOperations.cs:line 44](https://dev.azure.com/stow-robotics/stow%20RnD/_git/f046e4b0-956d-416e-b792-836a341d62dd?path=%2F_%2Fsrc%2FTestcontainers%2FClients%2FDockerContainerOperations.cs&version=GBdevelopment&_a=contents&line=44&lineEnd=45&lineStartColumn=1&lineEndColumn=1&lineStyle=plain)
[at DotNet.Testcontainers.Clients.TestcontainersClient.StartAsync(String id, CancellationToken ct) in /_/src/Testcontainers/Clients/TestcontainersClient.cs:line 126](https://dev.azure.com/stow-robotics/stow%20RnD/_git/f046e4b0-956d-416e-b792-836a341d62dd?path=%2F_%2Fsrc%2FTestcontainers%2FClients%2FTestcontainersClient.cs&version=GBdevelopment&_a=contents&line=126&lineEnd=127&lineStartColumn=1&lineEndColumn=1&lineStyle=plain)
[at DotNet.Testcontainers.Containers.DockerContainer.UnsafeStartAsync(CancellationToken ct) in /_/src/Testcontainers/Containers/DockerContainer.cs:line 505](https://dev.azure.com/stow-robotics/stow%20RnD/_git/f046e4b0-956d-416e-b792-836a341d62dd?path=%2F_%2Fsrc%2FTestcontainers%2FContainers%2FDockerContainer.cs&version=GBdevelopment&_a=contents&line=505&lineEnd=506&lineStartColumn=1&lineEndColumn=1&lineStyle=plain)
[at DotNet.Testcontainers.Containers.DockerContainer.StartAsync(CancellationToken ct) in /_/src/Testcontainers/Containers/DockerContainer.cs:line 301](https://dev.azure.com/stow-robotics/stow%20RnD/_git/f046e4b0-956d-416e-b792-836a341d62dd?path=%2F_%2Fsrc%2FTestcontainers%2FContainers%2FDockerContainer.cs&version=GBdevelopment&_a=contents&line=301&lineEnd=302&lineStartColumn=1&lineEndColumn=1&lineStyle=plain)

OR
Exception 2 during DockerContainer.CheckReadinessAsync

**OneTimeSetUp: System.Net.Http.HttpRequestException : Error while copying content to a stream.
----> System.IO.IOException : Invalid chunk header: a315d823287007f78af86d/diff","MergedDir":"/var/lib/docker/overlay2/3a126b57c8d95566277e9429174935acd2f16f09c4ac208567442bdf2e699330/merged","UpperDir":"/var/lib/docker/overlay2/3a126b57c8d95566277e9429174935acd2f16f09c4ac208567442bdf2e699330/diff","WorkDir":"/var/lib/docker/overlay2/3a126b57c8d95566277e9429174935acd2f16f09c4ac208567442bdf2e699330/work"},"Name":"overlay2"},"Mounts":[{"Type":"volume","Name":"45205d5b9ff18362cf79c94844c9297fcfb0d9010803a4f19f7f0cdae89735c0","Source":"/var/lib/docker/volumes/45205d5b9ff18362cf79c94844c9297fcfb0d9010803a4f19f7f0cdae89735c0/_data","Destination":"/var/lib/postgresql/data","Driver":"local","Mode":"","RW":true,"Propagation":""}],"Config":{"Hostname":"cbf9c2d41ff9","Domainname":"","User":"","AttachStdin":false,"AttachStdout":false,"AttachStderr":false,"ExposedPorts":{"5432/tcp":{}},"Tty":false,"OpenStdin":false,"StdinOnce":false,"Env":["POSTGRES_PASSWORD=postgres","POSTGRES_USER=postgres","POSTGRES_DB=postgres","PATH=/usr/local/sbin:/usr/local/bin:/usr/sbin:/usr/bin:/sbin:/bin:/usr/lib/postgresql/15/bin","GOSU_VERSION=1.16","LANG=en_US.utf8","PG_MAJOR=15","PG_VERSION=15.1-1.pgdg110+1","PGDATA=/var/lib/postgresql/data"],"Cmd":["-c","fsync=off","-c","full_page_writes=off","-c","synchronous_commit=off"],"Image":"postgres:15.1","Volumes":{"/var/lib/postgresql/data":{}},"WorkingDir":"","Entrypoint":["docker-entrypoint.sh"],"OnBuild":null,"Labels":{"org.testcontainers":"true","org.testcontainers.lang":"dotnet","org.testcontainers.resource-reaper-session":"70df180f-f424-4749-9f99-4b7ffd3e0cef","org.testcontainers.session-id":"70df180f-f424-4749-9f99-4b7ffd3e0cef","org.testcontainers.version":"4.3.0+b53e4f24afc2310b9695a77aa04d07719d964cf1"},"StopSignal":"SIGINT"},"NetworkSettings":{"Bridge":"","SandboxID":"31820ba19db92cb29bfd50bb6de6dd9de863d00b2aada875d96ef25be307f7fa","SandboxKey":"/var/run/docker/netns/31820ba19db9","Ports":{"5432/tcp":[{"HostIp":"0.0.0.0","HostPort":"35010"},{"HostIp":"::","HostPort":"35010"}]},"HairpinMode":false,"LinkLocalIPv6Address":"","LinkLocalIPv6PrefixLen":0,"SecondaryIPAddresses":null,"SecondaryIPv6Addresses":null,"EndpointID":"77bc51f6155d4c9c81b85f115ac75f8658f1ea8ee93b67f74d9dcd87b85c7fd5","Gateway":"172.17.0.1","GlobalIPv6Address":"","GlobalIPv6PrefixLen":0,"IPAddress":"172.17.0.3","IPPrefixLen":16,"IPv6Gateway":"","MacAddress":"02:42:ac:11:00:03","Networks":{"bridge":{"IPAMConfig":null,"Links":null,"Aliases":null,"MacAddress":"02:42:ac:11:00:03","NetworkID":"e959adf4a34df1590dded398fca7a8235844ed5057c580e41e5eaf4f8f83da9e","EndpointID":"77bc51f6155d4c9c81b85f115ac75f8658f1ea8ee93b67f74d9dcd87b85c7fd5","Gateway":"172.17.0.1","IPAddress":"172.17.0.3","IPPrefixLen":16,"IPv6Gateway":"","GlobalIPv6Address":"","GlobalIPv6PrefixLen":0,"DriverOpts":null,"DNSNames":null}}}}

With stacktrace:

at System.Net.Http.HttpContent.LoadIntoBufferAsyncCore(Task serializeToStreamTask, MemoryStream tempBuffer)
at System.Net.Http.HttpClient.<SendAsync>g__Core|83_0(HttpRequestMessage request, HttpCompletionOption completionOption, CancellationTokenSource cts, Boolean disposeCts, CancellationTokenSource pendingRequestsCts, CancellationToken originalCancellationToken)
[at Docker.DotNet.DockerClient.PrivateMakeRequestAsync(TimeSpan timeout, HttpCompletionOption completionOption, HttpMethod method, String path, IQueryString queryString, IDictionary`2 headers, IRequestContent data, CancellationToken cancellationToken) in /_/src/Docker.DotNet/DockerClient.cs:line 423](https://dev.azure.com/stow-robotics/stow%20RnD/_git/f046e4b0-956d-416e-b792-836a341d62dd?path=%2F_%2Fsrc%2FDocker.DotNet%2FDockerClient.cs&version=GBdevelopment&_a=contents&line=423&lineEnd=424&lineStartColumn=1&lineEndColumn=1&lineStyle=plain)
[at Docker.DotNet.DockerClient.MakeRequestAsync[T](IEnumerable`1 errorHandlers, HttpMethod method, String path, IQueryString queryString, IRequestContent body, IDictionary`2 headers, TimeSpan timeout, CancellationToken token) in /_/src/Docker.DotNet/DockerClient.cs:line 254](https://dev.azure.com/stow-robotics/stow%20RnD/_git/f046e4b0-956d-416e-b792-836a341d62dd?path=%2F_%2Fsrc%2FDocker.DotNet%2FDockerClient.cs&version=GBdevelopment&_a=contents&line=254&lineEnd=255&lineStartColumn=1&lineEndColumn=1&lineStyle=plain)
[at Docker.DotNet.ContainerOperations.InspectContainerAsync(String id, CancellationToken cancellationToken) in /_/src/Docker.DotNet/Endpoints/ContainerOperations.cs:line 74](https://dev.azure.com/stow-robotics/stow%20RnD/_git/f046e4b0-956d-416e-b792-836a341d62dd?path=%2F_%2Fsrc%2FDocker.DotNet%2FEndpoints%2FContainerOperations.cs&version=GBdevelopment&_a=contents&line=74&lineEnd=75&lineStartColumn=1&lineEndColumn=1&lineStyle=plain)
[at DotNet.Testcontainers.Clients.DockerContainerOperations.ByIdAsync(String id, CancellationToken ct) in /_/src/Testcontainers/Clients/DockerContainerOperations.cs:line 36](https://dev.azure.com/stow-robotics/stow%20RnD/_git/f046e4b0-956d-416e-b792-836a341d62dd?path=%2F_%2Fsrc%2FTestcontainers%2FClients%2FDockerContainerOperations.cs&version=GBdevelopment&_a=contents&line=36&lineEnd=37&lineStartColumn=1&lineEndColumn=1&lineStyle=plain)
[at DotNet.Testcontainers.Containers.DockerContainer.CheckReadinessAsync(WaitStrategy waitStrategy, CancellationToken ct) in /_/src/Testcontainers/Containers/DockerContainer.cs:line 635](https://dev.azure.com/stow-robotics/stow%20RnD/_git/f046e4b0-956d-416e-b792-836a341d62dd?path=%2F_%2Fsrc%2FTestcontainers%2FContainers%2FDockerContainer.cs&version=GBdevelopment&_a=contents&line=635&lineEnd=636&lineStartColumn=1&lineEndColumn=1&lineStyle=plain)
[at DotNet.Testcontainers.Configurations.WaitStrategy.<>c__DisplayClass24_0.<<WaitUntilAsync>g__UntilAsync|0>d.MoveNext() in /_/src/Testcontainers/Configurations/WaitStrategies/WaitStrategy.cs:line 184](https://dev.azure.com/stow-robotics/stow%20RnD/_git/f046e4b0-956d-416e-b792-836a341d62dd?path=%2F_%2Fsrc%2FTestcontainers%2FConfigurations%2FWaitStrategies%2FWaitStrategy.cs&version=GBdevelopment&_a=contents&line=184&lineEnd=185&lineStartColumn=1&lineEndColumn=1&lineStyle=plain)
--- End of stack trace from previous location ---
[at DotNet.Testcontainers.Configurations.WaitStrategy.WaitUntilAsync(Func`1 wait, TimeSpan interval, TimeSpan timeout, Int32 retries, CancellationToken ct) in /_/src/Testcontainers/Configurations/WaitStrategies/WaitStrategy.cs:line 213](https://dev.azure.com/stow-robotics/stow%20RnD/_git/f046e4b0-956d-416e-b792-836a341d62dd?path=%2F_%2Fsrc%2FTestcontainers%2FConfigurations%2FWaitStrategies%2FWaitStrategy.cs&version=GBdevelopment&_a=contents&line=213&lineEnd=214&lineStartColumn=1&lineEndColumn=1&lineStyle=plain)
[at DotNet.Testcontainers.Containers.DockerContainer.CheckReadinessAsync(IEnumerable`1 waitStrategies, CancellationToken ct) in /_/src/Testcontainers/Containers/DockerContainer.cs:line 656](https://dev.azure.com/stow-robotics/stow%20RnD/_git/f046e4b0-956d-416e-b792-836a341d62dd?path=%2F_%2Fsrc%2FTestcontainers%2FContainers%2FDockerContainer.cs&version=GBdevelopment&_a=contents&line=656&lineEnd=657&lineStartColumn=1&lineEndColumn=1&lineStyle=plain)
[at DotNet.Testcontainers.Containers.DockerContainer.UnsafeStartAsync(CancellationToken ct) in /_/src/Testcontainers/Containers/DockerContainer.cs:line 518](https://dev.azure.com/stow-robotics/stow%20RnD/_git/f046e4b0-956d-416e-b792-836a341d62dd?path=%2F_%2Fsrc%2FTestcontainers%2FContainers%2FDockerContainer.cs&version=GBdevelopment&_a=contents&line=518&lineEnd=519&lineStartColumn=1&lineEndColumn=1&lineStyle=plain)
[at DotNet.Testcontainers.Containers.DockerContainer.StartAsync(CancellationToken ct) in /_/src/Testcontainers/Containers/DockerContainer.cs:line 301](https://dev.azure.com/stow-robotics/stow%20RnD/_git/f046e4b0-956d-416e-b792-836a341d62dd?path=%2F_%2Fsrc%2FTestcontainers%2FContainers%2FDockerContainer.cs&version=GBdevelopment&_a=contents&line=301&lineEnd=302&lineStartColumn=1&lineEndColumn=1&lineStyle=plain)

Relevant log output

Additional information

No response

@maartenjorens maartenjorens added the bug Something isn't working label Mar 17, 2025
@HofmeisterAn HofmeisterAn transferred this issue from testcontainers/testcontainers-dotnet Mar 17, 2025
@HofmeisterAn
Copy link
Collaborator

HofmeisterAn commented Mar 17, 2025

Thank you for creating the issue. I believe this is an issue with Docker.DotNet. I moved the issue to the upstream repository. It looks like that Docker.DotNet fails to send the HTTP request properly. If you look at the exception message, the body (JSON payload) seems incomplete (the second one looks incomplete too).

Invalid chunk header: Source":"/var/lib/docker/volumes/c96b7eb7687483b283a5d59cd4905cfea059b77fab71121c5e37c0afb0303e4b/_data","Destination":"/var/lib/postgresql/data","Driver":"local","Mode":"","RW":true,"Propagation":""}],"Config":{"Hostname":"b93702419de0","Domainname":"","User":"","AttachStdin":false,"AttachStdout":false,"AttachStderr":false,"ExposedPorts":{"5432/tcp":{}},"Tty":false,"OpenStdin":false,"StdinOnce":false,"Env":["POSTGRES_PASSWORD=postgres","POSTGRES_USER=postgres","POSTGRES_DB=postgres","PATH=/usr/local/sbin:/usr/local/bin:/usr/sbin:/usr/bin:/sbin:/bin:/usr/lib/postgresql/15/bin","GOSU_VERSION=1.16","LANG=en_US.utf8","PG_MAJOR=15","PG_VERSION=15.1-1.pgdg110+1","PGDATA=/var/lib/postgresql/data"],"Cmd":["-c","fsync=off","-c","full_page_writes=off","-c","synchronous_commit=off"],"Image":"postgres:15.1","Volumes":{"/var/lib/postgresql/data":{}},"WorkingDir":"","Entrypoint":["docker-entrypoint.sh"],"OnBuild":null,"Labels":{"org.testcontainers":"true","org.testcontainers.lang":"dotnet","org.testcontainers.resource-reaper-session":"40531ddd-6f4f-4a34-9413-1b8c9cde31e7","org.testcontainers.session-id":"40531ddd-6f4f-4a34-9413-1b8c9cde31e7","org.testcontainers.version":"4.3.0+b53e4f24afc2310b9695a77aa04d07719d964cf1"},"StopSignal":"SIGINT"},"NetworkSettings":{"Bridge":"","SandboxID":"","SandboxKey":"","Ports":{},"HairpinMode":false,"LinkLocalIPv6Address":"","LinkLocalIPv6PrefixLen":0,"SecondaryIPAddresses":null,"SecondaryIPv6Addresses":null,"EndpointID":"","Gateway":"","GlobalIPv6Address":"","GlobalIPv6PrefixLen":0,"IPAddress":"","IPPrefixLen":0,"IPv6Gateway":"","MacAddress":"","Networks":{"bridge":{"IPAMConfig":null,"Links":null,"Aliases":null,"MacAddress":"","NetworkID":"","EndpointID":"","Gateway":"","IPAddress":"","IPPrefixLen":0,"IPv6Gateway":"","GlobalIPv6Address":"","GlobalIPv6PrefixLen":0,"DriverOpts":null,"DNSNames":null}}}}

@HofmeisterAn HofmeisterAn added the help wanted Extra attention is needed label Mar 17, 2025
@HofmeisterAn
Copy link
Collaborator

We should probably look into the HTTP client message handler and check why it is failing to send the request. Docker.DotNet sets the required handler in its constructor.

@maartenjorens
Copy link
Author

It appears that the request was sent correctly, and the 'Invalid chunk header' exception is related to the response from the GET containers/{id}/json request

Unfortunately, I am unable to reproduce this issue on my local machine. As usual everything works as expected.
The problem only occurs on our build server, despite having the same Docker version, Rancher Desktop version, etc.

@HofmeisterAn
Copy link
Collaborator

HofmeisterAn commented Mar 17, 2025

You are right, it looks like:

  1. We start reading the response here.
  2. Then, create a ChunkedReadStream(BufferedReadStream) instance.
  3. And finally, throw the exception IOException(string).

Do you think you could run a custom version of Docker.DotNet in your CI that logs additional information, such as the headerLine? Maybe we can introduce proper traceability by adding logging to the library.

@maartenjorens
Copy link
Author

maartenjorens commented Mar 18, 2025

Yeah, it's possible for me to run a custom version.

When debugging locally it seems like I am able to reproduce the issue, or at least something very similar.
In the ChunkedReadStream instance I get the following exception when debugging:

Image

Where responseLines in the HttpConnection had the following values:

Image

Can you potentially guide me towards some insights? It seems like I'm overlooking the problem.
I can only reproduce it when debugging and placing some breakpoints, otherwise when running without any breakpoints all goes well.

@HofmeisterAn
Copy link
Collaborator

I started yesterday adding a logger to the library. Hopefully, this will help us identify and address issues that occur when running with Podman, Rancher, etc. I also created a simple test (note that the output from the first run might get truncated due to the size of the pull log messages; however, the second run should contain the interesting and necessary information). When I run the test against Docker Desktop, I receive the following data. The headerLine always corresponds to a numeric hex value.

RequestUri="http://docker_engine/containers/create"
Headers="HTTP/1.1 201 Created, Api-Version: 1.47, Content-Type: application/json, Date: Tue, 18 Mar 2025 11:58:16 GMT, Docker-Experimental: false, Ostype: linux, Server: Docker/27.5.1 (linux), Connection: close, Transfer-Encoding: chunked"
HeaderLine="58"
HeaderLine="0"
Content="{"Id":"c326db38cfa70232485be88f54b17541618436c0dba1c8d653b88422add23830","Warnings":[]}"

RequestUri="http://docker_engine/containers/c326db38cfa70232485be88f54b17541618436c0dba1c8d653b88422add23830/json"
Headers="HTTP/1.1 200 OK, Api-Version: 1.47, Content-Type: application/json, Date: Tue, 18 Mar 2025 11:58:16 GMT, Docker-Experimental: false, Ostype: linux, Server: Docker/27.5.1 (linux), Connection: close, Transfer-Encoding: chunked"
HeaderLine="eed"
HeaderLine="0"
Content="{"Id":"c326db38cfa70232485be88f54b17541618436c0dba1c8d653b88422add23830","Created":"2025-03-18T11:58:16.735439603Z","Path":"docker-entrypoint.sh","Args":["postgres"],"State":{"Status":"created","Running":false,"Paused":false,"Restarting":false,"OOMKilled":false,"Dead":false,"Pid":0,"ExitCode":0,"Error":"","StartedAt":"0001-01-01T00:00:00Z","FinishedAt":"0001-01-01T00:00:00Z"},"Image":"sha256:7062a2109c4b51f3c792c7ea01e83ed12ef9a980886e3b3d380a7d2e5f6ce3f5","ResolvConfPath":"","HostnamePath":"","HostsPath":"","LogPath":"","Name":"/frosty_volhard","RestartCount":0,"Driver":"overlayfs","Platform":"linux","MountLabel":"","ProcessLabel":"","AppArmorProfile":"","ExecIDs":null,"HostConfig":{"Binds":null,"ContainerIDFile":"","LogConfig":{"Type":"json-file","Config":{}},"NetworkMode":"bridge","PortBindings":{},"RestartPolicy":{"Name":"no","MaximumRetryCount":0},"AutoRemove":false,"VolumeDriver":"","VolumesFrom":null,"ConsoleSize":[0,0],"CapAdd":null,"CapDrop":null,"CgroupnsMode":"host","Dns":null,"DnsOptions":null,"DnsSearch":null,"ExtraHosts":null,"GroupAdd":null,"IpcMode":"private","Cgroup":"","Links":null,"OomScoreAdj":0,"PidMode":"","Privileged":false,"PublishAllPorts":false,"ReadonlyRootfs":false,"SecurityOpt":null,"UTSMode":"","UsernsMode":"","ShmSize":67108864,"Runtime":"runc","Isolation":"","CpuShares":0,"Memory":0,"NanoCpus":0,"CgroupParent":"","BlkioWeight":0,"BlkioWeightDevice":null,"BlkioDeviceReadBps":null,"BlkioDeviceWriteBps":null,"BlkioDeviceReadIOps":null,"BlkioDeviceWriteIOps":null,"CpuPeriod":0,"CpuQuota":0,"CpuRealtimePeriod":0,"CpuRealtimeRuntime":0,"CpusetCpus":"","CpusetMems":"","Devices":null,"DeviceCgroupRules":null,"DeviceRequests":null,"MemoryReservation":0,"MemorySwap":0,"MemorySwappiness":null,"OomKillDisable":false,"PidsLimit":null,"Ulimits":null,"CpuCount":0,"CpuPercent":0,"IOMaximumIOps":0,"IOMaximumBandwidth":0,"MaskedPaths":["/proc/asound","/proc/acpi","/proc/kcore","/proc/keys","/proc/latency_stats","/proc/timer_list","/proc/timer_stats","/proc/sched_debug","/proc/scsi","/sys/firmware","/sys/devices/virtual/powercap"],"ReadonlyPaths":["/proc/bus","/proc/fs","/proc/irq","/proc/sys","/proc/sysrq-trigger"]},"GraphDriver":{"Data":null,"Name":"overlayfs"},"Mounts":[{"Type":"volume","Name":"218ec5bc0bd77591ba76821389beeebf68ef7d6f4b67c4e8de2625d5dfe35e8c","Source":"/var/lib/docker/volumes/218ec5bc0bd77591ba76821389beeebf68ef7d6f4b67c4e8de2625d5dfe35e8c/_data","Destination":"/var/lib/postgresql/data","Driver":"local","Mode":"","RW":true,"Propagation":""}],"Config":{"Hostname":"c326db38cfa7","Domainname":"","User":"","AttachStdin":false,"AttachStdout":false,"AttachStderr":false,"ExposedPorts":{"5432/tcp":{}},"Tty":false,"OpenStdin":false,"StdinOnce":false,"Env":["PATH=/usr/local/sbin:/usr/local/bin:/usr/sbin:/usr/bin:/sbin:/bin","GOSU_VERSION=1.17","LANG=en_US.utf8","PG_MAJOR=17","PG_VERSION=17.4","PG_SHA256=c4605b73fea11963406699f949b966e5d173a7ee0ccaef8938dec0ca8a995fe7","DOCKER_PG_LLVM_DEPS=llvm19-dev \t\tclang19","PGDATA=/var/lib/postgresql/data"],"Cmd":["postgres"],"Image":"postgres:alpine","Volumes":{"/var/lib/postgresql/data":{}},"WorkingDir":"/","Entrypoint":["docker-entrypoint.sh"],"OnBuild":null,"Labels":{},"StopSignal":"SIGINT"},"NetworkSettings":{"Bridge":"","SandboxID":"","SandboxKey":"","Ports":{},"HairpinMode":false,"LinkLocalIPv6Address":"","LinkLocalIPv6PrefixLen":0,"SecondaryIPAddresses":null,"SecondaryIPv6Addresses":null,"EndpointID":"","Gateway":"","GlobalIPv6Address":"","GlobalIPv6PrefixLen":0,"IPAddress":"","IPPrefixLen":0,"IPv6Gateway":"","MacAddress":"","Networks":{"bridge":{"IPAMConfig":null,"Links":null,"Aliases":null,"MacAddress":"","DriverOpts":null,"NetworkID":"","EndpointID":"","Gateway":"","IPAddress":"","IPPrefixLen":0,"IPv6Gateway":"","GlobalIPv6Address":"","GlobalIPv6PrefixLen":0,"DNSNames":null}}}}"

RequestUri="http://docker_engine/containers/c326db38cfa70232485be88f54b17541618436c0dba1c8d653b88422add23830/json"
Headers="HTTP/1.1 200 OK, Api-Version: 1.47, Content-Type: application/json, Date: Tue, 18 Mar 2025 11:58:16 GMT, Docker-Experimental: false, Ostype: linux, Server: Docker/27.5.1 (linux), Connection: close, Transfer-Encoding: chunked"
HeaderLine="eed"
HeaderLine="0"
Content="{"Id":"c326db38cfa70232485be88f54b17541618436c0dba1c8d653b88422add23830","Created":"2025-03-18T11:58:16.735439603Z","Path":"docker-entrypoint.sh","Args":["postgres"],"State":{"Status":"created","Running":false,"Paused":false,"Restarting":false,"OOMKilled":false,"Dead":false,"Pid":0,"ExitCode":0,"Error":"","StartedAt":"0001-01-01T00:00:00Z","FinishedAt":"0001-01-01T00:00:00Z"},"Image":"sha256:7062a2109c4b51f3c792c7ea01e83ed12ef9a980886e3b3d380a7d2e5f6ce3f5","ResolvConfPath":"","HostnamePath":"","HostsPath":"","LogPath":"","Name":"/frosty_volhard","RestartCount":0,"Driver":"overlayfs","Platform":"linux","MountLabel":"","ProcessLabel":"","AppArmorProfile":"","ExecIDs":null,"HostConfig":{"Binds":null,"ContainerIDFile":"","LogConfig":{"Type":"json-file","Config":{}},"NetworkMode":"bridge","PortBindings":{},"RestartPolicy":{"Name":"no","MaximumRetryCount":0},"AutoRemove":false,"VolumeDriver":"","VolumesFrom":null,"ConsoleSize":[0,0],"CapAdd":null,"CapDrop":null,"CgroupnsMode":"host","Dns":null,"DnsOptions":null,"DnsSearch":null,"ExtraHosts":null,"GroupAdd":null,"IpcMode":"private","Cgroup":"","Links":null,"OomScoreAdj":0,"PidMode":"","Privileged":false,"PublishAllPorts":false,"ReadonlyRootfs":false,"SecurityOpt":null,"UTSMode":"","UsernsMode":"","ShmSize":67108864,"Runtime":"runc","Isolation":"","CpuShares":0,"Memory":0,"NanoCpus":0,"CgroupParent":"","BlkioWeight":0,"BlkioWeightDevice":null,"BlkioDeviceReadBps":null,"BlkioDeviceWriteBps":null,"BlkioDeviceReadIOps":null,"BlkioDeviceWriteIOps":null,"CpuPeriod":0,"CpuQuota":0,"CpuRealtimePeriod":0,"CpuRealtimeRuntime":0,"CpusetCpus":"","CpusetMems":"","Devices":null,"DeviceCgroupRules":null,"DeviceRequests":null,"MemoryReservation":0,"MemorySwap":0,"MemorySwappiness":null,"OomKillDisable":false,"PidsLimit":null,"Ulimits":null,"CpuCount":0,"CpuPercent":0,"IOMaximumIOps":0,"IOMaximumBandwidth":0,"MaskedPaths":["/proc/asound","/proc/acpi","/proc/kcore","/proc/keys","/proc/latency_stats","/proc/timer_list","/proc/timer_stats","/proc/sched_debug","/proc/scsi","/sys/firmware","/sys/devices/virtual/powercap"],"ReadonlyPaths":["/proc/bus","/proc/fs","/proc/irq","/proc/sys","/proc/sysrq-trigger"]},"GraphDriver":{"Data":null,"Name":"overlayfs"},"Mounts":[{"Type":"volume","Name":"218ec5bc0bd77591ba76821389beeebf68ef7d6f4b67c4e8de2625d5dfe35e8c","Source":"/var/lib/docker/volumes/218ec5bc0bd77591ba76821389beeebf68ef7d6f4b67c4e8de2625d5dfe35e8c/_data","Destination":"/var/lib/postgresql/data","Driver":"local","Mode":"","RW":true,"Propagation":""}],"Config":{"Hostname":"c326db38cfa7","Domainname":"","User":"","AttachStdin":false,"AttachStdout":false,"AttachStderr":false,"ExposedPorts":{"5432/tcp":{}},"Tty":false,"OpenStdin":false,"StdinOnce":false,"Env":["PATH=/usr/local/sbin:/usr/local/bin:/usr/sbin:/usr/bin:/sbin:/bin","GOSU_VERSION=1.17","LANG=en_US.utf8","PG_MAJOR=17","PG_VERSION=17.4","PG_SHA256=c4605b73fea11963406699f949b966e5d173a7ee0ccaef8938dec0ca8a995fe7","DOCKER_PG_LLVM_DEPS=llvm19-dev \t\tclang19","PGDATA=/var/lib/postgresql/data"],"Cmd":["postgres"],"Image":"postgres:alpine","Volumes":{"/var/lib/postgresql/data":{}},"WorkingDir":"/","Entrypoint":["docker-entrypoint.sh"],"OnBuild":null,"Labels":{},"StopSignal":"SIGINT"},"NetworkSettings":{"Bridge":"","SandboxID":"","SandboxKey":"","Ports":{},"HairpinMode":false,"LinkLocalIPv6Address":"","LinkLocalIPv6PrefixLen":0,"SecondaryIPAddresses":null,"SecondaryIPv6Addresses":null,"EndpointID":"","Gateway":"","GlobalIPv6Address":"","GlobalIPv6PrefixLen":0,"IPAddress":"","IPPrefixLen":0,"IPv6Gateway":"","MacAddress":"","Networks":{"bridge":{"IPAMConfig":null,"Links":null,"Aliases":null,"MacAddress":"","DriverOpts":null,"NetworkID":"","EndpointID":"","Gateway":"","IPAddress":"","IPPrefixLen":0,"IPv6Gateway":"","GlobalIPv6Address":"","GlobalIPv6PrefixLen":0,"DNSNames":null}}}}"

RequestUri="http://docker_engine/containers/c326db38cfa70232485be88f54b17541618436c0dba1c8d653b88422add23830/json"
Headers="HTTP/1.1 200 OK, Api-Version: 1.47, Content-Type: application/json, Date: Tue, 18 Mar 2025 11:58:16 GMT, Docker-Experimental: false, Ostype: linux, Server: Docker/27.5.1 (linux), Connection: close, Transfer-Encoding: chunked"
HeaderLine="eed"
HeaderLine="0"
Content="{"Id":"c326db38cfa70232485be88f54b17541618436c0dba1c8d653b88422add23830","Created":"2025-03-18T11:58:16.735439603Z","Path":"docker-entrypoint.sh","Args":["postgres"],"State":{"Status":"created","Running":false,"Paused":false,"Restarting":false,"OOMKilled":false,"Dead":false,"Pid":0,"ExitCode":0,"Error":"","StartedAt":"0001-01-01T00:00:00Z","FinishedAt":"0001-01-01T00:00:00Z"},"Image":"sha256:7062a2109c4b51f3c792c7ea01e83ed12ef9a980886e3b3d380a7d2e5f6ce3f5","ResolvConfPath":"","HostnamePath":"","HostsPath":"","LogPath":"","Name":"/frosty_volhard","RestartCount":0,"Driver":"overlayfs","Platform":"linux","MountLabel":"","ProcessLabel":"","AppArmorProfile":"","ExecIDs":null,"HostConfig":{"Binds":null,"ContainerIDFile":"","LogConfig":{"Type":"json-file","Config":{}},"NetworkMode":"bridge","PortBindings":{},"RestartPolicy":{"Name":"no","MaximumRetryCount":0},"AutoRemove":false,"VolumeDriver":"","VolumesFrom":null,"ConsoleSize":[0,0],"CapAdd":null,"CapDrop":null,"CgroupnsMode":"host","Dns":null,"DnsOptions":null,"DnsSearch":null,"ExtraHosts":null,"GroupAdd":null,"IpcMode":"private","Cgroup":"","Links":null,"OomScoreAdj":0,"PidMode":"","Privileged":false,"PublishAllPorts":false,"ReadonlyRootfs":false,"SecurityOpt":null,"UTSMode":"","UsernsMode":"","ShmSize":67108864,"Runtime":"runc","Isolation":"","CpuShares":0,"Memory":0,"NanoCpus":0,"CgroupParent":"","BlkioWeight":0,"BlkioWeightDevice":null,"BlkioDeviceReadBps":null,"BlkioDeviceWriteBps":null,"BlkioDeviceReadIOps":null,"BlkioDeviceWriteIOps":null,"CpuPeriod":0,"CpuQuota":0,"CpuRealtimePeriod":0,"CpuRealtimeRuntime":0,"CpusetCpus":"","CpusetMems":"","Devices":null,"DeviceCgroupRules":null,"DeviceRequests":null,"MemoryReservation":0,"MemorySwap":0,"MemorySwappiness":null,"OomKillDisable":false,"PidsLimit":null,"Ulimits":null,"CpuCount":0,"CpuPercent":0,"IOMaximumIOps":0,"IOMaximumBandwidth":0,"MaskedPaths":["/proc/asound","/proc/acpi","/proc/kcore","/proc/keys","/proc/latency_stats","/proc/timer_list","/proc/timer_stats","/proc/sched_debug","/proc/scsi","/sys/firmware","/sys/devices/virtual/powercap"],"ReadonlyPaths":["/proc/bus","/proc/fs","/proc/irq","/proc/sys","/proc/sysrq-trigger"]},"GraphDriver":{"Data":null,"Name":"overlayfs"},"Mounts":[{"Type":"volume","Name":"218ec5bc0bd77591ba76821389beeebf68ef7d6f4b67c4e8de2625d5dfe35e8c","Source":"/var/lib/docker/volumes/218ec5bc0bd77591ba76821389beeebf68ef7d6f4b67c4e8de2625d5dfe35e8c/_data","Destination":"/var/lib/postgresql/data","Driver":"local","Mode":"","RW":true,"Propagation":""}],"Config":{"Hostname":"c326db38cfa7","Domainname":"","User":"","AttachStdin":false,"AttachStdout":false,"AttachStderr":false,"ExposedPorts":{"5432/tcp":{}},"Tty":false,"OpenStdin":false,"StdinOnce":false,"Env":["PATH=/usr/local/sbin:/usr/local/bin:/usr/sbin:/usr/bin:/sbin:/bin","GOSU_VERSION=1.17","LANG=en_US.utf8","PG_MAJOR=17","PG_VERSION=17.4","PG_SHA256=c4605b73fea11963406699f949b966e5d173a7ee0ccaef8938dec0ca8a995fe7","DOCKER_PG_LLVM_DEPS=llvm19-dev \t\tclang19","PGDATA=/var/lib/postgresql/data"],"Cmd":["postgres"],"Image":"postgres:alpine","Volumes":{"/var/lib/postgresql/data":{}},"WorkingDir":"/","Entrypoint":["docker-entrypoint.sh"],"OnBuild":null,"Labels":{},"StopSignal":"SIGINT"},"NetworkSettings":{"Bridge":"","SandboxID":"","SandboxKey":"","Ports":{},"HairpinMode":false,"LinkLocalIPv6Address":"","LinkLocalIPv6PrefixLen":0,"SecondaryIPAddresses":null,"SecondaryIPv6Addresses":null,"EndpointID":"","Gateway":"","GlobalIPv6Address":"","GlobalIPv6PrefixLen":0,"IPAddress":"","IPPrefixLen":0,"IPv6Gateway":"","MacAddress":"","Networks":{"bridge":{"IPAMConfig":null,"Links":null,"Aliases":null,"MacAddress":"","DriverOpts":null,"NetworkID":"","EndpointID":"","Gateway":"","IPAddress":"","IPPrefixLen":0,"IPv6Gateway":"","GlobalIPv6Address":"","GlobalIPv6PrefixLen":0,"DNSNames":null}}}}"

When debugging locally it seems like I am able to reproduce the issue, or at least something very similar.

Did you do anything special to break/reproduce it?

It seems that in your environment, the library is reading the wrong parts of the stream. It appears to be reading the body instead of the header.

Have you tried using an older version of Testcontainers for .NET as well? I noticed you’re using an outdated version of Docker. Have you tried updating it? We recently updated the library to support the new Docker API. Although, this alone does not explain the flakiness.

@maartenjorens
Copy link
Author

Thank you, I've just checked out the branch and ran the test creating the following result:

[Docker.DotNet 00:00:00.04] RequestUri="http://docker_engine/images/create?fromImage=postgres%3Aalpine"
[Docker.DotNet 00:00:00.95] Headers="HTTP/1.1 200 OK, Api-Version: 1.45, Content-Type: application/json, Date: Tue, 18 Mar 2025 12:49:15 GMT, Docker-Experimental: false, Ostype: linux, Server: Docker/26.1.5 (linux), Connection: close, Transfer-Encoding: chunked"
[Docker.DotNet 00:00:00.96] HeaderLine="d6"
[Docker.DotNet 00:00:00.96] HeaderLine="0"
[Docker.DotNet 00:00:00.96] Content="{"status":"Pulling from library/postgres","id":"alpine"}
{"status":"Digest: sha256:7062a2109c4b51f3c792c7ea01e83ed12ef9a980886e3b3d380a7d2e5f6ce3f5"}
{"status":"Status: Image is up to date for postgres:alpine"}"

[Docker.DotNet 00:00:00.99] RequestUri="http://docker_engine/containers/create"
[Docker.DotNet 00:00:01.03] Headers="HTTP/1.1 201 Created, Api-Version: 1.45, Content-Length: 88, Content-Type: application/json, Date: Tue, 18 Mar 2025 12:49:15 GMT, Docker-Experimental: false, Ostype: linux, Server: Docker/26.1.5 (linux), Connection: close"
[Docker.DotNet 00:00:01.03] Content="{"Id":"040c4970b7bbf57033d439f92da218c4307eed5c18500ef4ec354231035be972","Warnings":[]}"

[Docker.DotNet 00:00:01.03] RequestUri="http://docker_engine/containers/040c4970b7bbf57033d439f92da218c4307eed5c18500ef4ec354231035be972/json"
[Docker.DotNet 00:00:01.04] Headers="HTTP/1.1 200 OK, Api-Version: 1.45, Content-Type: application/json, Date: Tue, 18 Mar 2025 12:49:15 GMT, Docker-Experimental: false, Ostype: linux, Server: Docker/26.1.5 (linux), Connection: close, Transfer-Encoding: chunked"
[Docker.DotNet 00:00:01.04] HeaderLine="1456"
[Docker.DotNet 00:00:01.04] HeaderLine="0"
[Docker.DotNet 00:00:01.04] Content="{"Id":"040c4970b7bbf57033d439f92da218c4307eed5c18500ef4ec354231035be972","Created":"2025-03-18T12:49:15.087386969Z","Path":"docker-entrypoint.sh","Args":["postgres"],"State":{"Status":"created","Running":false,"Paused":false,"Restarting":false,"OOMKilled":false,"Dead":false,"Pid":0,"ExitCode":0,"Error":"","StartedAt":"0001-01-01T00:00:00Z","FinishedAt":"0001-01-01T00:00:00Z"},"Image":"sha256:0150e3200277b907866758e22a3b9bba7857325b994848fe9f44b3610c3ae17e","ResolvConfPath":"","HostnamePath":"","HostsPath":"","LogPath":"","Name":"/agitated_pike","RestartCount":0,"Driver":"overlay2","Platform":"linux","MountLabel":"","ProcessLabel":"","AppArmorProfile":"","ExecIDs":null,"HostConfig":{"Binds":null,"ContainerIDFile":"","LogConfig":{"Type":"json-file","Config":{}},"NetworkMode":"bridge","PortBindings":null,"RestartPolicy":{"Name":"no","MaximumRetryCount":0},"AutoRemove":false,"VolumeDriver":"","VolumesFrom":null,"ConsoleSize":[0,0],"CapAdd":null,"CapDrop":null,"CgroupnsMode":"host","Dns":null,"DnsOptions":null,"DnsSearch":null,"ExtraHosts":null,"GroupAdd":null,"IpcMode":"private","Cgroup":"","Links":null,"OomScoreAdj":0,"PidMode":"","Privileged":false,"PublishAllPorts":false,"ReadonlyRootfs":false,"SecurityOpt":null,"UTSMode":"","UsernsMode":"","ShmSize":67108864,"Runtime":"runc","Isolation":"","CpuShares":0,"Memory":0,"NanoCpus":0,"CgroupParent":"","BlkioWeight":0,"BlkioWeightDevice":null,"BlkioDeviceReadBps":null,"BlkioDeviceWriteBps":null,"BlkioDeviceReadIOps":null,"BlkioDeviceWriteIOps":null,"CpuPeriod":0,"CpuQuota":0,"CpuRealtimePeriod":0,"CpuRealtimeRuntime":0,"CpusetCpus":"","CpusetMems":"","Devices":null,"DeviceCgroupRules":null,"DeviceRequests":null,"MemoryReservation":0,"MemorySwap":0,"MemorySwappiness":null,"OomKillDisable":false,"PidsLimit":null,"Ulimits":null,"CpuCount":0,"CpuPercent":0,"IOMaximumIOps":0,"IOMaximumBandwidth":0,"MaskedPaths":["/proc/asound","/proc/acpi","/proc/kcore","/proc/keys","/proc/latency_stats","/proc/timer_list","/proc/timer_stats","/proc/sched_debug","/proc/scsi","/sys/firmware","/sys/devices/virtual/powercap"],"ReadonlyPaths":["/proc/bus","/proc/fs","/proc/irq","/proc/sys","/proc/sysrq-trigger"]},"GraphDriver":{"Data":{"LowerDir":"/var/lib/docker/overlay2/3a3ddee76b1f5e76e02b303d3dcb16c04516880e60cd744dc14a219708b696c5-init/diff:/var/lib/docker/overlay2/08e3bd065c8092fca3d3c3e1e05378a9ff51aae9104ffb341105938119bc1587/diff:/var/lib/docker/overlay2/dca8aacd78be49f31cbb0531050eef913c08ff174049f56d26b70f392df64178/diff:/var/lib/docker/overlay2/cf9116ca77de65a9f85f001cfc6f27b922024a23dbe44260460cd87b8a04f90d/diff:/var/lib/docker/overlay2/6da91204cd6443d7abb7eb7f5db2edf95b9e325c2bed22f2edb9634fbd9aed8e/diff:/var/lib/docker/overlay2/7103485d5f137bd152d11a5495eb3547aa5bf9061875017f9c9a78ee0dc3a481/diff:/var/lib/docker/overlay2/927aadce05364c8ff5affb6dbaf1ec3a4986686d7288c41c2ad6525316906f63/diff:/var/lib/docker/overlay2/86646b8beca383f6c403e952629f7673907ae46619e980387229d0073c81d994/diff:/var/lib/docker/overlay2/b31ededb53b899df74a9ee61ef05fc50d2865795cf709945615151b51e2d6c76/diff:/var/lib/docker/overlay2/e2f6d08c2a6f2c8b9178a6db133555dcf3ba59cd7f272a28be4bc085c7caf855/diff:/var/lib/docker/overlay2/4b89349860a7bf7681f9d162a18ffc4003cd654b0acb94658ba4d51cafa51a6c/diff","MergedDir":"/var/lib/docker/overlay2/3a3ddee76b1f5e76e02b303d3dcb16c04516880e60cd744dc14a219708b696c5/merged","UpperDir":"/var/lib/docker/overlay2/3a3ddee76b1f5e76e02b303d3dcb16c04516880e60cd744dc14a219708b696c5/diff","WorkDir":"/var/lib/docker/overlay2/3a3ddee76b1f5e76e02b303d3dcb16c04516880e60cd744dc14a219708b696c5/work"},"Name":"overlay2"},"Mounts":[{"Type":"volume","Name":"16538a2a1d6460a3778237fd40638c92896f243f753ab83046ecf85f1fd09fce","Source":"/var/lib/docker/volumes/16538a2a1d6460a3778237fd40638c92896f243f753ab83046ecf85f1fd09fce/_data","Destination":"/var/lib/postgresql/data","Driver":"local","Mode":"","RW":true,"Propagation":""}],"Config":{"Hostname":"040c4970b7bb","Domainname":"","User":"","AttachStdin":false,"AttachStdout":false,"AttachStderr":false,"ExposedPorts":{"5432/tcp":{}},"Tty":false,"OpenStdin":false,"StdinOnce":false,"Env":["PATH=/usr/local/sbin:/usr/local/bin:/usr/sbin:/usr/bin:/sbin:/bin","GOSU_VERSION=1.17","LANG=en_US.utf8","PG_MAJOR=17","PG_VERSION=17.4","PG_SHA256=c4605b73fea11963406699f949b966e5d173a7ee0ccaef8938dec0ca8a995fe7","DOCKER_PG_LLVM_DEPS=llvm19-dev \t\tclang19","PGDATA=/var/lib/postgresql/data"],"Cmd":["postgres"],"Image":"postgres:alpine","Volumes":{"/var/lib/postgresql/data":{}},"WorkingDir":"/","Entrypoint":["docker-entrypoint.sh"],"OnBuild":null,"Labels":{},"StopSignal":"SIGINT"},"NetworkSettings":{"Bridge":"","SandboxID":"","SandboxKey":"","Ports":{},"HairpinMode":false,"LinkLocalIPv6Address":"","LinkLocalIPv6PrefixLen":0,"SecondaryIPAddresses":null,"SecondaryIPv6Addresses":null,"EndpointID":"","Gateway":"","GlobalIPv6Address":"","GlobalIPv6PrefixLen":0,"IPAddress":"","IPPrefixLen":0,"IPv6Gateway":"","MacAddress":"","Networks":{"bridge":{"IPAMConfig":null,"Links":null,"Aliases":null,"MacAddress":"","NetworkID":"","EndpointID":"","Gateway":"","IPAddress":"","IPPrefixLen":0,"IPv6Gateway":"","GlobalIPv6Address":"","GlobalIPv6PrefixLen":0,"DriverOpts":null,"DNSNames":null}}}}"

[Docker.DotNet 00:00:01.06] RequestUri="http://docker_engine/containers/040c4970b7bbf57033d439f92da218c4307eed5c18500ef4ec354231035be972/json"
[Docker.DotNet 00:00:01.06] Headers="HTTP/1.1 200 OK, Api-Version: 1.45, Content-Type: application/json, Date: Tue, 18 Mar 2025 12:49:15 GMT, Docker-Experimental: false, Ostype: linux, Server: Docker/26.1.5 (linux), Connection: close, Transfer-Encoding: chunked"
[Docker.DotNet 00:00:01.06] HeaderLine="1456"
[Docker.DotNet 00:00:01.06] HeaderLine="0"
[Docker.DotNet 00:00:01.06] Content="{"Id":"040c4970b7bbf57033d439f92da218c4307eed5c18500ef4ec354231035be972","Created":"2025-03-18T12:49:15.087386969Z","Path":"docker-entrypoint.sh","Args":["postgres"],"State":{"Status":"created","Running":false,"Paused":false,"Restarting":false,"OOMKilled":false,"Dead":false,"Pid":0,"ExitCode":0,"Error":"","StartedAt":"0001-01-01T00:00:00Z","FinishedAt":"0001-01-01T00:00:00Z"},"Image":"sha256:0150e3200277b907866758e22a3b9bba7857325b994848fe9f44b3610c3ae17e","ResolvConfPath":"","HostnamePath":"","HostsPath":"","LogPath":"","Name":"/agitated_pike","RestartCount":0,"Driver":"overlay2","Platform":"linux","MountLabel":"","ProcessLabel":"","AppArmorProfile":"","ExecIDs":null,"HostConfig":{"Binds":null,"ContainerIDFile":"","LogConfig":{"Type":"json-file","Config":{}},"NetworkMode":"bridge","PortBindings":null,"RestartPolicy":{"Name":"no","MaximumRetryCount":0},"AutoRemove":false,"VolumeDriver":"","VolumesFrom":null,"ConsoleSize":[0,0],"CapAdd":null,"CapDrop":null,"CgroupnsMode":"host","Dns":null,"DnsOptions":null,"DnsSearch":null,"ExtraHosts":null,"GroupAdd":null,"IpcMode":"private","Cgroup":"","Links":null,"OomScoreAdj":0,"PidMode":"","Privileged":false,"PublishAllPorts":false,"ReadonlyRootfs":false,"SecurityOpt":null,"UTSMode":"","UsernsMode":"","ShmSize":67108864,"Runtime":"runc","Isolation":"","CpuShares":0,"Memory":0,"NanoCpus":0,"CgroupParent":"","BlkioWeight":0,"BlkioWeightDevice":null,"BlkioDeviceReadBps":null,"BlkioDeviceWriteBps":null,"BlkioDeviceReadIOps":null,"BlkioDeviceWriteIOps":null,"CpuPeriod":0,"CpuQuota":0,"CpuRealtimePeriod":0,"CpuRealtimeRuntime":0,"CpusetCpus":"","CpusetMems":"","Devices":null,"DeviceCgroupRules":null,"DeviceRequests":null,"MemoryReservation":0,"MemorySwap":0,"MemorySwappiness":null,"OomKillDisable":false,"PidsLimit":null,"Ulimits":null,"CpuCount":0,"CpuPercent":0,"IOMaximumIOps":0,"IOMaximumBandwidth":0,"MaskedPaths":["/proc/asound","/proc/acpi","/proc/kcore","/proc/keys","/proc/latency_stats","/proc/timer_list","/proc/timer_stats","/proc/sched_debug","/proc/scsi","/sys/firmware","/sys/devices/virtual/powercap"],"ReadonlyPaths":["/proc/bus","/proc/fs","/proc/irq","/proc/sys","/proc/sysrq-trigger"]},"GraphDriver":{"Data":{"LowerDir":"/var/lib/docker/overlay2/3a3ddee76b1f5e76e02b303d3dcb16c04516880e60cd744dc14a219708b696c5-init/diff:/var/lib/docker/overlay2/08e3bd065c8092fca3d3c3e1e05378a9ff51aae9104ffb341105938119bc1587/diff:/var/lib/docker/overlay2/dca8aacd78be49f31cbb0531050eef913c08ff174049f56d26b70f392df64178/diff:/var/lib/docker/overlay2/cf9116ca77de65a9f85f001cfc6f27b922024a23dbe44260460cd87b8a04f90d/diff:/var/lib/docker/overlay2/6da91204cd6443d7abb7eb7f5db2edf95b9e325c2bed22f2edb9634fbd9aed8e/diff:/var/lib/docker/overlay2/7103485d5f137bd152d11a5495eb3547aa5bf9061875017f9c9a78ee0dc3a481/diff:/var/lib/docker/overlay2/927aadce05364c8ff5affb6dbaf1ec3a4986686d7288c41c2ad6525316906f63/diff:/var/lib/docker/overlay2/86646b8beca383f6c403e952629f7673907ae46619e980387229d0073c81d994/diff:/var/lib/docker/overlay2/b31ededb53b899df74a9ee61ef05fc50d2865795cf709945615151b51e2d6c76/diff:/var/lib/docker/overlay2/e2f6d08c2a6f2c8b9178a6db133555dcf3ba59cd7f272a28be4bc085c7caf855/diff:/var/lib/docker/overlay2/4b89349860a7bf7681f9d162a18ffc4003cd654b0acb94658ba4d51cafa51a6c/diff","MergedDir":"/var/lib/docker/overlay2/3a3ddee76b1f5e76e02b303d3dcb16c04516880e60cd744dc14a219708b696c5/merged","UpperDir":"/var/lib/docker/overlay2/3a3ddee76b1f5e76e02b303d3dcb16c04516880e60cd744dc14a219708b696c5/diff","WorkDir":"/var/lib/docker/overlay2/3a3ddee76b1f5e76e02b303d3dcb16c04516880e60cd744dc14a219708b696c5/work"},"Name":"overlay2"},"Mounts":[{"Type":"volume","Name":"16538a2a1d6460a3778237fd40638c92896f243f753ab83046ecf85f1fd09fce","Source":"/var/lib/docker/volumes/16538a2a1d6460a3778237fd40638c92896f243f753ab83046ecf85f1fd09fce/_data","Destination":"/var/lib/postgresql/data","Driver":"local","Mode":"","RW":true,"Propagation":""}],"Config":{"Hostname":"040c4970b7bb","Domainname":"","User":"","AttachStdin":false,"AttachStdout":false,"AttachStderr":false,"ExposedPorts":{"5432/tcp":{}},"Tty":false,"OpenStdin":false,"StdinOnce":false,"Env":["PATH=/usr/local/sbin:/usr/local/bin:/usr/sbin:/usr/bin:/sbin:/bin","GOSU_VERSION=1.17","LANG=en_US.utf8","PG_MAJOR=17","PG_VERSION=17.4","PG_SHA256=c4605b73fea11963406699f949b966e5d173a7ee0ccaef8938dec0ca8a995fe7","DOCKER_PG_LLVM_DEPS=llvm19-dev \t\tclang19","PGDATA=/var/lib/postgresql/data"],"Cmd":["postgres"],"Image":"postgres:alpine","Volumes":{"/var/lib/postgresql/data":{}},"WorkingDir":"/","Entrypoint":["docker-entrypoint.sh"],"OnBuild":null,"Labels":{},"StopSignal":"SIGINT"},"NetworkSettings":{"Bridge":"","SandboxID":"","SandboxKey":"","Ports":{},"HairpinMode":false,"LinkLocalIPv6Address":"","LinkLocalIPv6PrefixLen":0,"SecondaryIPAddresses":null,"SecondaryIPv6Addresses":null,"EndpointID":"","Gateway":"","GlobalIPv6Address":"","GlobalIPv6PrefixLen":0,"IPAddress":"","IPPrefixLen":0,"IPv6Gateway":"","MacAddress":"","Networks":{"bridge":{"IPAMConfig":null,"Links":null,"Aliases":null,"MacAddress":"","NetworkID":"","EndpointID":"","Gateway":"","IPAddress":"","IPPrefixLen":0,"IPv6Gateway":"","GlobalIPv6Address":"","GlobalIPv6PrefixLen":0,"DriverOpts":null,"DNSNames":null}}}}"

[Docker.DotNet 00:00:01.06] RequestUri="http://docker_engine/containers/040c4970b7bbf57033d439f92da218c4307eed5c18500ef4ec354231035be972/json"
[Docker.DotNet 00:00:01.06] Headers="HTTP/1.1 200 OK, Api-Version: 1.45, Content-Type: application/json, Date: Tue, 18 Mar 2025 12:49:15 GMT, Docker-Experimental: false, Ostype: linux, Server: Docker/26.1.5 (linux), Connection: close, Transfer-Encoding: chunked"
[Docker.DotNet 00:00:01.06] HeaderLine="1456"
[Docker.DotNet 00:00:01.06] HeaderLine="0"
[Docker.DotNet 00:00:01.06] Content="{"Id":"040c4970b7bbf57033d439f92da218c4307eed5c18500ef4ec354231035be972","Created":"2025-03-18T12:49:15.087386969Z","Path":"docker-entrypoint.sh","Args":["postgres"],"State":{"Status":"created","Running":false,"Paused":false,"Restarting":false,"OOMKilled":false,"Dead":false,"Pid":0,"ExitCode":0,"Error":"","StartedAt":"0001-01-01T00:00:00Z","FinishedAt":"0001-01-01T00:00:00Z"},"Image":"sha256:0150e3200277b907866758e22a3b9bba7857325b994848fe9f44b3610c3ae17e","ResolvConfPath":"","HostnamePath":"","HostsPath":"","LogPath":"","Name":"/agitated_pike","RestartCount":0,"Driver":"overlay2","Platform":"linux","MountLabel":"","ProcessLabel":"","AppArmorProfile":"","ExecIDs":null,"HostConfig":{"Binds":null,"ContainerIDFile":"","LogConfig":{"Type":"json-file","Config":{}},"NetworkMode":"bridge","PortBindings":null,"RestartPolicy":{"Name":"no","MaximumRetryCount":0},"AutoRemove":false,"VolumeDriver":"","VolumesFrom":null,"ConsoleSize":[0,0],"CapAdd":null,"CapDrop":null,"CgroupnsMode":"host","Dns":null,"DnsOptions":null,"DnsSearch":null,"ExtraHosts":null,"GroupAdd":null,"IpcMode":"private","Cgroup":"","Links":null,"OomScoreAdj":0,"PidMode":"","Privileged":false,"PublishAllPorts":false,"ReadonlyRootfs":false,"SecurityOpt":null,"UTSMode":"","UsernsMode":"","ShmSize":67108864,"Runtime":"runc","Isolation":"","CpuShares":0,"Memory":0,"NanoCpus":0,"CgroupParent":"","BlkioWeight":0,"BlkioWeightDevice":null,"BlkioDeviceReadBps":null,"BlkioDeviceWriteBps":null,"BlkioDeviceReadIOps":null,"BlkioDeviceWriteIOps":null,"CpuPeriod":0,"CpuQuota":0,"CpuRealtimePeriod":0,"CpuRealtimeRuntime":0,"CpusetCpus":"","CpusetMems":"","Devices":null,"DeviceCgroupRules":null,"DeviceRequests":null,"MemoryReservation":0,"MemorySwap":0,"MemorySwappiness":null,"OomKillDisable":false,"PidsLimit":null,"Ulimits":null,"CpuCount":0,"CpuPercent":0,"IOMaximumIOps":0,"IOMaximumBandwidth":0,"MaskedPaths":["/proc/asound","/proc/acpi","/proc/kcore","/proc/keys","/proc/latency_stats","/proc/timer_list","/proc/timer_stats","/proc/sched_debug","/proc/scsi","/sys/firmware","/sys/devices/virtual/powercap"],"ReadonlyPaths":["/proc/bus","/proc/fs","/proc/irq","/proc/sys","/proc/sysrq-trigger"]},"GraphDriver":{"Data":{"LowerDir":"/var/lib/docker/overlay2/3a3ddee76b1f5e76e02b303d3dcb16c04516880e60cd744dc14a219708b696c5-init/diff:/var/lib/docker/overlay2/08e3bd065c8092fca3d3c3e1e05378a9ff51aae9104ffb341105938119bc1587/diff:/var/lib/docker/overlay2/dca8aacd78be49f31cbb0531050eef913c08ff174049f56d26b70f392df64178/diff:/var/lib/docker/overlay2/cf9116ca77de65a9f85f001cfc6f27b922024a23dbe44260460cd87b8a04f90d/diff:/var/lib/docker/overlay2/6da91204cd6443d7abb7eb7f5db2edf95b9e325c2bed22f2edb9634fbd9aed8e/diff:/var/lib/docker/overlay2/7103485d5f137bd152d11a5495eb3547aa5bf9061875017f9c9a78ee0dc3a481/diff:/var/lib/docker/overlay2/927aadce05364c8ff5affb6dbaf1ec3a4986686d7288c41c2ad6525316906f63/diff:/var/lib/docker/overlay2/86646b8beca383f6c403e952629f7673907ae46619e980387229d0073c81d994/diff:/var/lib/docker/overlay2/b31ededb53b899df74a9ee61ef05fc50d2865795cf709945615151b51e2d6c76/diff:/var/lib/docker/overlay2/e2f6d08c2a6f2c8b9178a6db133555dcf3ba59cd7f272a28be4bc085c7caf855/diff:/var/lib/docker/overlay2/4b89349860a7bf7681f9d162a18ffc4003cd654b0acb94658ba4d51cafa51a6c/diff","MergedDir":"/var/lib/docker/overlay2/3a3ddee76b1f5e76e02b303d3dcb16c04516880e60cd744dc14a219708b696c5/merged","UpperDir":"/var/lib/docker/overlay2/3a3ddee76b1f5e76e02b303d3dcb16c04516880e60cd744dc14a219708b696c5/diff","WorkDir":"/var/lib/docker/overlay2/3a3ddee76b1f5e76e02b303d3dcb16c04516880e60cd744dc14a219708b696c5/work"},"Name":"overlay2"},"Mounts":[{"Type":"volume","Name":"16538a2a1d6460a3778237fd40638c92896f243f753ab83046ecf85f1fd09fce","Source":"/var/lib/docker/volumes/16538a2a1d6460a3778237fd40638c92896f243f753ab83046ecf85f1fd09fce/_data","Destination":"/var/lib/postgresql/data","Driver":"local","Mode":"","RW":true,"Propagation":""}],"Config":{"Hostname":"040c4970b7bb","Domainname":"","User":"","AttachStdin":false,"AttachStdout":false,"AttachStderr":false,"ExposedPorts":{"5432/tcp":{}},"Tty":false,"OpenStdin":false,"StdinOnce":false,"Env":["PATH=/usr/local/sbin:/usr/local/bin:/usr/sbin:/usr/bin:/sbin:/bin","GOSU_VERSION=1.17","LANG=en_US.utf8","PG_MAJOR=17","PG_VERSION=17.4","PG_SHA256=c4605b73fea11963406699f949b966e5d173a7ee0ccaef8938dec0ca8a995fe7","DOCKER_PG_LLVM_DEPS=llvm19-dev \t\tclang19","PGDATA=/var/lib/postgresql/data"],"Cmd":["postgres"],"Image":"postgres:alpine","Volumes":{"/var/lib/postgresql/data":{}},"WorkingDir":"/","Entrypoint":["docker-entrypoint.sh"],"OnBuild":null,"Labels":{},"StopSignal":"SIGINT"},"NetworkSettings":{"Bridge":"","SandboxID":"","SandboxKey":"","Ports":{},"HairpinMode":false,"LinkLocalIPv6Address":"","LinkLocalIPv6PrefixLen":0,"SecondaryIPAddresses":null,"SecondaryIPv6Addresses":null,"EndpointID":"","Gateway":"","GlobalIPv6Address":"","GlobalIPv6PrefixLen":0,"IPAddress":"","IPPrefixLen":0,"IPv6Gateway":"","MacAddress":"","Networks":{"bridge":{"IPAMConfig":null,"Links":null,"Aliases":null,"MacAddress":"","NetworkID":"","EndpointID":"","Gateway":"","IPAddress":"","IPPrefixLen":0,"IPv6Gateway":"","GlobalIPv6Address":"","GlobalIPv6PrefixLen":0,"DriverOpts":null,"DNSNames":null}}}}"

The HeaderLine value seems to be correct, other than that it's significantly longer than your response.

Did you do anything special to break/reproduce it?

I placed some breakpoints in the stacktrace starting at StartAsync, nothing special.

@maartenjorens
Copy link
Author

maartenjorens commented Mar 18, 2025

I'll try with an older version of testcontainers as well as an older version of rancher desktop.

@maartenjorens maartenjorens reopened this Mar 18, 2025
@HofmeisterAn
Copy link
Collaborator

I placed some breakpoints in the stacktrace starting at StartAsync, nothing special.

Hmm, the output looks good so far. How does it behave when you try to break it? I'm curious if this issue only occurs in conjunction with Testcontainers. 🤔 Are you running multiple containers? Perhaps it is a race condition?

@maartenjorens
Copy link
Author

maartenjorens commented Mar 18, 2025

When placing a single breakpoint on l186 in the HttpConnection.cs of your custom branch

content.ResolveResponseStream(chunked: response.Headers.TransferEncodingChunked.HasValue && response.Headers.TransferEncodingChunked.Value);
I can reproduce the following 100% of the time:

System.Text.Json.JsonException: The input does not contain any JSON tokens. Expected the input to start with a valid JSON token, when isFinalBlock is ...

System.Text.Json.JsonException
The input does not contain any JSON tokens. Expected the input to start with a valid JSON token, when isFinalBlock is true. Path: $ | LineNumber: 0 | BytePositionInLine: 0.
   at System.Text.Json.ThrowHelper.ReThrowWithPath(ReadStack& state, JsonReaderException ex)
   at System.Text.Json.Serialization.JsonConverter`1.ReadCore(Utf8JsonReader& reader, T& value, JsonSerializerOptions options, ReadStack& state)
   at System.Text.Json.Serialization.Metadata.JsonTypeInfo`1.ContinueDeserialize(ReadBufferState& bufferState, JsonReaderState& jsonReaderState, ReadStack& readStack, T& value)
   at System.Text.Json.Serialization.Metadata.JsonTypeInfo`1.DeserializeAsync(Stream utf8Json, CancellationToken cancellationToken)
   at System.Net.Http.Json.HttpContentJsonExtensions.ReadFromJsonAsyncCore[T](HttpContent content, JsonSerializerOptions options, CancellationToken cancellationToken)
   at Docker.DotNet.DockerClient.MakeRequestAsync[T](IEnumerable`1 errorHandlers, HttpMethod method, String path, IQueryString queryString, IRequestContent body, IDictionary`2 headers, TimeSpan timeout, CancellationToken token) in C:\Users\COMJO\RiderProjects\Docker.DotNet\src\Docker.DotNet\DockerClient.cs:line 270
   at Docker.DotNet.ContainerOperations.InspectContainerAsync(String id, CancellationToken cancellationToken) in C:\Users\COMJO\RiderProjects\Docker.DotNet\src\Docker.DotNet\Endpoints\ContainerOperations.cs:line 74
   at Docker.DotNet.Tests.DebugHttpRequestResponse.Run() in C:\Users\COMJO\RiderProjects\Docker.DotNet\test\Docker.DotNet.Tests\DebugHttpRequestResponse.cs:line 25
   at Xunit.Sdk.TestInvoker`1.<>c__DisplayClass47_0.<<InvokeTestMethodAsync>b__1>d.MoveNext() in /_/src/xunit.execution/Sdk/Frameworks/Runners/TestInvoker.cs:line 259
--- End of stack trace from previous location ---
   at Xunit.Sdk.ExecutionTimer.AggregateAsync(Func`1 asyncAction) in /_/src/xunit.execution/Sdk/Frameworks/ExecutionTimer.cs:line 48
   at Xunit.Sdk.ExceptionAggregator.RunAsync(Func`1 code) in /_/src/xunit.core/Sdk/ExceptionAggregator.cs:line 90

System.Text.Json.JsonReaderException
The input does not contain any JSON tokens. Expected the input to start with a valid JSON token, when isFinalBlock is true. LineNumber: 0 | BytePositionInLine: 0.
   at System.Text.Json.ThrowHelper.ThrowJsonReaderException(Utf8JsonReader& json, ExceptionResource resource, Byte nextByte, ReadOnlySpan`1 bytes)
   at System.Text.Json.Utf8JsonReader.Read()
   at System.Text.Json.Serialization.JsonConverter`1.ReadCore(Utf8JsonReader& reader, T& value, JsonSerializerOptions options, ReadStack& state)



[Docker.DotNet 00:00:00.16] RequestUri="http://docker_engine/images/create?fromImage=postgres%3Aalpine"
[Docker.DotNet 00:00:01.07] Headers="HTTP/1.1 200 OK, Api-Version: 1.45, Content-Type: application/json, Date: Tue, 18 Mar 2025 14:34:46 GMT, Docker-Experimental: false, Ostype: linux, Server: Docker/26.1.5 (linux), Connection: close, Transfer-Encoding: chunked"
[Docker.DotNet 00:00:02.41] HeaderLine="d6"
[Docker.DotNet 00:00:02.41] HeaderLine="0"
[Docker.DotNet 00:00:02.41] Content="{"status":"Pulling from library/postgres","id":"alpine"}
{"status":"Digest: sha256:7062a2109c4b51f3c792c7ea01e83ed12ef9a980886e3b3d380a7d2e5f6ce3f5"}
{"status":"Status: Image is up to date for postgres:alpine"}"
[Docker.DotNet 00:00:02.51] RequestUri="http://docker_engine/containers/create"
[Docker.DotNet 00:00:02.54] Headers="HTTP/1.1 201 Created, Api-Version: 1.45, Content-Length: 88, Content-Type: application/json, Date: Tue, 18 Mar 2025 14:34:48 GMT, Docker-Experimental: false, Ostype: linux, Server: Docker/26.1.5 (linux), Connection: close"
[Docker.DotNet 00:00:02.67] Content="{"Id":"7fdc07d1723c93c202e79e1a6041a078ec664c1bc3d6ebc3a698c75c94f94dc4","Warnings":[]}"
[Docker.DotNet 00:00:02.68] RequestUri="http://docker_engine/containers/7fdc07d1723c93c202e79e1a6041a078ec664c1bc3d6ebc3a698c75c94f94dc4/json"
[Docker.DotNet 00:00:02.68] Headers="HTTP/1.1 200 OK, Api-Version: 1.45, Content-Type: application/json, Date: Tue, 18 Mar 2025 14:34:48 GMT, Docker-Experimental: false, Ostype: linux, Server: Docker/26.1.5 (linux), Connection: close, Transfer-Encoding: chunked"
[Docker.DotNet 00:00:02.84] HeaderLine="1451"
[Docker.DotNet 00:00:02.84] HeaderLine="0"
[Docker.DotNet 00:00:02.84] Content="{"Id":"7fdc07d1723c93c202e79e1a6041a078ec664c1bc3d6ebc3a698c75c94f94dc4","Created":"2025-03-18T14:34:48.279661515Z","Path":"docker-entrypoint.sh","Args":["postgres"],"State":{"Status":"created","Running":false,"Paused":false,"Restarting":false,"OOMKilled":false,"Dead":false,"Pid":0,"ExitCode":0,"Error":"","StartedAt":"0001-01-01T00:00:00Z","FinishedAt":"0001-01-01T00:00:00Z"},"Image":"sha256:0150e3200277b907866758e22a3b9bba7857325b994848fe9f44b3610c3ae17e","ResolvConfPath":"","HostnamePath":"","HostsPath":"","LogPath":"","Name":"/zen_pike","RestartCount":0,"Driver":"overlay2","Platform":"linux","MountLabel":"","ProcessLabel":"","AppArmorProfile":"","ExecIDs":null,"HostConfig":{"Binds":null,"ContainerIDFile":"","LogConfig":{"Type":"json-file","Config":{}},"NetworkMode":"bridge","PortBindings":null,"RestartPolicy":{"Name":"no","MaximumRetryCount":0},"AutoRemove":false,"VolumeDriver":"","VolumesFrom":null,"ConsoleSize":[0,0],"CapAdd":null,"CapDrop":null,"CgroupnsMode":"host","Dns":null,"DnsOptions":null,"DnsSearch":null,"ExtraHosts":null,"GroupAdd":null,"IpcMode":"private","Cgroup":"","Links":null,"OomScoreAdj":0,"PidMode":"","Privileged":false,"PublishAllPorts":false,"ReadonlyRootfs":false,"SecurityOpt":null,"UTSMode":"","UsernsMode":"","ShmSize":67108864,"Runtime":"runc","Isolation":"","CpuShares":0,"Memory":0,"NanoCpus":0,"CgroupParent":"","BlkioWeight":0,"BlkioWeightDevice":null,"BlkioDeviceReadBps":null,"BlkioDeviceWriteBps":null,"BlkioDeviceReadIOps":null,"BlkioDeviceWriteIOps":null,"CpuPeriod":0,"CpuQuota":0,"CpuRealtimePeriod":0,"CpuRealtimeRuntime":0,"CpusetCpus":"","CpusetMems":"","Devices":null,"DeviceCgroupRules":null,"DeviceRequests":null,"MemoryReservation":0,"MemorySwap":0,"MemorySwappiness":null,"OomKillDisable":false,"PidsLimit":null,"Ulimits":null,"CpuCount":0,"CpuPercent":0,"IOMaximumIOps":0,"IOMaximumBandwidth":0,"MaskedPaths":["/proc/asound","/proc/acpi","/proc/kcore","/proc/keys","/proc/latency_stats","/proc/timer_list","/proc/timer_stats","/proc/sched_debug","/proc/scsi","/sys/firmware","/sys/devices/virtual/powercap"],"ReadonlyPaths":["/proc/bus","/proc/fs","/proc/irq","/proc/sys","/proc/sysrq-trigger"]},"GraphDriver":{"Data":{"LowerDir":"/var/lib/docker/overlay2/e10c9555dc617f5d0058d41451a2a4bcb517df0287d2ba211b665a4b4b650a53-init/diff:/var/lib/docker/overlay2/08e3bd065c8092fca3d3c3e1e05378a9ff51aae9104ffb341105938119bc1587/diff:/var/lib/docker/overlay2/dca8aacd78be49f31cbb0531050eef913c08ff174049f56d26b70f392df64178/diff:/var/lib/docker/overlay2/cf9116ca77de65a9f85f001cfc6f27b922024a23dbe44260460cd87b8a04f90d/diff:/var/lib/docker/overlay2/6da91204cd6443d7abb7eb7f5db2edf95b9e325c2bed22f2edb9634fbd9aed8e/diff:/var/lib/docker/overlay2/7103485d5f137bd152d11a5495eb3547aa5bf9061875017f9c9a78ee0dc3a481/diff:/var/lib/docker/overlay2/927aadce05364c8ff5affb6dbaf1ec3a4986686d7288c41c2ad6525316906f63/diff:/var/lib/docker/overlay2/86646b8beca383f6c403e952629f7673907ae46619e980387229d0073c81d994/diff:/var/lib/docker/overlay2/b31ededb53b899df74a9ee61ef05fc50d2865795cf709945615151b51e2d6c76/diff:/var/lib/docker/overlay2/e2f6d08c2a6f2c8b9178a6db133555dcf3ba59cd7f272a28be4bc085c7caf855/diff:/var/lib/docker/overlay2/4b89349860a7bf7681f9d162a18ffc4003cd654b0acb94658ba4d51cafa51a6c/diff","MergedDir":"/var/lib/docker/overlay2/e10c9555dc617f5d0058d41451a2a4bcb517df0287d2ba211b665a4b4b650a53/merged","UpperDir":"/var/lib/docker/overlay2/e10c9555dc617f5d0058d41451a2a4bcb517df0287d2ba211b665a4b4b650a53/diff","WorkDir":"/var/lib/docker/overlay2/e10c9555dc617f5d0058d41451a2a4bcb517df0287d2ba211b665a4b4b650a53/work"},"Name":"overlay2"},"Mounts":[{"Type":"volume","Name":"8c751b0837674ff57c99961761827e467a9987b96ff35a4cde5b1eff9d1cdcdd","Source":"/var/lib/docker/volumes/8c751b0837674ff57c99961761827e467a9987b96ff35a4cde5b1eff9d1cdcdd/_data","Destination":"/var/lib/postgresql/data","Driver":"local","Mode":"","RW":true,"Propagation":""}],"Config":{"Hostname":"7fdc07d1723c","Domainname":"","User":"","AttachStdin":false,"AttachStdout":false,"AttachStderr":false,"ExposedPorts":{"5432/tcp":{}},"Tty":false,"OpenStdin":false,"StdinOnce":false,"Env":["PATH=/usr/local/sbin:/usr/local/bin:/usr/sbin:/usr/bin:/sbin:/bin","GOSU_VERSION=1.17","LANG=en_US.utf8","PG_MAJOR=17","PG_VERSION=17.4","PG_SHA256=c4605b73fea11963406699f949b966e5d173a7ee0ccaef8938dec0ca8a995fe7","DOCKER_PG_LLVM_DEPS=llvm19-dev \t\tclang19","PGDATA=/var/lib/postgresql/data"],"Cmd":["postgres"],"Image":"postgres:alpine","Volumes":{"/var/lib/postgresql/data":{}},"WorkingDir":"/","Entrypoint":["docker-entrypoint.sh"],"OnBuild":null,"Labels":{},"StopSignal":"SIGINT"},"NetworkSettings":{"Bridge":"","SandboxID":"","SandboxKey":"","Ports":{},"HairpinMode":false,"LinkLocalIPv6Address":"","LinkLocalIPv6PrefixLen":0,"SecondaryIPAddresses":null,"SecondaryIPv6Addresses":null,"EndpointID":"","Gateway":"","GlobalIPv6Address":"","GlobalIPv6PrefixLen":0,"IPAddress":"","IPPrefixLen":0,"IPv6Gateway":"","MacAddress":"","Networks":{"bridge":{"IPAMConfig":null,"Links":null,"Aliases":null,"MacAddress":"","NetworkID":"","EndpointID":"","Gateway":"","IPAddress":"","IPPrefixLen":0,"IPv6Gateway":"","GlobalIPv6Address":"","GlobalIPv6PrefixLen":0,"DriverOpts":null,"DNSNames":null}}}}"
[Docker.DotNet 00:00:02.88] RequestUri="http://docker_engine/containers/7fdc07d1723c93c202e79e1a6041a078ec664c1bc3d6ebc3a698c75c94f94dc4/json"
[Docker.DotNet 00:00:02.88] Headers="HTTP/1.1 200 OK, Api-Version: 1.45, Content-Type: application/json, Date: Tue, 18 Mar 2025 14:34:48 GMT, Docker-Experimental: false, Ostype: linux, Server: Docker/26.1.5 (linux), Connection: close, Transfer-Encoding: chunked"
[Docker.DotNet 00:00:03.02] HeaderLine="1451"
[Docker.DotNet 00:00:03.02] HeaderLine="Once":false,"Env":["PATH=/usr/local/sbin:/usr/local/bin:/usr/sbin:/usr/bin:/sbin:/bin","GOSU_VERSION=1.17","LANG=en_US.utf8","PG_MAJOR=17","PG_VERSION=17.4","PG_SHA256=c4605b73fea11963406699f949b966e5d173a7ee0ccaef8938dec0ca8a995fe7","DOCKER_PG_LLVM_DEPS=llvm19-dev \t\tclang19","PGDATA=/var/lib/postgresql/data"],"Cmd":["postgres"],"Image":"postgres:alpine","Volumes":{"/var/lib/postgresql/data":{}},"WorkingDir":"/","Entrypoint":["docker-entrypoint.sh"],"OnBuild":null,"Labels":{},"StopSignal":"SIGINT"},"NetworkSettings":{"Bridge":"","SandboxID":"","SandboxKey":"","Ports":{},"HairpinMode":false,"LinkLocalIPv6Address":"","LinkLocalIPv6PrefixLen":0,"SecondaryIPAddresses":null,"SecondaryIPv6Addresses":null,"EndpointID":"","Gateway":"","GlobalIPv6Address":"","GlobalIPv6PrefixLen":0,"IPAddress":"","IPPrefixLen":0,"IPv6Gateway":"","MacAddress":"","Networks":{"bridge":{"IPAMConfig":null,"Links":null,"Aliases":null,"MacAddress":"","NetworkID":"","EndpointID":"","Gateway":"","IPAddress":"","IPPrefixLen":0,"IPv6Gateway":"","GlobalIPv6Address":"","GlobalIPv6PrefixLen":0,"DriverOpts":null,"DNSNames":null}}}}
"
[Docker.DotNet 00:00:03.08] Content=""
[Docker.DotNet 00:00:03.08] HeaderLine="0"

The following then always hits:

Image

@HofmeisterAn
Copy link
Collaborator

HofmeisterAn commented Mar 18, 2025

Not sure if this is a good sign, but maybe we've made a step forward 😅. Unfortunately, I still cannot reproduce the issue using Docker Desktop or Podman Desktop.

What's interesting is that the first time it reads the numeric hex value 1451, but fails the second time:

[Docker.DotNet 00:00:03.02] HeaderLine="1451"
[Docker.DotNet 00:00:03.02] HeaderLine="Once[...]"

This is how the successful request looks:

[Docker.DotNet 00:00:02.84] HeaderLine="1451"
[Docker.DotNet 00:00:02.84] HeaderLine="0"

It seems like we read too much and start extracting the body too early, or more specifically, we begin reading the body when we should actually receive 0 for _chunkBytesRemaining.

It probably makes sense to debug into these lines and check what's going wrong. I suspect we're missing a case here. Or ReadLineAsync(CancellationToken) reads or does nonsense.

If you add var content = Encoding.ASCII.GetString(buffer, offset, read); right before the return, it should read the chunks for the body and contain the complete body once all chunks are read.

@maartenjorens
Copy link
Author

maartenjorens commented Mar 18, 2025

Can the issue be the following if (read == 0) check?

When _chunkBytesRemaining is 0, can we safely set _done on true instead of waiting on the next iteration from Stream.cs CopyToAsync?
In the last iteration after _chunkBytesRemaining is set to 0 after succesfull reads, the headerline property is filled with what seems like recurring text instead of "0" - the content was succesfully read.

It still doesn't make sense to me why this only happens during debugging.

@maartenjorens
Copy link
Author

If I read line by line after reading the first "_chunkBytesRemaining" I get the following.
I have no clue why the second ReadLineAsync results in a partial json body matching with the previous line.

_inner.ReadLineAsync(CancellationToken.None).Result
  "{\"Id\":\"5fb38dbef39da6c2251f4b5fa57d236a24c3256af3710aed142c0b18267013ca\",\"Created\":\"2025-03-18T17:06:55.434012692Z\",\"Path\":\"docker-entrypoint.sh\",\"Args\":[\"postgres\"],\"State\":{\"Status\":\"created\",\"Running\":false,\"Paused\":false,\"Restarting\":false,\"OOMKilled\":false,\"Dead\":false,\"Pid\":0,\"ExitCode\":0,\"Error\":\"\",\"StartedAt\":\"0001-01-01T00:00:00Z\",\"FinishedAt\":\"0001-01-01T00:00:00Z\"},\"Image\":\"sha256:0150e3200277b907866758e22a3b9bba7857325b994848fe9f44b3610c3ae17e\",\"ResolvConfPath\":\"\",\"HostnamePath\":\"\",\"HostsPath\":\"\",\"LogPath\":\"\",\"Name\":\"/determined_hoover\",\"RestartCount\":0,\"Driver\":\"overlay2\",\"Platform\":\"linux\",\"MountLabel\":\"\",\"ProcessLabel\":\"\",\"AppArmorProfile\":\"\",\"ExecIDs\":null,\"HostConfig\":{\"Binds\":null,\"ContainerIDFile\":\"\",\"LogConfig\":{\"Type\":\"json-file\",\"Config\":{}},\"NetworkMode\":\"bridge\",\"PortBindings\":null,\"RestartPolicy\":{\"Name\":\"no\",\"MaximumRetryCount\":0},\"AutoRemove\":false,\"VolumeDriver\":\"\",\"VolumesFrom\":null,\"ConsoleSize\":[0,0],\"CapAdd\":null,\"CapDrop\":null,\"CgroupnsMode\":\"host\",\"Dns\":null,\"DnsOptions\":null,\"DnsSearch\":null,\"ExtraHosts\":null,\"GroupAdd\":null,\"IpcMode\":\"private\",\"Cgroup\":\"\",\"Links\":null,\"OomScoreAdj\":0,\"PidMode\":\"\",\"Privileged\":false,\"PublishAllPorts\":false,\"ReadonlyRootfs\":false,\"SecurityOpt\":null,\"UTSMode\":\"\",\"UsernsMode\":\"\",\"ShmSize\":67108864,\"Runtime\":\"runc\",\"Isolation\":\"\",\"CpuShares\":0,\"Memory\":0,\"NanoCpus\":0,\"CgroupParent\":\"\",\"BlkioWeight\":0,\"BlkioWeightDevice\":null,\"BlkioDeviceReadBps\":null,\"BlkioDeviceWriteBps\":null,\"BlkioDeviceReadIOps\":null,\"BlkioDeviceWriteIOps\":null,\"CpuPeriod\":0,\"CpuQuota\":0,\"CpuRealtimePeriod\":0,\"CpuRealtimeRuntime\":0,\"CpusetCpus\":\"\",\"CpusetMems\":\"\",\"Devices\":null,\"DeviceCgroupRules\":null,\"DeviceRequests\":null,\"MemoryReservation\":0,\"MemorySwap\":0,\"MemorySwappiness\":null,\"OomKillDisable\":false,\"PidsLimit\":null,\"Ulimits\":null,\"CpuCount\":0,\"CpuPercent\":0,\"IOMaximumIOps\":0,\"IOMaximumBandwidth\":0,\"MaskedPaths\":[\"/proc/asound\",\"/proc/acpi\",\"/proc/kcore\",\"/proc/keys\",\"/proc/latency_stats\",\"/proc/timer_list\",\"/proc/timer_stats\",\"/proc/sched_debug\",\"/proc/scsi\",\"/sys/firmware\",\"/sys/devices/virtual/powercap\"],\"ReadonlyPaths\":[\"/proc/bus\",\"/proc/fs\",\"/proc/irq\",\"/proc/sys\",\"/proc/sysrq-trigger\"]},\"GraphDriver\":{\"Data\":{\"LowerDir\":\"/var/lib/docker/overlay2/39fb903daf4bc476a8a179693887aa2d0e40b509ff5066c6389a4b35ede8b47b-init/diff:/var/lib/docker/overlay2/08e3bd065c8092fca3d3c3e1e05378a9ff51aae9104ffb341105938119bc1587/diff:/var/lib/docker/overlay2/dca8aacd78be49f31cbb0531050eef913c08ff174049f56d26b70f392df64178/diff:/var/lib/docker/overlay2/cf9116ca77de65a9f85f001cfc6f27b922024a23dbe44260460cd87b8a04f90d/diff:/var/lib/docker/overlay2/6da91204cd6443d7abb7eb7f5db2edf95b9e325c2bed22f2edb9634fbd9aed8e/diff:/var/lib/docker/overlay2/7103485d5f137bd152d11a5495eb3547aa5bf9061875017f9c9a78ee0dc3a481/diff:/var/lib/docker/overlay2/927aadce05364c8ff5affb6dbaf1ec3a4986686d7288c41c2ad6525316906f63/diff:/var/lib/docker/overlay2/86646b8beca383f6c403e952629f7673907ae46619e980387229d0073c81d994/diff:/var/lib/docker/overlay2/b31ededb53b899df74a9ee61ef05fc50d2865795cf709945615151b51e2d6c76/diff:/var/lib/docker/overlay2/e2f6d08c2a6f2c8b9178a6db133555dcf3ba59cd7f272a28be4bc085c7caf855/diff:/var/lib/docker/overlay2/4b89349860a7bf7681f9d162a18ffc4003cd654b0acb94658ba4d51cafa51a6c/diff\",\"MergedDir\":\"/var/lib/docker/overlay2/39fb903daf4bc476a8a179693887aa2d0e40b509ff5066c6389a4b35ede8b47b/merged\",\"UpperDir\":\"/var/lib/docker/overlay2/39fb903daf4bc476a8a179693887aa2d0e40b509ff5066c6389a4b35ede8b47b/diff\",\"WorkDir\":\"/var/lib/docker/overlay2/39fb903daf4bc476a8a179693887aa2d0e40b509ff5066c6389a4b35ede8b47b/work\"},\"Name\":\"overlay2\"},\"Mounts\":[{\"Type\":\"volume\",\"Name\":\"b1127a620bd9d6b54979c0ed38474486c75da628110b94ff94bd05332824ee02\",\"Source\":\"/var/lib/docker/volumes/b1127a620bd9d6b54979c0ed38474486c75da628110b94ff94bd05332824ee02/_data\",\"Destination\":\"/var/lib/postgresql/data\",\"Driver\":\"local\",\"Mode\":\"\",\"RW\":true,\"Propagation\":\"\"}],\"Config\":{\"Hostname\":\"5fb38dbef39d\",\"Domainname\":\"\",\"User\":\"\",\"AttachStdin\":false,\"AttachStdout\":false,\"AttachStderr\":false,\"ExposedPorts\":{\"5432/tcp\":{}},\"Tty\":false,\"OpenStdin\":false,\"StdinOnce\":false,\"Env\":[\"PATH=/usr/local/sbin:/usr/local/bin:/usr/sbin:/usr/bin:/sbin:/bin\",\"GOSU_VERSION=1.17\",\"LANG=en_US.utf8\",\"PG_MAJOR=17\",\"PG_VERSION=17.4\",\"PG_SHA256=c4605b73fea11963406699f949b966e5d173a7ee0ccaef8938dec0ca8a995fe7\",\"DOCKER_PG_LLVM_DEPS=llvm19-dev \\t\\tclang19\",\"PGDATA=/var/lib/postgresql/data\"],\"Cmd\":[\"postgres\"],\"Image\":\"postgres:alpine\",\"Volumes\":{\"/var/lib/postgresql/data\":{}},\"WorkingDir\":\"/\",\"Entrypoint\":[\"docker-entrypoint.sh\"],\"OnBuild\":null,\"Labels\":{},\"StopSignal\":\"SIGINT\"},\"NetworkSettings\":{\"Bridge\":\"\",\"SandboxID\":\"\",\"SandboxKey\":\"\",\"Ports\":{},\"HairpinMode\":false,\"LinkLocalIPv6Address\":\"\",\"LinkLocalIPv6PrefixLen\":0,\"SecondaryIPAddresses\":null,\"SecondaryIPv6Addresses\":null,\"EndpointID\":\"\",\"Gateway\":\"\",\"GlobalIPv6Address\":\"\",\"GlobalIPv6PrefixLen\":0,\"IPAddress\":\"\",\"IPPrefixLen\":0,\"IPv6Gateway\":\"\",\"MacAddress\":\"\",\"Networks\":{\"bridge\":{\"IPAMConfig\":null,\"Links\":null,\"Aliases\":null,\"MacAddress\":\"\",\"NetworkID\":\"\",\"EndpointID\":\"\",\"Gateway\":\"\",\"IPAddress\":\"\",\"IPPrefixLen\":0,\"IPv6Gateway\":\"\",\"GlobalIPv6Address\":\"\",\"GlobalIPv6PrefixLen\":0,\"DriverOpts\":null,\"DNSNames\":null}}}}\n"

_inner.ReadLineAsync(CancellationToken.None).Result
  "se,\"StdinOnce\":false,\"Env\":[\"PATH=/usr/local/sbin:/usr/local/bin:/usr/sbin:/usr/bin:/sbin:/bin\",\"GOSU_VERSION=1.17\",\"LANG=en_US.utf8\",\"PG_MAJOR=17\",\"PG_VERSION=17.4\",\"PG_SHA256=c4605b73fea11963406699f949b966e5d173a7ee0ccaef8938dec0ca8a995fe7\",\"DOCKER_PG_LLVM_DEPS=llvm19-dev \\t\\tclang19\",\"PGDATA=/var/lib/postgresql/data\"],\"Cmd\":[\"postgres\"],\"Image\":\"postgres:alpine\",\"Volumes\":{\"/var/lib/postgresql/data\":{}},\"WorkingDir\":\"/\",\"Entrypoint\":[\"docker-entrypoint.sh\"],\"OnBuild\":null,\"Labels\":{},\"StopSignal\":\"SIGINT\"},\"NetworkSettings\":{\"Bridge\":\"\",\"SandboxID\":\"\",\"SandboxKey\":\"\",\"Ports\":{},\"HairpinMode\":false,\"LinkLocalIPv6Address\":\"\",\"LinkLocalIPv6PrefixLen\":0,\"SecondaryIPAddresses\":null,\"SecondaryIPv6Addresses\":null,\"EndpointID\":\"\",\"Gateway\":\"\",\"GlobalIPv6Address\":\"\",\"GlobalIPv6PrefixLen\":0,\"IPAddress\":\"\",\"IPPrefixLen\":0,\"IPv6Gateway\":\"\",\"MacAddress\":\"\",\"Networks\":{\"bridge\":{\"IPAMConfig\":null,\"Links\":null,\"Aliases\":null,\"MacAddress\":\"\",\"NetworkID\":\"\",\"EndpointID\":\"\",\"Gateway\":\"\",\"IPAddress\":\"\",\"IPPrefixLen\":0,\"IPv6Gateway\":\"\",\"GlobalIPv6Address\":\"\",\"GlobalIPv6PrefixLen\":0,\"DriverOpts\":null,\"DNSNames\":null}}}}\n"

_inner.ReadLineAsync(CancellationToken.None).Result
  "0"

_inner.ReadLineAsync(CancellationToken.None).Result
  ""

_inner.ReadLineAsync(CancellationToken.None).Result
  Exception of type 'System.AggregateException' was thrown

@HofmeisterAn
Copy link
Collaborator

HofmeisterAn commented Mar 19, 2025

I believe this is heading in the right direction, but I still don't understand why it fails in your environment. Unfortunately, there is no previous maintainer available that we can ask AFAIK, but I've fixed a couple of similar issues in the past, and I think I'm seeing some familiar behavior here.

As you mentioned, it seems like we're calling or processing the ReadAsync(byte[], int, int, CancellationToken) method one time too many. It appears that for every complete processing (_chunkBytesRemaining == 0), the method is being called once more (see the duplicate output).

InstanceCount=1
{"status":"Pulling from library/postgres","id":"alpine"}

InstanceCount=2
{"status":"Digest: sha256:7062a2109c4b51f3c792c7ea01e83ed12ef9a980886e3b3d380a7d2e5f6ce3f5"}
{"status":"Status: Image is up to date for postgres:alpine"}

InstanceCount=3
{"status":"Digest: sha256:7062a2109c4b51f3c792c7ea01e83ed12ef9a980886e3b3d380a7d2e5f6ce3f5"}
{"status":"Status: Image is up to date for postgres:alpine"}

InstanceCount=4
{"Id":"fba67eede3cacd9383049b12daf22de8aa5b45f11099c58f5ac845b95c43147f","Warnings":[]}
f5"}
{"status":"Status: Image is up to date for postgres:alpine"}

InstanceCount=5
{"Id":"fba67eede3cacd9383049b12daf22de8aa5b45f11099c58f5ac845b95c43147f","Warnings":[]}
f5"}
{"status":"Status: Image is up to date for postgres:alpine"}

InstanceCount=6
{"Id":"fba67eede3cacd9383049b12daf22de8aa5b45f11099c58f5ac845b95c43147f","Created":"2025-03-19T07:56:32.493819596Z","Path":"docker-entrypoint.sh","Args":["postgres"],"State":{"Status":"running","Running":true,"Paused":false,"Restarting":false,"OOMKilled":false,"Dead":false,"Pid":1560,"ExitCode":0,"Error":"","StartedAt":"2025-03-19T07:56:32.574025732Z","FinishedAt":"0001-01-01T00:00:00Z"},"Image":"sha256:7062a2109c4b51f3c792c7ea01e83ed12ef9a980886e3b3d380a7d2e5f6ce3f5","ResolvConfPath":"/var/lib/docker/containers/fba67eede3cacd9383049b12daf22de8aa5b45f11099c58f5ac845b95c43147f/resolv.conf","HostnamePath":"/var/lib/docker/containers/fba67eede3cacd9383049b12daf22de8aa5b45f11099c58f5ac845b95c43147f/hostname","HostsPath":"/var/lib/docker/containers/fba67eede3cacd9383049b12daf22de8aa5b45f11099c58f5ac845b95c43147f/hosts","LogPath":"/var/lib/docker/containers/fba67eede3cacd9383049b12daf22de8aa5b45f11099c58f5ac845b95c43147f/fba67eede3cacd9383049b12daf22de8aa5b45f11099c58f5ac845b95c43147f-json.log","Name":"/musin
InstanceCount=7
g_bhaskara","RestartCount":0,"Driver":"overlayfs","Platform":"linux","MountLabel":"","ProcessLabel":"","AppArmorProfile":"","ExecIDs":null,"HostConfig":{"Binds":null,"ContainerIDFile":"","LogConfig":{"Type":"json-file","Config":{}},"NetworkMode":"bridge","PortBindings":{},"RestartPolicy":{"Name":"no","MaximumRetryCount":0},"AutoRemove":false,"VolumeDriver":"","VolumesFrom":null,"ConsoleSize":[0,0],"CapAdd":null,"CapDrop":null,"CgroupnsMode":"host","Dns":null,"DnsOptions":null,"DnsSearch":null,"ExtraHosts":null,"GroupAdd":null,"IpcMode":"private","Cgroup":"","Links":null,"OomScoreAdj":0,"PidMode":"","Privileged":false,"PublishAllPorts":false,"ReadonlyRootfs":false,"SecurityOpt":null,"UTSMode":"","UsernsMode":"","ShmSize":67108864,"Runtime":"runc","Isolation":"","CpuShares":0,"Memory":0,"NanoCpus":0,"CgroupParent":"","BlkioWeight":0,"BlkioWeightDevice":null,"BlkioDeviceReadBps":null,"BlkioDeviceWriteBps":null,"BlkioDeviceReadIOps":null,"BlkioDeviceWriteIOps":null,"CpuPeriod":0,"CpuQuota":0,"CpuRealtimePeriod":0,"CpuRealtimeRuntime":0,"CpusetCpus":"","CpusetMems":"","Devices":null,"DeviceCgroupRules":null,"DeviceRequests":null,"MemoryReservation":0,"MemorySwap":0,"MemorySwappiness":null,"OomKillDisable":false,"PidsLimit":null,"Ulimits":null,"CpuCount":0,"CpuPercent":0,"IOMaximumIOps":0,"IOMaximumBandwidth":0,"MaskedPaths":["/proc/asound","/proc/acpi","/proc/kcore","/proc/keys","/proc/latency_stats","/proc/timer_list","/proc/timer_stats","/proc/sched_debug","/proc/scsi","/sys/firmware","/sys/devices/virtual/powercap"],"ReadonlyPaths":["/proc/bus","/proc/fs","/proc/irq","/proc/sys","/proc/sysrq-trigger"]},"GraphDriver":{"Data":null,"Name":"overlayfs"},"Mounts":[{"Type":"volume","Name":"0d4b3ef8430c8a37a47574415688de9f62474b12614fc6f456846f42ee96c622","Source":"/var/lib/docker/volumes/0d4b3ef8430c8a37a47574415688de9f62474b12614fc6f456846f42ee96c622/_data","Destination":"/var/lib/postgresql/data","Driver":"local","Mode":"","RW":true,"Propagation":""}],"Config":{"Hostname":"fba67eede3ca","Domainname":"","User":"","AttachStdin":false,"AttachStdout":false,"AttachStderr":false,"ExposedPorts":{"5432/tcp":{}},"Tty":false,"OpenStdin":false,"StdinOnce":false,"Env":["POSTGRES_PASSWORD=password","PATH=/usr/local/sbin:/usr/local/bin:/usr/sbin:/usr/bin:/sbin:/bin","GOSU_VERSION=1.17","LANG=en_US.utf8","PG_MAJOR=17","PG_VERSION=17.4","PG_SHA256=c4605b73fea11963406699f949b966e5d173a7ee0ccaef8938dec0ca8a995fe7","DOCKER_PG_LLVM_DEPS=llvm19-dev \t\tclang19","PGDATA=/var/lib/postgresql/data"],"Cmd":["postgres"],"Image":"postgres:alpine","Volumes":{"/var/lib/postgresql/data":{}},"WorkingDir":"/","Entrypoint":["docker-entrypoint.sh"],"OnBuild":null,"Labels":{},"StopSignal":"SIGINT"},"NetworkSettings":{"Bridge":"","SandboxID":"f67503d0505c06e18c636e60772c38287e6ab8d795c61b2dd79459dc00659c32","SandboxKey":"/var/run/docker/netns/f67503d0505c","Ports":{"5432/tcp":null},"HairpinMode":false,"LinkLocalIPv6Address":"","LinkLocalIPv6PrefixLen":0,"SecondaryIPAddresses":null,"SecondaryIPv6Addresses":null,"EndpointID":"3a400848514ac1e99cd21047b7fdbcaf83bb72027388f6dd3c999a146f497999","Gateway":"172.17.0.1","GlobalIPv6Address":"","GlobalIPv6PrefixLen":0,"IPAddress":"172.17.0.8","IPPrefixLen":16,"IPv6Gateway":"","MacAddress":"02:42:ac:11:00:08","Networks":{"bridge":{"IPAMConfig":null,"Links":null,"Aliases":null,"MacAddress":"02:42:ac:11:00:08","DriverOpts":null,"NetworkID":"ab4fca983793173a23c56eccdd4d280b5a0ae86e4b72f212a74edfc637ec990b","EndpointID":"3a400848514ac1e99cd21047b7fdbcaf83bb72027388f6dd3c999a146f497999","Gateway":"172.17.0.1","IPAddress":"172.17.0.8","IPPrefixLen":16,"IPv6Gateway":"","GlobalIPv6Address":"","GlobalIPv6PrefixLen":0,"DNSNames":null}}}}

InstanceCount=8
g_bhaskara","RestartCount":0,"Driver":"overlayfs","Platform":"linux","MountLabel":"","ProcessLabel":"","AppArmorProfile":"","ExecIDs":null,"HostConfig":{"Binds":null,"ContainerIDFile":"","LogConfig":{"Type":"json-file","Config":{}},"NetworkMode":"bridge","PortBindings":{},"RestartPolicy":{"Name":"no","MaximumRetryCount":0},"AutoRemove":false,"VolumeDriver":"","VolumesFrom":null,"ConsoleSize":[0,0],"CapAdd":null,"CapDrop":null,"CgroupnsMode":"host","Dns":null,"DnsOptions":null,"DnsSearch":null,"ExtraHosts":null,"GroupAdd":null,"IpcMode":"private","Cgroup":"","Links":null,"OomScoreAdj":0,"PidMode":"","Privileged":false,"PublishAllPorts":false,"ReadonlyRootfs":false,"SecurityOpt":null,"UTSMode":"","UsernsMode":"","ShmSize":67108864,"Runtime":"runc","Isolation":"","CpuShares":0,"Memory":0,"NanoCpus":0,"CgroupParent":"","BlkioWeight":0,"BlkioWeightDevice":null,"BlkioDeviceReadBps":null,"BlkioDeviceWriteBps":null,"BlkioDeviceReadIOps":null,"BlkioDeviceWriteIOps":null,"CpuPeriod":0,"CpuQuota":0,"CpuRealtimePeriod":0,"CpuRealtimeRuntime":0,"CpusetCpus":"","CpusetMems":"","Devices":null,"DeviceCgroupRules":null,"DeviceRequests":null,"MemoryReservation":0,"MemorySwap":0,"MemorySwappiness":null,"OomKillDisable":false,"PidsLimit":null,"Ulimits":null,"CpuCount":0,"CpuPercent":0,"IOMaximumIOps":0,"IOMaximumBandwidth":0,"MaskedPaths":["/proc/asound","/proc/acpi","/proc/kcore","/proc/keys","/proc/latency_stats","/proc/timer_list","/proc/timer_stats","/proc/sched_debug","/proc/scsi","/sys/firmware","/sys/devices/virtual/powercap"],"ReadonlyPaths":["/proc/bus","/proc/fs","/proc/irq","/proc/sys","/proc/sysrq-trigger"]},"GraphDriver":{"Data":null,"Name":"overlayfs"},"Mounts":[{"Type":"volume","Name":"0d4b3ef8430c8a37a47574415688de9f62474b12614fc6f456846f42ee96c622","Source":"/var/lib/docker/volumes/0d4b3ef8430c8a37a47574415688de9f62474b12614fc6f456846f42ee96c622/_data","Destination":"/var/lib/postgresql/data","Driver":"local","Mode":"","RW":true,"Propagation":""}],"Config":{"Hostname":"fba67eede3ca","Domainname":"","User":"","AttachStdin":false,"AttachStdout":false,"AttachStderr":false,"ExposedPorts":{"5432/tcp":{}},"Tty":false,"OpenStdin":false,"StdinOnce":false,"Env":["POSTGRES_PASSWORD=password","PATH=/usr/local/sbin:/usr/local/bin:/usr/sbin:/usr/bin:/sbin:/bin","GOSU_VERSION=1.17","LANG=en_US.utf8","PG_MAJOR=17","PG_VERSION=17.4","PG_SHA256=c4605b73fea11963406699f949b966e5d173a7ee0ccaef8938dec0ca8a995fe7","DOCKER_PG_LLVM_DEPS=llvm19-dev \t\tclang19","PGDATA=/var/lib/postgresql/data"],"Cmd":["postgres"],"Image":"postgres:alpine","Volumes":{"/var/lib/postgresql/data":{}},"WorkingDir":"/","Entrypoint":["docker-entrypoint.sh"],"OnBuild":null,"Labels":{},"StopSignal":"SIGINT"},"NetworkSettings":{"Bridge":"","SandboxID":"f67503d0505c06e18c636e60772c38287e6ab8d795c61b2dd79459dc00659c32","SandboxKey":"/var/run/docker/netns/f67503d0505c","Ports":{"5432/tcp":null},"HairpinMode":false,"LinkLocalIPv6Address":"","LinkLocalIPv6PrefixLen":0,"SecondaryIPAddresses":null,"SecondaryIPv6Addresses":null,"EndpointID":"3a400848514ac1e99cd21047b7fdbcaf83bb72027388f6dd3c999a146f497999","Gateway":"172.17.0.1","GlobalIPv6Address":"","GlobalIPv6PrefixLen":0,"IPAddress":"172.17.0.8","IPPrefixLen":16,"IPv6Gateway":"","MacAddress":"02:42:ac:11:00:08","Networks":{"bridge":{"IPAMConfig":null,"Links":null,"Aliases":null,"MacAddress":"02:42:ac:11:00:08","DriverOpts":null,"NetworkID":"ab4fca983793173a23c56eccdd4d280b5a0ae86e4b72f212a74edfc637ec990b","EndpointID":"3a400848514ac1e99cd21047b7fdbcaf83bb72027388f6dd3c999a146f497999","Gateway":"172.17.0.1","IPAddress":"172.17.0.8","IPPrefixLen":16,"IPv6Gateway":"","GlobalIPv6Address":"","GlobalIPv6PrefixLen":0,"DNSNames":null}}}}

Could you please try setting _done to true when _chunkBytesRemaining equals 0 (However, this seems to break streaming, but it is something we can address if we know it resolves the issue with getting the inspect response)?

if (_chunkBytesRemaining == 0)
{
    // End of chunk, read the terminator CRLF
    var trailer = await _inner.ReadLineAsync(cancellationToken).ConfigureAwait(false);
    if (trailer.Length > 0)
    {
        throw new IOException("Invalid chunk trailer");
    }

    _done = true;
}

@HofmeisterAn
Copy link
Collaborator

HofmeisterAn commented Mar 23, 2025

I refactored some parts related to reading from chunked streams and added additional trace messages to identify the issue. I may have already fixed it by refactoring the code. It would be great if you could try to reproduce the issue again using the following test (branch: feature/add-logger-interface):

[Fact]
public async Task Run()
{
const string image = "postgres:alpine";
// TODO: Set the Docker host address according to your environment.
using var dockerClientConfiguration = new DockerClientConfiguration(new Uri("npipe://./pipe/docker_engine"));
using var dockerClient = dockerClientConfiguration.CreateClient(logger: this);
// await dockerClient.Images.CreateImageAsync(new ImagesCreateParameters { FromImage = image }, new AuthConfig(), new Progress<JSONMessage>());
var createContainerResponse = await dockerClient.Containers.CreateContainerAsync(new CreateContainerParameters { Image = image });
var inspectContainerResponse = await dockerClient.Containers.InspectContainerAsync(createContainerResponse.ID);
_ = inspectContainerResponse;
}

I will finalize it and try to integrate it into Testcontainers for .NET to enable tracing of the raw communication.

@maartenjorens
Copy link
Author

I've managed to test it again using commit 6767e01.
Using Rancher 1.18.2, I am able to reproduce the issue.

Running without breakpoints (no issue)

[Docker.DotNet 00:00:00.14] Raw buffer content: 'HTTP/1.1 201 Created<CR><LF>Api-Version: 1.45<CR><LF>Content-Length: 88<CR><LF>Content-Type: application/json<CR><LF>Date: Mon, 24 Mar 2025 17:00:14 GMT<CR><LF>Docker-Experimental: false<CR><LF>Ostype: linux<CR><LF>Server: Docker/26.1.5 (linux)<CR><LF>Connection: close<CR><LF><CR><LF>'.
[Docker.DotNet 00:00:00.15] CRLF found at positions 20 and 21.
[Docker.DotNet 00:00:00.15] CRLF found. Consumed 22 bytes. New offset: 22, Remaining count: 203.
[Docker.DotNet 00:00:00.15] String from positions 0 to 20 (length 20): 'HTTP/1.1 201 Created'.
[Docker.DotNet 00:00:00.15] Raw buffer content: 'HTTP/1.1 201 Created<CR><LF>Api-Version: 1.45<CR><LF>Content-Length: 88<CR><LF>Content-Type: application/json<CR><LF>Date: Mon, 24 Mar 2025 17:00:14 GMT<CR><LF>Docker-Experimental: false<CR><LF>Ostype: linux<CR><LF>Server: Docker/26.1.5 (linux)<CR><LF>Connection: close<CR><LF><CR><LF>'.
[Docker.DotNet 00:00:00.15] CRLF found at positions 39 and 40.
[Docker.DotNet 00:00:00.15] CRLF found. Consumed 19 bytes. New offset: 41, Remaining count: 184.
[Docker.DotNet 00:00:00.15] String from positions 22 to 39 (length 17): 'Api-Version: 1.45'.
[Docker.DotNet 00:00:00.15] Raw buffer content: 'HTTP/1.1 201 Created<CR><LF>Api-Version: 1.45<CR><LF>Content-Length: 88<CR><LF>Content-Type: application/json<CR><LF>Date: Mon, 24 Mar 2025 17:00:14 GMT<CR><LF>Docker-Experimental: false<CR><LF>Ostype: linux<CR><LF>Server: Docker/26.1.5 (linux)<CR><LF>Connection: close<CR><LF><CR><LF>'.
[Docker.DotNet 00:00:00.15] CRLF found at positions 59 and 60.
[Docker.DotNet 00:00:00.15] CRLF found. Consumed 20 bytes. New offset: 61, Remaining count: 164.
[Docker.DotNet 00:00:00.15] String from positions 41 to 59 (length 18): 'Content-Length: 88'.
[Docker.DotNet 00:00:00.15] Raw buffer content: 'HTTP/1.1 201 Created<CR><LF>Api-Version: 1.45<CR><LF>Content-Length: 88<CR><LF>Content-Type: application/json<CR><LF>Date: Mon, 24 Mar 2025 17:00:14 GMT<CR><LF>Docker-Experimental: false<CR><LF>Ostype: linux<CR><LF>Server: Docker/26.1.5 (linux)<CR><LF>Connection: close<CR><LF><CR><LF>'.
[Docker.DotNet 00:00:00.15] CRLF found at positions 91 and 92.
[Docker.DotNet 00:00:00.15] CRLF found. Consumed 32 bytes. New offset: 93, Remaining count: 132.
[Docker.DotNet 00:00:00.15] String from positions 61 to 91 (length 30): 'Content-Type: application/json'.
[Docker.DotNet 00:00:00.15] Raw buffer content: 'HTTP/1.1 201 Created<CR><LF>Api-Version: 1.45<CR><LF>Content-Length: 88<CR><LF>Content-Type: application/json<CR><LF>Date: Mon, 24 Mar 2025 17:00:14 GMT<CR><LF>Docker-Experimental: false<CR><LF>Ostype: linux<CR><LF>Server: Docker/26.1.5 (linux)<CR><LF>Connection: close<CR><LF><CR><LF>'.
[Docker.DotNet 00:00:00.15] CRLF found at positions 128 and 129.
[Docker.DotNet 00:00:00.15] CRLF found. Consumed 37 bytes. New offset: 130, Remaining count: 95.
[Docker.DotNet 00:00:00.15] String from positions 93 to 128 (length 35): 'Date: Mon, 24 Mar 2025 17:00:14 GMT'.
[Docker.DotNet 00:00:00.15] Raw buffer content: 'HTTP/1.1 201 Created<CR><LF>Api-Version: 1.45<CR><LF>Content-Length: 88<CR><LF>Content-Type: application/json<CR><LF>Date: Mon, 24 Mar 2025 17:00:14 GMT<CR><LF>Docker-Experimental: false<CR><LF>Ostype: linux<CR><LF>Server: Docker/26.1.5 (linux)<CR><LF>Connection: close<CR><LF><CR><LF>'.
[Docker.DotNet 00:00:00.15] CRLF found at positions 156 and 157.
[Docker.DotNet 00:00:00.15] CRLF found. Consumed 28 bytes. New offset: 158, Remaining count: 67.
[Docker.DotNet 00:00:00.15] String from positions 130 to 156 (length 26): 'Docker-Experimental: false'.
[Docker.DotNet 00:00:00.15] Raw buffer content: 'HTTP/1.1 201 Created<CR><LF>Api-Version: 1.45<CR><LF>Content-Length: 88<CR><LF>Content-Type: application/json<CR><LF>Date: Mon, 24 Mar 2025 17:00:14 GMT<CR><LF>Docker-Experimental: false<CR><LF>Ostype: linux<CR><LF>Server: Docker/26.1.5 (linux)<CR><LF>Connection: close<CR><LF><CR><LF>'.
[Docker.DotNet 00:00:00.15] CRLF found at positions 171 and 172.
[Docker.DotNet 00:00:00.15] CRLF found. Consumed 15 bytes. New offset: 173, Remaining count: 52.
[Docker.DotNet 00:00:00.15] String from positions 158 to 171 (length 13): 'Ostype: linux'.
[Docker.DotNet 00:00:00.15] Raw buffer content: 'HTTP/1.1 201 Created<CR><LF>Api-Version: 1.45<CR><LF>Content-Length: 88<CR><LF>Content-Type: application/json<CR><LF>Date: Mon, 24 Mar 2025 17:00:14 GMT<CR><LF>Docker-Experimental: false<CR><LF>Ostype: linux<CR><LF>Server: Docker/26.1.5 (linux)<CR><LF>Connection: close<CR><LF><CR><LF>'.
[Docker.DotNet 00:00:00.15] CRLF found at positions 202 and 203.
[Docker.DotNet 00:00:00.15] CRLF found. Consumed 31 bytes. New offset: 204, Remaining count: 21.
[Docker.DotNet 00:00:00.15] String from positions 173 to 202 (length 29): 'Server: Docker/26.1.5 (linux)'.
[Docker.DotNet 00:00:00.15] Raw buffer content: 'HTTP/1.1 201 Created<CR><LF>Api-Version: 1.45<CR><LF>Content-Length: 88<CR><LF>Content-Type: application/json<CR><LF>Date: Mon, 24 Mar 2025 17:00:14 GMT<CR><LF>Docker-Experimental: false<CR><LF>Ostype: linux<CR><LF>Server: Docker/26.1.5 (linux)<CR><LF>Connection: close<CR><LF><CR><LF>'.
[Docker.DotNet 00:00:00.15] CRLF found at positions 221 and 222.
[Docker.DotNet 00:00:00.15] CRLF found. Consumed 19 bytes. New offset: 223, Remaining count: 2.
[Docker.DotNet 00:00:00.15] String from positions 204 to 221 (length 17): 'Connection: close'.
[Docker.DotNet 00:00:00.15] Raw buffer content: 'HTTP/1.1 201 Created<CR><LF>Api-Version: 1.45<CR><LF>Content-Length: 88<CR><LF>Content-Type: application/json<CR><LF>Date: Mon, 24 Mar 2025 17:00:14 GMT<CR><LF>Docker-Experimental: false<CR><LF>Ostype: linux<CR><LF>Server: Docker/26.1.5 (linux)<CR><LF>Connection: close<CR><LF><CR><LF>'.
[Docker.DotNet 00:00:00.15] CRLF found at positions 223 and 224.
[Docker.DotNet 00:00:00.15] CRLF found. Consumed 2 bytes. New offset: 225, Remaining count: 0.
[Docker.DotNet 00:00:00.15] String from positions 223 to 223 (length 0): ''.
[Docker.DotNet 00:00:00.17] Raw buffer content: 'HTTP/1.1 200 OK<CR><LF>Api-Version: 1.45<CR><LF>Content-Type: application/json<CR><LF>Date: Mon, 24 Mar 2025 17:00:14 GMT<CR><LF>Docker-Experimental: false<CR><LF>Ostype: linux<CR><LF>Server: Docker/26.1.5 (linux)<CR><LF>Connection: close<CR><LF>Transfer-Encoding: chunked<CR><LF><CR><LF>'.
[Docker.DotNet 00:00:00.17] CRLF found at positions 15 and 16.
[Docker.DotNet 00:00:00.17] CRLF found. Consumed 17 bytes. New offset: 17, Remaining count: 211.
[Docker.DotNet 00:00:00.17] String from positions 0 to 15 (length 15): 'HTTP/1.1 200 OK'.
[Docker.DotNet 00:00:00.17] Raw buffer content: 'HTTP/1.1 200 OK<CR><LF>Api-Version: 1.45<CR><LF>Content-Type: application/json<CR><LF>Date: Mon, 24 Mar 2025 17:00:14 GMT<CR><LF>Docker-Experimental: false<CR><LF>Ostype: linux<CR><LF>Server: Docker/26.1.5 (linux)<CR><LF>Connection: close<CR><LF>Transfer-Encoding: chunked<CR><LF><CR><LF>'.
[Docker.DotNet 00:00:00.17] CRLF found at positions 34 and 35.
[Docker.DotNet 00:00:00.17] CRLF found. Consumed 19 bytes. New offset: 36, Remaining count: 192.
[Docker.DotNet 00:00:00.17] String from positions 17 to 34 (length 17): 'Api-Version: 1.45'.
[Docker.DotNet 00:00:00.17] Raw buffer content: 'HTTP/1.1 200 OK<CR><LF>Api-Version: 1.45<CR><LF>Content-Type: application/json<CR><LF>Date: Mon, 24 Mar 2025 17:00:14 GMT<CR><LF>Docker-Experimental: false<CR><LF>Ostype: linux<CR><LF>Server: Docker/26.1.5 (linux)<CR><LF>Connection: close<CR><LF>Transfer-Encoding: chunked<CR><LF><CR><LF>'.
[Docker.DotNet 00:00:00.17] CRLF found at positions 66 and 67.
[Docker.DotNet 00:00:00.17] CRLF found. Consumed 32 bytes. New offset: 68, Remaining count: 160.
[Docker.DotNet 00:00:00.17] String from positions 36 to 66 (length 30): 'Content-Type: application/json'.
[Docker.DotNet 00:00:00.17] Raw buffer content: 'HTTP/1.1 200 OK<CR><LF>Api-Version: 1.45<CR><LF>Content-Type: application/json<CR><LF>Date: Mon, 24 Mar 2025 17:00:14 GMT<CR><LF>Docker-Experimental: false<CR><LF>Ostype: linux<CR><LF>Server: Docker/26.1.5 (linux)<CR><LF>Connection: close<CR><LF>Transfer-Encoding: chunked<CR><LF><CR><LF>'.
[Docker.DotNet 00:00:00.17] CRLF found at positions 103 and 104.
[Docker.DotNet 00:00:00.17] CRLF found. Consumed 37 bytes. New offset: 105, Remaining count: 123.
[Docker.DotNet 00:00:00.17] String from positions 68 to 103 (length 35): 'Date: Mon, 24 Mar 2025 17:00:14 GMT'.
[Docker.DotNet 00:00:00.17] Raw buffer content: 'HTTP/1.1 200 OK<CR><LF>Api-Version: 1.45<CR><LF>Content-Type: application/json<CR><LF>Date: Mon, 24 Mar 2025 17:00:14 GMT<CR><LF>Docker-Experimental: false<CR><LF>Ostype: linux<CR><LF>Server: Docker/26.1.5 (linux)<CR><LF>Connection: close<CR><LF>Transfer-Encoding: chunked<CR><LF><CR><LF>'.
[Docker.DotNet 00:00:00.17] CRLF found at positions 131 and 132.
[Docker.DotNet 00:00:00.17] CRLF found. Consumed 28 bytes. New offset: 133, Remaining count: 95.
[Docker.DotNet 00:00:00.17] String from positions 105 to 131 (length 26): 'Docker-Experimental: false'.
[Docker.DotNet 00:00:00.17] Raw buffer content: 'HTTP/1.1 200 OK<CR><LF>Api-Version: 1.45<CR><LF>Content-Type: application/json<CR><LF>Date: Mon, 24 Mar 2025 17:00:14 GMT<CR><LF>Docker-Experimental: false<CR><LF>Ostype: linux<CR><LF>Server: Docker/26.1.5 (linux)<CR><LF>Connection: close<CR><LF>Transfer-Encoding: chunked<CR><LF><CR><LF>'.
[Docker.DotNet 00:00:00.17] CRLF found at positions 146 and 147.
[Docker.DotNet 00:00:00.17] CRLF found. Consumed 15 bytes. New offset: 148, Remaining count: 80.
[Docker.DotNet 00:00:00.17] String from positions 133 to 146 (length 13): 'Ostype: linux'.
[Docker.DotNet 00:00:00.17] Raw buffer content: 'HTTP/1.1 200 OK<CR><LF>Api-Version: 1.45<CR><LF>Content-Type: application/json<CR><LF>Date: Mon, 24 Mar 2025 17:00:14 GMT<CR><LF>Docker-Experimental: false<CR><LF>Ostype: linux<CR><LF>Server: Docker/26.1.5 (linux)<CR><LF>Connection: close<CR><LF>Transfer-Encoding: chunked<CR><LF><CR><LF>'.
[Docker.DotNet 00:00:00.17] CRLF found at positions 177 and 178.
[Docker.DotNet 00:00:00.17] CRLF found. Consumed 31 bytes. New offset: 179, Remaining count: 49.
[Docker.DotNet 00:00:00.17] String from positions 148 to 177 (length 29): 'Server: Docker/26.1.5 (linux)'.
[Docker.DotNet 00:00:00.17] Raw buffer content: 'HTTP/1.1 200 OK<CR><LF>Api-Version: 1.45<CR><LF>Content-Type: application/json<CR><LF>Date: Mon, 24 Mar 2025 17:00:14 GMT<CR><LF>Docker-Experimental: false<CR><LF>Ostype: linux<CR><LF>Server: Docker/26.1.5 (linux)<CR><LF>Connection: close<CR><LF>Transfer-Encoding: chunked<CR><LF><CR><LF>'.
[Docker.DotNet 00:00:00.17] CRLF found at positions 196 and 197.
[Docker.DotNet 00:00:00.17] CRLF found. Consumed 19 bytes. New offset: 198, Remaining count: 30.
[Docker.DotNet 00:00:00.17] String from positions 179 to 196 (length 17): 'Connection: close'.
[Docker.DotNet 00:00:00.17] Raw buffer content: 'HTTP/1.1 200 OK<CR><LF>Api-Version: 1.45<CR><LF>Content-Type: application/json<CR><LF>Date: Mon, 24 Mar 2025 17:00:14 GMT<CR><LF>Docker-Experimental: false<CR><LF>Ostype: linux<CR><LF>Server: Docker/26.1.5 (linux)<CR><LF>Connection: close<CR><LF>Transfer-Encoding: chunked<CR><LF><CR><LF>'.
[Docker.DotNet 00:00:00.17] CRLF found at positions 224 and 225.
[Docker.DotNet 00:00:00.17] CRLF found. Consumed 28 bytes. New offset: 226, Remaining count: 2.
[Docker.DotNet 00:00:00.17] String from positions 198 to 224 (length 26): 'Transfer-Encoding: chunked'.
[Docker.DotNet 00:00:00.17] Raw buffer content: 'HTTP/1.1 200 OK<CR><LF>Api-Version: 1.45<CR><LF>Content-Type: application/json<CR><LF>Date: Mon, 24 Mar 2025 17:00:14 GMT<CR><LF>Docker-Experimental: false<CR><LF>Ostype: linux<CR><LF>Server: Docker/26.1.5 (linux)<CR><LF>Connection: close<CR><LF>Transfer-Encoding: chunked<CR><LF><CR><LF>'.
[Docker.DotNet 00:00:00.17] CRLF found at positions 226 and 227.
[Docker.DotNet 00:00:00.17] CRLF found. Consumed 2 bytes. New offset: 228, Remaining count: 0.
[Docker.DotNet 00:00:00.17] String from positions 226 to 226 (length 0): ''.
[Docker.DotNet 00:00:00.17] Raw buffer content: '1459<CR><LF>{"Id":"0e2706b0078418256373a5825fb58b148c22e4ff0a6afb58d5767328af5c9260","Created":"2025-03-24T17:00:14.338801576Z","Path":"docker-entrypoint.sh","Args":["postgres"],"State":{"Status":"created","Running":false,"Paused":false,"Restarting":false,"OOMKilled":false,"Dead":false,"Pid":0,"ExitCode":0,"Error":"","StartedAt":"0001-01-01T00:00:00Z","FinishedAt":"0001-01-01T00:00:00Z"},"Image":"sha256:0150e3200277b907866758e22a3b9bba7857325b994848fe9f44b3610c3ae17e","ResolvConfPath":"","HostnamePath":"","HostsPath":"","LogPath":"","Name":"/flamboyant_kalam","RestartCount":0,"Driver":"overlay2","Platform":"linux","MountLabel":"","ProcessLabel":"","AppArmorProfile":"","ExecIDs":null,"HostConfig":{"Binds":null,"ContainerIDFile":"","LogConfig":{"Type":"json-file","Config":{}},"NetworkMode":"bridge","PortBindings":null,"RestartPolicy":{"Name":"no","MaximumRetryCount":0},"AutoRemove":false,"VolumeDriver":"","VolumesFrom":null,"ConsoleSize":[0,0],"CapAdd":null,"CapDrop":null,"CgroupnsMode":"host","Dns":null,"DnsOptions":null,"DnsSearch":null,"ExtraHosts":null,"GroupAdd":null,"IpcMode":"private","Cgroup":"","Links":null,"OomScoreAdj":0,"PidMode":"","Privileged":false,"PublishAllPorts":false,"ReadonlyRootfs":false,"SecurityOpt":null,"UTSMode":"","UsernsMode":"","ShmSize":67108864,"Runtime":"runc","Isolation":"","CpuShares":0,"Memory":0,"NanoCpus":0,"CgroupParent":"","BlkioWeight":0,"BlkioWeightDevice":null,"BlkioDeviceReadBps":null,"BlkioDeviceWriteBps":null,"BlkioDeviceReadIOps":null,"BlkioDeviceWriteIOps":null,"CpuPeriod":0,"CpuQuota":0,"CpuRealtimePeriod":0,"CpuRealtimeRuntime":0,"CpusetCpus":"","CpusetMems":"","Devices":null,"DeviceCgroupRules":null,"DeviceRequests":null,"MemoryReservation":0,"MemorySwap":0,"MemorySwappiness":null,"OomKillDisable":false,"PidsLimit":null,"Ulimits":null,"CpuCount":0,"CpuPercent":0,"IOMaximumIOps":0,"IOMaximumBandwidth":0,"MaskedPaths":["/proc/asound","/proc/acpi","/proc/kcore","/proc/keys","/proc/latency_stats","/proc/timer_list","/proc/timer_stats","/proc/sched_debug","/proc/scsi","/sys/firmware","/sys/devices/virtual/powercap"],"ReadonlyPaths":["/proc/bus","/proc/fs","/proc/irq","/proc/sys","/proc/sysrq-trigger"]},"GraphDriver":{"Data":{"LowerDir":"/var/lib/docker/overlay2/33525d2048f20d4c1cc301ec7f8531efef42b9a822488161e76c55f55fa3d449-init/diff:/var/lib/docker/overlay2/b11a76ed7876078226874069c4659d92e212313a01a6756d1022059021adee47/diff:/var/lib/docker/overlay2/a86f1e8914bbe458402755a5b621e47585f9625bbb6c69893d8516658930dbe9/diff:/var/lib/docker/overlay2/41b80a34527860c550c0a4947fa7b0c3e76c8366350c3b80580f4ccbafcfb6a4/diff:/var/lib/docker/overlay2/9bce3631b6196054c6871753b565a9377b98b95282e67e0e8e3495f56df59d59/diff:/var/lib/docker/overlay2/83b9142c71105a37eaac927b03f6e46a8125b34593a065c6ba3acc1f781cac0b/diff:/var/lib/docker/overlay2/de79a2dfb2a28a9cba3642871b9c96664256bb8131e78133a0fd15c8ab8e9310/diff:/var/lib/docker/overlay2/04e350801675cda5e3da22cd3eb57430f385c24e02c96fdf5c7f3d11bcdd3710/diff:/var/lib/docker/overlay2/4024b990a94825b7ceece93e209e5ae6bcc6eb9d63a6cf9143e293c4ecbddfea/diff:/var/lib/docker/overlay2/52b888f17ab044424c968bba1b8f7f121775376303ccf9345862ee0d1d0df449/diff:/var/lib/docker/overlay2/2e07778dda591de6f675ed15d6b575d4d75447dd42e3cca8336a03eb72fe82f2/diff","MergedDir":"/var/lib/docker/overlay2/33525d2048f20d4c1cc301ec7f8531efef42b9a822488161e76c55f55fa3d449/merged","UpperDir":"/var/lib/docker/overlay2/33525d2048f20d4c1cc301ec7f8531efef42b9a822488161e76c55f55fa3d449/diff","WorkDir":"/var/lib/docker/overlay2/33525d2048f20d4c1cc301ec7f8531efef42b9a822488161e76c55f55fa3d449/work"},"Name":"overlay2"},"Mounts":[{"Type":"volume","Name":"3a79c4dc51c58fdb20c3711d6da1249528b56a7e4b41154350777861330a5f26","Source":"/var/lib/docker/volumes/3a79c4dc51c58fdb20c3711d6da1249528b56a7e4b41154350777861330a5f26/_data","Destination":"/var/lib/postgresql/data","Driver":"local","Mode":"","RW":true,"Propagation":""}],"Config":{"Hostname":"0e2706b00784","Domainname":"","User":"","AttachStdin":false,"AttachStdout":false,"AttachStderr":false,"ExposedPorts":{"5432/tcp":{}},"Tty":false,"OpenStdin":fals'.
[Docker.DotNet 00:00:00.17] CRLF found at positions 4 and 5.
[Docker.DotNet 00:00:00.17] CRLF found. Consumed 6 bytes. New offset: 6, Remaining count: 4090.
[Docker.DotNet 00:00:00.17] String from positions 0 to 4 (length 4): '1459'.
[Docker.DotNet 00:00:00.17] Raw buffer content: '<CR><LF>0<CR><LF><CR><LF>"Id":"0e2706b0078418256373a5825fb58b148c22e4ff0a6afb58d5767328af5c9260","Created":"2025-03-24T17:00:14.338801576Z","Path":"docker-entrypoint.sh","Args":["postgres"],"State":{"Status":"created","Running":false,"Paused":false,"Restarting":false,"OOMKilled":false,"Dead":false,"Pid":0,"ExitCode":0,"Error":"","StartedAt":"0001-01-01T00:00:00Z","FinishedAt":"0001-01-01T00:00:00Z"},"Image":"sha256:0150e3200277b907866758e22a3b9bba7857325b994848fe9f44b3610c3ae17e","ResolvConfPath":"","HostnamePath":"","HostsPath":"","LogPath":"","Name":"/flamboyant_kalam","RestartCount":0,"Driver":"overlay2","Platform":"linux","MountLabel":"","ProcessLabel":"","AppArmorProfile":"","ExecIDs":null,"HostConfig":{"Binds":null,"ContainerIDFile":"","LogConfig":{"Type":"json-file","Config":{}},"NetworkMode":"bridge","PortBindings":null,"RestartPolicy":{"Name":"no","MaximumRetryCount":0},"AutoRemove":false,"VolumeDriver":"","VolumesFrom":null,"ConsoleSize":[0,0],"CapAdd":null,"CapDrop":null,"CgroupnsMode":"host","Dns":null,"DnsOptions":null,"DnsSearch":null,"ExtraHosts":null,"GroupAdd":null,"IpcMode":"private","Cgroup":"","Links":null,"OomScoreAdj":0,"PidMode":"","Privileged":false,"PublishAllPorts":false,"ReadonlyRootfs":false,"SecurityOpt":null,"UTSMode":"","UsernsMode":"","ShmSize":67108864,"Runtime":"runc","Isolation":"","CpuShares":0,"Memory":0,"NanoCpus":0,"CgroupParent":"","BlkioWeight":0,"BlkioWeightDevice":null,"BlkioDeviceReadBps":null,"BlkioDeviceWriteBps":null,"BlkioDeviceReadIOps":null,"BlkioDeviceWriteIOps":null,"CpuPeriod":0,"CpuQuota":0,"CpuRealtimePeriod":0,"CpuRealtimeRuntime":0,"CpusetCpus":"","CpusetMems":"","Devices":null,"DeviceCgroupRules":null,"DeviceRequests":null,"MemoryReservation":0,"MemorySwap":0,"MemorySwappiness":null,"OomKillDisable":false,"PidsLimit":null,"Ulimits":null,"CpuCount":0,"CpuPercent":0,"IOMaximumIOps":0,"IOMaximumBandwidth":0,"MaskedPaths":["/proc/asound","/proc/acpi","/proc/kcore","/proc/keys","/proc/latency_stats","/proc/timer_list","/proc/timer_stats","/proc/sched_debug","/proc/scsi","/sys/firmware","/sys/devices/virtual/powercap"],"ReadonlyPaths":["/proc/bus","/proc/fs","/proc/irq","/proc/sys","/proc/sysrq-trigger"]},"GraphDriver":{"Data":{"LowerDir":"/var/lib/docker/overlay2/33525d2048f20d4c1cc301ec7f8531efef42b9a822488161e76c55f55fa3d449-init/diff:/var/lib/docker/overlay2/b11a76ed7876078226874069c4659d92e212313a01a6756d1022059021adee47/diff:/var/lib/docker/overlay2/a86f1e8914bbe458402755a5b621e47585f9625bbb6c69893d8516658930dbe9/diff:/var/lib/docker/overlay2/41b80a34527860c550c0a4947fa7b0c3e76c8366350c3b80580f4ccbafcfb6a4/diff:/var/lib/docker/overlay2/9bce3631b6196054c6871753b565a9377b98b95282e67e0e8e3495f56df59d59/diff:/var/lib/docker/overlay2/83b9142c71105a37eaac927b03f6e46a8125b34593a065c6ba3acc1f781cac0b/diff:/var/lib/docker/overlay2/de79a2dfb2a28a9cba3642871b9c96664256bb8131e78133a0fd15c8ab8e9310/diff:/var/lib/docker/overlay2/04e350801675cda5e3da22cd3eb57430f385c24e02c96fdf5c7f3d11bcdd3710/diff:/var/lib/docker/overlay2/4024b990a94825b7ceece93e209e5ae6bcc6eb9d63a6cf9143e293c4ecbddfea/diff:/var/lib/docker/overlay2/52b888f17ab044424c968bba1b8f7f121775376303ccf9345862ee0d1d0df449/diff:/var/lib/docker/overlay2/2e07778dda591de6f675ed15d6b575d4d75447dd42e3cca8336a03eb72fe82f2/diff","MergedDir":"/var/lib/docker/overlay2/33525d2048f20d4c1cc301ec7f8531efef42b9a822488161e76c55f55fa3d449/merged","UpperDir":"/var/lib/docker/overlay2/33525d2048f20d4c1cc301ec7f8531efef42b9a822488161e76c55f55fa3d449/diff","WorkDir":"/var/lib/docker/overlay2

Placing a single breakpoint on if (_done) and continue on break produces following exception:

System.Net.Http.HttpRequestException: Error while copying content to a stream.

System.Net.Http.HttpRequestException
Error while copying content to a stream.
   at System.Net.Http.HttpContent.LoadIntoBufferAsyncCore(Task serializeToStreamTask, MemoryStream tempBuffer)
   at System.Net.Http.HttpClient.<SendAsync>g__Core|83_0(HttpRequestMessage request, HttpCompletionOption completionOption, CancellationTokenSource cts, Boolean disposeCts, CancellationTokenSource pendingRequestsCts, CancellationToken originalCancellationToken)
   at Docker.DotNet.DockerClient.PrivateMakeRequestAsync(TimeSpan timeout, HttpCompletionOption completionOption, HttpMethod method, String path, IQueryString queryString, IDictionary`2 headers, IRequestContent data, CancellationToken cancellationToken) in C:\Users\X\RiderProjects\Docker.DotNet\src\Docker.DotNet\DockerClient.cs:line 417
   at Docker.DotNet.DockerClient.MakeRequestAsync[T](IEnumerable`1 errorHandlers, HttpMethod method, String path, IQueryString queryString, IRequestContent body, IDictionary`2 headers, TimeSpan timeout, CancellationToken token) in C:\Users\X\RiderProjects\Docker.DotNet\src\Docker.DotNet\DockerClient.cs:line 248
   at Docker.DotNet.ContainerOperations.InspectContainerAsync(String id, CancellationToken cancellationToken) in C:\Users\X\RiderProjects\Docker.DotNet\src\Docker.DotNet\Endpoints\ContainerOperations.cs:line 64
   at Docker.DotNet.Tests.DebugHttpRequestResponse.Run() in C:\Users\X\RiderProjects\Docker.DotNet\test\Docker.DotNet.Tests\DebugHttpRequestResponse.cs:line 26
   at Xunit.Sdk.TestInvoker`1.<>c__DisplayClass47_0.<<InvokeTestMethodAsync>b__1>d.MoveNext() in /_/src/xunit.execution/Sdk/Frameworks/Runners/TestInvoker.cs:line 259
--- End of stack trace from previous location ---
   at Xunit.Sdk.ExecutionTimer.AggregateAsync(Func`1 asyncAction) in /_/src/xunit.execution/Sdk/Frameworks/ExecutionTimer.cs:line 48
   at Xunit.Sdk.ExceptionAggregator.RunAsync(Func`1 code) in /_/src/xunit.core/Sdk/ExceptionAggregator.cs:line 90
System.IO.IOException
Invalid chunk header encountered: 'false,"StdinOnce":false,"Env":["PATH=/usr/local/sbin:/usr/local/bin:/usr/sbin:/usr/bin:/sbin:/bin","GOSU_VERSION=1.17","LANG=en_US.utf8","PG_MAJOR=17","PG_VERSION=17.4","PG_SHA256=c4605b73fea11963406699f949b966e5d173a7ee0ccaef8938dec0ca8a995fe7","DOCKER_PG_LLVM_DEPS=llvm19-dev \t\tclang19","PGDATA=/var/lib/postgresql/data"],"Cmd":["postgres"],"Image":"postgres:alpine","Volumes":{"/var/lib/postgresql/data":{}},"WorkingDir":"/","Entrypoint":["docker-entrypoint.sh"],"OnBuild":null,"Labels":{},"StopSignal":"SIGINT"},"NetworkSettings":{"Bridge":"","SandboxID":"","SandboxKey":"","Ports":{},"HairpinMode":false,"LinkLocalIPv6Address":"","LinkLocalIPv6PrefixLen":0,"SecondaryIPAddresses":null,"SecondaryIPv6Addresses":null,"EndpointID":"","Gateway":"","GlobalIPv6Address":"","GlobalIPv6PrefixLen":0,"IPAddress":"","IPPrefixLen":0,"IPv6Gateway":"","MacAddress":"","Networks":{"bridge":{"IPAMConfig":null,"Links":null,"Aliases":null,"MacAddress":"","NetworkID":"","EndpointID":"","Gateway":"","IPAddress":"","IPPrefixLen":0,"IPv6Gateway":"","GlobalIPv6Address":"","GlobalIPv6PrefixLen":0,"DriverOpts":null,"DNSNames":null}}}}
'.
   at Microsoft.Net.Http.Client.ChunkedReadStream.ReadAsync(Byte[] buffer, Int32 offset, Int32 count, CancellationToken cancellationToken) in C:\Users\X\RiderProjects\Docker.DotNet\src\Docker.DotNet\Microsoft.Net.Http.Client\ChunkedReadStream.cs:line 103
   at System.IO.Stream.<CopyToAsync>g__Core|27_0(Stream source, Stream destination, Int32 bufferSize, CancellationToken cancellationToken)
   at System.Net.Http.HttpContent.LoadIntoBufferAsyncCore(Task serializeToStreamTask, MemoryStream tempBuffer)



[Docker.DotNet 00:00:02.52] Raw buffer content: 'HTTP/1.1 201 Created<CR><LF>Api-Version: 1.45<CR><LF>Content-Length: 88<CR><LF>Content-Type: application/json<CR><LF>Date: Mon, 24 Mar 2025 17:01:11 GMT<CR><LF>Docker-Experimental: false<CR><LF>Ostype: linux<CR><LF>Server: Docker/26.1.5 (linux)<CR><LF>Connection: close<CR><LF><CR><LF>'.
[Docker.DotNet 00:00:02.53] CRLF found at positions 20 and 21.
[Docker.DotNet 00:00:02.53] CRLF found. Consumed 22 bytes. New offset: 22, Remaining count: 203.
[Docker.DotNet 00:00:02.53] String from positions 0 to 20 (length 20): 'HTTP/1.1 201 Created'.
[Docker.DotNet 00:00:02.53] Raw buffer content: 'HTTP/1.1 201 Created<CR><LF>Api-Version: 1.45<CR><LF>Content-Length: 88<CR><LF>Content-Type: application/json<CR><LF>Date: Mon, 24 Mar 2025 17:01:11 GMT<CR><LF>Docker-Experimental: false<CR><LF>Ostype: linux<CR><LF>Server: Docker/26.1.5 (linux)<CR><LF>Connection: close<CR><LF><CR><LF>'.
[Docker.DotNet 00:00:02.53] CRLF found at positions 39 and 40.
[Docker.DotNet 00:00:02.53] CRLF found. Consumed 19 bytes. New offset: 41, Remaining count: 184.
[Docker.DotNet 00:00:02.53] String from positions 22 to 39 (length 17): 'Api-Version: 1.45'.
[Docker.DotNet 00:00:02.53] Raw buffer content: 'HTTP/1.1 201 Created<CR><LF>Api-Version: 1.45<CR><LF>Content-Length: 88<CR><LF>Content-Type: application/json<CR><LF>Date: Mon, 24 Mar 2025 17:01:11 GMT<CR><LF>Docker-Experimental: false<CR><LF>Ostype: linux<CR><LF>Server: Docker/26.1.5 (linux)<CR><LF>Connection: close<CR><LF><CR><LF>'.
[Docker.DotNet 00:00:02.53] CRLF found at positions 59 and 60.
[Docker.DotNet 00:00:02.53] CRLF found. Consumed 20 bytes. New offset: 61, Remaining count: 164.
[Docker.DotNet 00:00:02.53] String from positions 41 to 59 (length 18): 'Content-Length: 88'.
[Docker.DotNet 00:00:02.53] Raw buffer content: 'HTTP/1.1 201 Created<CR><LF>Api-Version: 1.45<CR><LF>Content-Length: 88<CR><LF>Content-Type: application/json<CR><LF>Date: Mon, 24 Mar 2025 17:01:11 GMT<CR><LF>Docker-Experimental: false<CR><LF>Ostype: linux<CR><LF>Server: Docker/26.1.5 (linux)<CR><LF>Connection: close<CR><LF><CR><LF>'.
[Docker.DotNet 00:00:02.53] CRLF found at positions 91 and 92.
[Docker.DotNet 00:00:02.53] CRLF found. Consumed 32 bytes. New offset: 93, Remaining count: 132.
[Docker.DotNet 00:00:02.53] String from positions 61 to 91 (length 30): 'Content-Type: application/json'.
[Docker.DotNet 00:00:02.53] Raw buffer content: 'HTTP/1.1 201 Created<CR><LF>Api-Version: 1.45<CR><LF>Content-Length: 88<CR><LF>Content-Type: application/json<CR><LF>Date: Mon, 24 Mar 2025 17:01:11 GMT<CR><LF>Docker-Experimental: false<CR><LF>Ostype: linux<CR><LF>Server: Docker/26.1.5 (linux)<CR><LF>Connection: close<CR><LF><CR><LF>'.
[Docker.DotNet 00:00:02.53] CRLF found at positions 128 and 129.
[Docker.DotNet 00:00:02.53] CRLF found. Consumed 37 bytes. New offset: 130, Remaining count: 95.
[Docker.DotNet 00:00:02.53] String from positions 93 to 128 (length 35): 'Date: Mon, 24 Mar 2025 17:01:11 GMT'.
[Docker.DotNet 00:00:02.53] Raw buffer content: 'HTTP/1.1 201 Created<CR><LF>Api-Version: 1.45<CR><LF>Content-Length: 88<CR><LF>Content-Type: application/json<CR><LF>Date: Mon, 24 Mar 2025 17:01:11 GMT<CR><LF>Docker-Experimental: false<CR><LF>Ostype: linux<CR><LF>Server: Docker/26.1.5 (linux)<CR><LF>Connection: close<CR><LF><CR><LF>'.
[Docker.DotNet 00:00:02.53] CRLF found at positions 156 and 157.
[Docker.DotNet 00:00:02.53] CRLF found. Consumed 28 bytes. New offset: 158, Remaining count: 67.
[Docker.DotNet 00:00:02.53] String from positions 130 to 156 (length 26): 'Docker-Experimental: false'.
[Docker.DotNet 00:00:02.53] Raw buffer content: 'HTTP/1.1 201 Created<CR><LF>Api-Version: 1.45<CR><LF>Content-Length: 88<CR><LF>Content-Type: application/json<CR><LF>Date: Mon, 24 Mar 2025 17:01:11 GMT<CR><LF>Docker-Experimental: false<CR><LF>Ostype: linux<CR><LF>Server: Docker/26.1.5 (linux)<CR><LF>Connection: close<CR><LF><CR><LF>'.
[Docker.DotNet 00:00:02.53] CRLF found at positions 171 and 172.
[Docker.DotNet 00:00:02.53] CRLF found. Consumed 15 bytes. New offset: 173, Remaining count: 52.
[Docker.DotNet 00:00:02.53] String from positions 158 to 171 (length 13): 'Ostype: linux'.
[Docker.DotNet 00:00:02.53] Raw buffer content: 'HTTP/1.1 201 Created<CR><LF>Api-Version: 1.45<CR><LF>Content-Length: 88<CR><LF>Content-Type: application/json<CR><LF>Date: Mon, 24 Mar 2025 17:01:11 GMT<CR><LF>Docker-Experimental: false<CR><LF>Ostype: linux<CR><LF>Server: Docker/26.1.5 (linux)<CR><LF>Connection: close<CR><LF><CR><LF>'.
[Docker.DotNet 00:00:02.53] CRLF found at positions 202 and 203.
[Docker.DotNet 00:00:02.53] CRLF found. Consumed 31 bytes. New offset: 204, Remaining count: 21.
[Docker.DotNet 00:00:02.53] String from positions 173 to 202 (length 29): 'Server: Docker/26.1.5 (linux)'.
[Docker.DotNet 00:00:02.53] Raw buffer content: 'HTTP/1.1 201 Created<CR><LF>Api-Version: 1.45<CR><LF>Content-Length: 88<CR><LF>Content-Type: application/json<CR><LF>Date: Mon, 24 Mar 2025 17:01:11 GMT<CR><LF>Docker-Experimental: false<CR><LF>Ostype: linux<CR><LF>Server: Docker/26.1.5 (linux)<CR><LF>Connection: close<CR><LF><CR><LF>'.
[Docker.DotNet 00:00:02.53] CRLF found at positions 221 and 222.
[Docker.DotNet 00:00:02.53] CRLF found. Consumed 19 bytes. New offset: 223, Remaining count: 2.
[Docker.DotNet 00:00:02.53] String from positions 204 to 221 (length 17): 'Connection: close'.
[Docker.DotNet 00:00:02.53] Raw buffer content: 'HTTP/1.1 201 Created<CR><LF>Api-Version: 1.45<CR><LF>Content-Length: 88<CR><LF>Content-Type: application/json<CR><LF>Date: Mon, 24 Mar 2025 17:01:11 GMT<CR><LF>Docker-Experimental: false<CR><LF>Ostype: linux<CR><LF>Server: Docker/26.1.5 (linux)<CR><LF>Connection: close<CR><LF><CR><LF>'.
[Docker.DotNet 00:00:02.53] CRLF found at positions 223 and 224.
[Docker.DotNet 00:00:02.53] CRLF found. Consumed 2 bytes. New offset: 225, Remaining count: 0.
[Docker.DotNet 00:00:02.53] String from positions 223 to 223 (length 0): ''.
[Docker.DotNet 00:00:02.57] Raw buffer content: 'HTTP/1.1 200 OK<CR><LF>Api-Version: 1.45<CR><LF>Content-Type: application/json<CR><LF>Date: Mon, 24 Mar 2025 17:01:11 GMT<CR><LF>Docker-Experimental: false<CR><LF>Ostype: linux<CR><LF>Server: Docker/26.1.5 (linux)<CR><LF>Connection: close<CR><LF>Transfer-Encoding: chunked<CR><LF><CR><LF>'.
[Docker.DotNet 00:00:02.58] CRLF found at positions 15 and 16.
[Docker.DotNet 00:00:02.58] CRLF found. Consumed 17 bytes. New offset: 17, Remaining count: 211.
[Docker.DotNet 00:00:02.58] String from positions 0 to 15 (length 15): 'HTTP/1.1 200 OK'.
[Docker.DotNet 00:00:02.58] Raw buffer content: 'HTTP/1.1 200 OK<CR><LF>Api-Version: 1.45<CR><LF>Content-Type: application/json<CR><LF>Date: Mon, 24 Mar 2025 17:01:11 GMT<CR><LF>Docker-Experimental: false<CR><LF>Ostype: linux<CR><LF>Server: Docker/26.1.5 (linux)<CR><LF>Connection: close<CR><LF>Transfer-Encoding: chunked<CR><LF><CR><LF>'.
[Docker.DotNet 00:00:02.58] CRLF found at positions 34 and 35.
[Docker.DotNet 00:00:02.58] CRLF found. Consumed 19 bytes. New offset: 36, Remaining count: 192.
[Docker.DotNet 00:00:02.58] String from positions 17 to 34 (length 17): 'Api-Version: 1.45'.
[Docker.DotNet 00:00:02.58] Raw buffer content: 'HTTP/1.1 200 OK<CR><LF>Api-Version: 1.45<CR><LF>Content-Type: application/json<CR><LF>Date: Mon, 24 Mar 2025 17:01:11 GMT<CR><LF>Docker-Experimental: false<CR><LF>Ostype: linux<CR><LF>Server: Docker/26.1.5 (linux)<CR><LF>Connection: close<CR><LF>Transfer-Encoding: chunked<CR><LF><CR><LF>'.
[Docker.DotNet 00:00:02.58] CRLF found at positions 66 and 67.
[Docker.DotNet 00:00:02.58] CRLF found. Consumed 32 bytes. New offset: 68, Remaining count: 160.
[Docker.DotNet 00:00:02.58] String from positions 36 to 66 (length 30): 'Content-Type: application/json'.
[Docker.DotNet 00:00:02.58] Raw buffer content: 'HTTP/1.1 200 OK<CR><LF>Api-Version: 1.45<CR><LF>Content-Type: application/json<CR><LF>Date: Mon, 24 Mar 2025 17:01:11 GMT<CR><LF>Docker-Experimental: false<CR><LF>Ostype: linux<CR><LF>Server: Docker/26.1.5 (linux)<CR><LF>Connection: close<CR><LF>Transfer-Encoding: chunked<CR><LF><CR><LF>'.
[Docker.DotNet 00:00:02.58] CRLF found at positions 103 and 104.
[Docker.DotNet 00:00:02.58] CRLF found. Consumed 37 bytes. New offset: 105, Remaining count: 123.
[Docker.DotNet 00:00:02.58] String from positions 68 to 103 (length 35): 'Date: Mon, 24 Mar 2025 17:01:11 GMT'.
[Docker.DotNet 00:00:02.58] Raw buffer content: 'HTTP/1.1 200 OK<CR><LF>Api-Version: 1.45<CR><LF>Content-Type: application/json<CR><LF>Date: Mon, 24 Mar 2025 17:01:11 GMT<CR><LF>Docker-Experimental: false<CR><LF>Ostype: linux<CR><LF>Server: Docker/26.1.5 (linux)<CR><LF>Connection: close<CR><LF>Transfer-Encoding: chunked<CR><LF><CR><LF>'.
[Docker.DotNet 00:00:02.58] CRLF found at positions 131 and 132.
[Docker.DotNet 00:00:02.58] CRLF found. Consumed 28 bytes. New offset: 133, Remaining count: 95.
[Docker.DotNet 00:00:02.58] String from positions 105 to 131 (length 26): 'Docker-Experimental: false'.
[Docker.DotNet 00:00:02.58] Raw buffer content: 'HTTP/1.1 200 OK<CR><LF>Api-Version: 1.45<CR><LF>Content-Type: application/json<CR><LF>Date: Mon, 24 Mar 2025 17:01:11 GMT<CR><LF>Docker-Experimental: false<CR><LF>Ostype: linux<CR><LF>Server: Docker/26.1.5 (linux)<CR><LF>Connection: close<CR><LF>Transfer-Encoding: chunked<CR><LF><CR><LF>'.
[Docker.DotNet 00:00:02.58] CRLF found at positions 146 and 147.
[Docker.DotNet 00:00:02.58] CRLF found. Consumed 15 bytes. New offset: 148, Remaining count: 80.
[Docker.DotNet 00:00:02.58] String from positions 133 to 146 (length 13): 'Ostype: linux'.
[Docker.DotNet 00:00:02.58] Raw buffer content: 'HTTP/1.1 200 OK<CR><LF>Api-Version: 1.45<CR><LF>Content-Type: application/json<CR><LF>Date: Mon, 24 Mar 2025 17:01:11 GMT<CR><LF>Docker-Experimental: false<CR><LF>Ostype: linux<CR><LF>Server: Docker/26.1.5 (linux)<CR><LF>Connection: close<CR><LF>Transfer-Encoding: chunked<CR><LF><CR><LF>'.
[Docker.DotNet 00:00:02.58] CRLF found at positions 177 and 178.
[Docker.DotNet 00:00:02.58] CRLF found. Consumed 31 bytes. New offset: 179, Remaining count: 49.
[Docker.DotNet 00:00:02.58] String from positions 148 to 177 (length 29): 'Server: Docker/26.1.5 (linux)'.
[Docker.DotNet 00:00:02.58] Raw buffer content: 'HTTP/1.1 200 OK<CR><LF>Api-Version: 1.45<CR><LF>Content-Type: application/json<CR><LF>Date: Mon, 24 Mar 2025 17:01:11 GMT<CR><LF>Docker-Experimental: false<CR><LF>Ostype: linux<CR><LF>Server: Docker/26.1.5 (linux)<CR><LF>Connection: close<CR><LF>Transfer-Encoding: chunked<CR><LF><CR><LF>'.
[Docker.DotNet 00:00:02.58] CRLF found at positions 196 and 197.
[Docker.DotNet 00:00:02.58] CRLF found. Consumed 19 bytes. New offset: 198, Remaining count: 30.
[Docker.DotNet 00:00:02.58] String from positions 179 to 196 (length 17): 'Connection: close'.
[Docker.DotNet 00:00:02.58] Raw buffer content: 'HTTP/1.1 200 OK<CR><LF>Api-Version: 1.45<CR><LF>Content-Type: application/json<CR><LF>Date: Mon, 24 Mar 2025 17:01:11 GMT<CR><LF>Docker-Experimental: false<CR><LF>Ostype: linux<CR><LF>Server: Docker/26.1.5 (linux)<CR><LF>Connection: close<CR><LF>Transfer-Encoding: chunked<CR><LF><CR><LF>'.
[Docker.DotNet 00:00:02.58] CRLF found at positions 224 and 225.
[Docker.DotNet 00:00:02.58] CRLF found. Consumed 28 bytes. New offset: 226, Remaining count: 2.
[Docker.DotNet 00:00:02.58] String from positions 198 to 224 (length 26): 'Transfer-Encoding: chunked'.
[Docker.DotNet 00:00:02.58] Raw buffer content: 'HTTP/1.1 200 OK<CR><LF>Api-Version: 1.45<CR><LF>Content-Type: application/json<CR><LF>Date: Mon, 24 Mar 2025 17:01:11 GMT<CR><LF>Docker-Experimental: false<CR><LF>Ostype: linux<CR><LF>Server: Docker/26.1.5 (linux)<CR><LF>Connection: close<CR><LF>Transfer-Encoding: chunked<CR><LF><CR><LF>'.
[Docker.DotNet 00:00:02.58] CRLF found at positions 226 and 227.
[Docker.DotNet 00:00:02.58] CRLF found. Consumed 2 bytes. New offset: 228, Remaining count: 0.
[Docker.DotNet 00:00:02.58] String from positions 226 to 226 (length 0): ''.
[Docker.DotNet 00:00:03.70] Raw buffer content: '145d<CR><LF>{"Id":"f878cff49979e300fe4d5ee693234434f55a1a212f8c83adfe5b1c76e8e8252c","Created":"2025-03-24T17:01:11.726907832Z","Path":"docker-entrypoint.sh","Args":["postgres"],"State":{"Status":"created","Running":false,"Paused":false,"Restarting":false,"OOMKilled":false,"Dead":false,"Pid":0,"ExitCode":0,"Error":"","StartedAt":"0001-01-01T00:00:00Z","FinishedAt":"0001-01-01T00:00:00Z"},"Image":"sha256:0150e3200277b907866758e22a3b9bba7857325b994848fe9f44b3610c3ae17e","ResolvConfPath":"","HostnamePath":"","HostsPath":"","LogPath":"","Name":"/flamboyant_matsumoto","RestartCount":0,"Driver":"overlay2","Platform":"linux","MountLabel":"","ProcessLabel":"","AppArmorProfile":"","ExecIDs":null,"HostConfig":{"Binds":null,"ContainerIDFile":"","LogConfig":{"Type":"json-file","Config":{}},"NetworkMode":"bridge","PortBindings":null,"RestartPolicy":{"Name":"no","MaximumRetryCount":0},"AutoRemove":false,"VolumeDriver":"","VolumesFrom":null,"ConsoleSize":[0,0],"CapAdd":null,"CapDrop":null,"CgroupnsMode":"host","Dns":null,"DnsOptions":null,"DnsSearch":null,"ExtraHosts":null,"GroupAdd":null,"IpcMode":"private","Cgroup":"","Links":null,"OomScoreAdj":0,"PidMode":"","Privileged":false,"PublishAllPorts":false,"ReadonlyRootfs":false,"SecurityOpt":null,"UTSMode":"","UsernsMode":"","ShmSize":67108864,"Runtime":"runc","Isolation":"","CpuShares":0,"Memory":0,"NanoCpus":0,"CgroupParent":"","BlkioWeight":0,"BlkioWeightDevice":null,"BlkioDeviceReadBps":null,"BlkioDeviceWriteBps":null,"BlkioDeviceReadIOps":null,"BlkioDeviceWriteIOps":null,"CpuPeriod":0,"CpuQuota":0,"CpuRealtimePeriod":0,"CpuRealtimeRuntime":0,"CpusetCpus":"","CpusetMems":"","Devices":null,"DeviceCgroupRules":null,"DeviceRequests":null,"MemoryReservation":0,"MemorySwap":0,"MemorySwappiness":null,"OomKillDisable":false,"PidsLimit":null,"Ulimits":null,"CpuCount":0,"CpuPercent":0,"IOMaximumIOps":0,"IOMaximumBandwidth":0,"MaskedPaths":["/proc/asound","/proc/acpi","/proc/kcore","/proc/keys","/proc/latency_stats","/proc/timer_list","/proc/timer_stats","/proc/sched_debug","/proc/scsi","/sys/firmware","/sys/devices/virtual/powercap"],"ReadonlyPaths":["/proc/bus","/proc/fs","/proc/irq","/proc/sys","/proc/sysrq-trigger"]},"GraphDriver":{"Data":{"LowerDir":"/var/lib/docker/overlay2/b2e7e3afa9b90e8acfc41411531d0d0345b504d8ce7b00053a0fc6c67d984081-init/diff:/var/lib/docker/overlay2/b11a76ed7876078226874069c4659d92e212313a01a6756d1022059021adee47/diff:/var/lib/docker/overlay2/a86f1e8914bbe458402755a5b621e47585f9625bbb6c69893d8516658930dbe9/diff:/var/lib/docker/overlay2/41b80a34527860c550c0a4947fa7b0c3e76c8366350c3b80580f4ccbafcfb6a4/diff:/var/lib/docker/overlay2/9bce3631b6196054c6871753b565a9377b98b95282e67e0e8e3495f56df59d59/diff:/var/lib/docker/overlay2/83b9142c71105a37eaac927b03f6e46a8125b34593a065c6ba3acc1f781cac0b/diff:/var/lib/docker/overlay2/de79a2dfb2a28a9cba3642871b9c96664256bb8131e78133a0fd15c8ab8e9310/diff:/var/lib/docker/overlay2/04e350801675cda5e3da22cd3eb57430f385c24e02c96fdf5c7f3d11bcdd3710/diff:/var/lib/docker/overlay2/4024b990a94825b7ceece93e209e5ae6bcc6eb9d63a6cf9143e293c4ecbddfea/diff:/var/lib/docker/overlay2/52b888f17ab044424c968bba1b8f7f121775376303ccf9345862ee0d1d0df449/diff:/var/lib/docker/overlay2/2e07778dda591de6f675ed15d6b575d4d75447dd42e3cca8336a03eb72fe82f2/diff","MergedDir":"/var/lib/docker/overlay2/b2e7e3afa9b90e8acfc41411531d0d0345b504d8ce7b00053a0fc6c67d984081/merged","UpperDir":"/var/lib/docker/overlay2/b2e7e3afa9b90e8acfc41411531d0d0345b504d8ce7b00053a0fc6c67d984081/diff","WorkDir":"/var/lib/docker/overlay2/b2e7e3afa9b90e8acfc41411531d0d0345b504d8ce7b00053a0fc6c67d984081/work"},"Name":"overlay2"},"Mounts":[{"Type":"volume","Name":"f91e583821b473f2d968134f2a722083c39bb4f951d3b40dba4d8f3c81d775cf","Source":"/var/lib/docker/volumes/f91e583821b473f2d968134f2a722083c39bb4f951d3b40dba4d8f3c81d775cf/_data","Destination":"/var/lib/postgresql/data","Driver":"local","Mode":"","RW":true,"Propagation":""}],"Config":{"Hostname":"f878cff49979","Domainname":"","User":"","AttachStdin":false,"AttachStdout":false,"AttachStderr":false,"ExposedPorts":{"5432/tcp":{}},"Tty":false,"OpenStdin":'.
[Docker.DotNet 00:00:03.70] CRLF found at positions 4 and 5.
[Docker.DotNet 00:00:03.70] CRLF found. Consumed 6 bytes. New offset: 6, Remaining count: 4090.
[Docker.DotNet 00:00:03.70] String from positions 0 to 4 (length 4): '145d'.
[Docker.DotNet 00:00:04.88] Raw buffer content: '<CR><LF>false,"StdinOnce":false,"Env":["PATH=/usr/local/sbin:/usr/local/bin:/usr/sbin:/usr/bin:/sbin:/bin","GOSU_VERSION=1.17","LANG=en_US.utf8","PG_MAJOR=17","PG_VERSION=17.4","PG_SHA256=c4605b73fea11963406699f949b966e5d173a7ee0ccaef8938dec0ca8a995fe7","DOCKER_PG_LLVM_DEPS=llvm19-dev \t\tclang19","PGDATA=/var/lib/postgresql/data"],"Cmd":["postgres"],"Image":"postgres:alpine","Volumes":{"/var/lib/postgresql/data":{}},"WorkingDir":"/","Entrypoint":["docker-entrypoint.sh"],"OnBuild":null,"Labels":{},"StopSignal":"SIGINT"},"NetworkSettings":{"Bridge":"","SandboxID":"","SandboxKey":"","Ports":{},"HairpinMode":false,"LinkLocalIPv6Address":"","LinkLocalIPv6PrefixLen":0,"SecondaryIPAddresses":null,"SecondaryIPv6Addresses":null,"EndpointID":"","Gateway":"","GlobalIPv6Address":"","GlobalIPv6PrefixLen":0,"IPAddress":"","IPPrefixLen":0,"IPv6Gateway":"","MacAddress":"","Networks":{"bridge":{"IPAMConfig":null,"Links":null,"Aliases":null,"MacAddress":"","NetworkID":"","EndpointID":"","Gateway":"","IPAddress":"","IPPrefixLen":0,"IPv6Gateway":"","GlobalIPv6Address":"","GlobalIPv6PrefixLen":0,"DriverOpts":null,"DNSNames":null}}}}<LF><CR><LF>0<CR><LF><CR><LF>omScoreAdj":0,"PidMode":"","Privileged":false,"PublishAllPorts":false,"ReadonlyRootfs":false,"SecurityOpt":null,"UTSMode":"","UsernsMode":"","ShmSize":67108864,"Runtime":"runc","Isolation":"","CpuShares":0,"Memory":0,"NanoCpus":0,"CgroupParent":"","BlkioWeight":0,"BlkioWeightDevice":null,"BlkioDeviceReadBps":null,"BlkioDeviceWriteBps":null,"BlkioDeviceReadIOps":null,"BlkioDeviceWriteIOps":null,"CpuPeriod":0,"CpuQuota":0,"CpuRealtimePeriod":0,"CpuRealtimeRuntime":0,"CpusetCpus":"","CpusetMems":"","Devices":null,"DeviceCgroupRules":null,"DeviceRequests":null,"MemoryReservation":0,"MemorySwap":0,"MemorySwappiness":null,"OomKillDisable":false,"PidsLimit":null,"Ulimits":null,"CpuCount":0,"CpuPercent":0,"IOMaximumIOps":0,"IOMaximumBandwidth":0,"MaskedPaths":["/proc/asound","/proc/acpi","/proc/kcore","/proc/keys","/proc/latency_stats","/proc/timer_list","/proc/timer_stats","/proc/sched_debug","/proc/scsi","/sys/firmware","/sys/devices/virtual/powercap"],"ReadonlyPaths":["/proc/bus","/proc/fs","/proc/irq","/proc/sys","/proc/sysrq-trigger"]},"GraphDriver":{"Data":{"LowerDir":"/var/lib/docker/overlay2/b2e7e3afa9b90e8acfc41411531d0d0345b504d8ce7b00053a0fc6c67d984081-init/diff:/var/lib/docker/overlay2/b11a76ed7876078226874069c4659d92e212313a01a6756d1022059021adee47/diff:/var/lib/docker/overlay2/a86f1e8914bbe458402755a5b621e47585f9625bbb6c69893d8516658930dbe9/diff:/var/lib/docker/overlay2/41b80a34527860c550c0a4947fa7b0c3e76c8366350c3b80580f4ccbafcfb6a4/diff:/var/lib/docker/overlay2/9bce3631b6196054c6871753b565a9377b98b95282e67e0e8e3495f56df59d59/diff:/var/lib/docker/overlay2/83b9142c71105a37eaac927b03f6e46a8125b34593a065c6ba3acc1f781cac0b/diff:/var/lib/docker/overlay2/de79a2dfb2a28a9cba3642871b9c96664256bb8131e78133a0fd15c8ab8e9310/diff:/var/lib/docker/overlay2/04e350801675cda5e3da22cd3eb57430f385c24e02c96fdf5c7f3d11bcdd3710/diff:/var/lib/docker/overlay2/4024b990a94825b7ceece93e209e5ae6bcc6eb9d63a6cf9143e293c4ecbddfea/diff:/var/lib/docker/overlay2/52b888f17ab044424c968bba1b8f7f121775376303ccf9345862ee0d1d0df449/diff:/var/lib/docker/overlay2/2e07778dda591de6f675ed15d6b575d4d75447dd42e3cca8336a03eb72fe82f2/diff","MergedDir":"/var/lib/docker/overlay2/b2e7e3afa9b90e8acfc41411531d0d0345b504d8ce7b00053a0fc6c67d984081/merged","UpperDir":"/var/lib/docker/overlay2/b2e7e3afa9b90e8acfc41411531d0d0345b504d8ce7b00053a0fc6c67d984081/diff","WorkDir":"/var/lib/do

Sign up for free to join this conversation on GitHub. Already have an account? Sign in to comment
Labels
bug Something isn't working help wanted Extra attention is needed
Projects
None yet
Development

No branches or pull requests

2 participants