-
Notifications
You must be signed in to change notification settings - Fork 2.4k
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
Bump Traefik to v2.2.3 #8329
Bump Traefik to v2.2.3 #8329
Conversation
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
LGTM
Diff for a967a0c:diff --git a/_bashbrew-cat b/_bashbrew-cat
index 78ea984..128297c 100644
--- a/_bashbrew-cat
+++ b/_bashbrew-cat
@@ -1,13 +1,13 @@
Maintainers: Emile Vauge <emile@vauge.com> (@emilevauge), Vincent Demeester <vincent@sbr.pm> (@vdemeester), Ludovic Fernandez <ludovic@containo.us> (@ldez), Julien Salleyron <julien@containo.us> (@juliens), Nicolas Mengin <nicolas@containo.us> (@nmengin), Michael Matur <michael@containo.us> (@mmatur)
GitRepo: https://github.com/containous/traefik-library-image.git
-Tags: v2.2.2, 2.2.2, v2.2, 2.2, chevrotin, latest
+Tags: v2.2.3, 2.2.3, v2.2, 2.2, chevrotin, latest
Architectures: amd64, arm32v6, arm64v8
-GitCommit: 296caddf8ba97b52841872b2192758af9e9d7775
+GitCommit: afd07131364252ecf9c43a202f9f5151b0cb0bb9
Directory: alpine
-Tags: v2.2.2-windowsservercore-1809, 2.2.2-windowsservercore-1809, v2.2-windowsservercore-1809, 2.2-windowsservercore-1809, chevrotin-windowsservercore-1809, windowsservercore-1809
+Tags: v2.2.3-windowsservercore-1809, 2.2.3-windowsservercore-1809, v2.2-windowsservercore-1809, 2.2-windowsservercore-1809, chevrotin-windowsservercore-1809, windowsservercore-1809
Architectures: windows-amd64
-GitCommit: 296caddf8ba97b52841872b2192758af9e9d7775
+GitCommit: afd07131364252ecf9c43a202f9f5151b0cb0bb9
Directory: windows/1809
Constraints: windowsservercore-1809
diff --git a/_bashbrew-list b/_bashbrew-list
index 0272c2f..629578b 100644
--- a/_bashbrew-list
+++ b/_bashbrew-list
@@ -1,12 +1,12 @@
traefik:2.2
traefik:2.2-windowsservercore-1809
-traefik:2.2.2
-traefik:2.2.2-windowsservercore-1809
+traefik:2.2.3
+traefik:2.2.3-windowsservercore-1809
traefik:chevrotin
traefik:chevrotin-windowsservercore-1809
traefik:latest
traefik:v2.2
traefik:v2.2-windowsservercore-1809
-traefik:v2.2.2
-traefik:v2.2.2-windowsservercore-1809
+traefik:v2.2.3
+traefik:v2.2.3-windowsservercore-1809
traefik:windowsservercore-1809
diff --git a/traefik_latest/Dockerfile b/traefik_latest/Dockerfile
index 2c67462..bafb159 100644
--- a/traefik_latest/Dockerfile
+++ b/traefik_latest/Dockerfile
@@ -8,7 +8,7 @@ RUN set -ex; \
x86_64) arch='amd64' ;; \
*) echo >&2 "error: unsupported architecture: $apkArch"; exit 1 ;; \
esac; \
- wget --quiet -O /tmp/traefik.tar.gz "https://github.com/containous/traefik/releases/download/v2.2.2/traefik_v2.2.2_linux_$arch.tar.gz"; \
+ wget --quiet -O /tmp/traefik.tar.gz "https://github.com/containous/traefik/releases/download/v2.2.3/traefik_v2.2.3_linux_$arch.tar.gz"; \
tar xzvf /tmp/traefik.tar.gz -C /usr/local/bin traefik; \
rm -f /tmp/traefik.tar.gz; \
chmod +x /usr/local/bin/traefik
@@ -22,5 +22,5 @@ LABEL org.opencontainers.image.vendor="Containous" \
org.opencontainers.image.url="https://traefik.io" \
org.opencontainers.image.title="Traefik" \
org.opencontainers.image.description="A modern reverse-proxy" \
- org.opencontainers.image.version="v2.2.2" \
+ org.opencontainers.image.version="v2.2.3" \
org.opencontainers.image.documentation="https://docs.traefik.io"
diff --git a/traefik_windowsservercore-1809/Dockerfile b/traefik_windowsservercore-1809/Dockerfile
index 5929179..11398aa 100644
--- a/traefik_windowsservercore-1809/Dockerfile
+++ b/traefik_windowsservercore-1809/Dockerfile
@@ -3,12 +3,14 @@ FROM mcr.microsoft.com/windows/servercore:1809
SHELL ["powershell", "-Command", "$ErrorActionPreference = 'Stop'; $ProgressPreference = 'SilentlyContinue';"]
RUN Invoke-WebRequest \
- -Uri "https://github.com/containous/traefik/releases/download/v2.2.2/traefik_v2.2.2_windows_amd64.zip" \
+ -Uri "https://github.com/containous/traefik/releases/download/v2.2.3/traefik_v2.2.3_windows_amd64.zip" \
-OutFile "/traefik.zip"; \
Expand-Archive -Path "/traefik.zip" -DestinationPath "/" -Force; \
Remove-Item "/traefik.zip" -Force
+COPY entrypoint.ps1 /
EXPOSE 80
+ENTRYPOINT [ "powershell.exe", "/entrypoint.ps1" ]
CMD ["/traefik"]
# Metadata
@@ -16,5 +18,5 @@ LABEL org.opencontainers.image.vendor="Containous" \
org.opencontainers.image.url="https://traefik.io" \
org.opencontainers.image.title="Traefik" \
org.opencontainers.image.description="A modern reverse-proxy" \
- org.opencontainers.image.version="v2.2.2" \
+ org.opencontainers.image.version="v2.2.3" \
org.opencontainers.image.documentation="https://docs.traefik.io"
diff --git a/traefik_windowsservercore-1809/entrypoint.ps1 b/traefik_windowsservercore-1809/entrypoint.ps1
new file mode 100644
index 0000000..a5f6207
--- /dev/null
+++ b/traefik_windowsservercore-1809/entrypoint.ps1
@@ -0,0 +1,19 @@
+if ($null -eq $args[0]) {
+ /traefik
+ exit $LASTEXITCODE
+}
+
+if ($args[0].StartsWith("-")) {
+ /traefik $args
+ exit $LASTEXITCODE
+}
+
+(/traefik $args[0] --help 2>&1>$null)
+
+if ($LASTEXITCODE -eq 0) {
+ /traefik $args
+ exit $LASTEXITCODE
+}
+
+Invoke-Expression "$args"
+exit $LASTEXITCODE
\ No newline at end of file |
Regarding an entrypoint script in Windows containers.
What this means is that both the resident powershell and the traefik process get the signal to exit at the same time, so there is a race. One effect is that the On one $ docker run -it --rm --name test traefik:windowsservercore-1809
runtime: bad pointer in frame github.com/konsorten/go-windows-terminal-sequences.EnableVirtualTerminalProcessing at 0xc00064d680: 0x54
fatal error: invalid pointer found on stack
runtime stack:
runtime.throw(0x29125ef, 0x1e)
/usr/local/go/src/runtime/panic.go:1116 +0x79 fp=0x2a9ff7b8 sp=0x2a9ff788 pc=0x438729
runtime.adjustpointers(0xc00064d680, 0x2a9ff8b8, 0x2a9ffc48, 0x3275720, 0x43bbf20)
/usr/local/go/src/runtime/stack.go:599 +0x22e fp=0x2a9ff818 sp=0x2a9ff7b8 pc=0x44f66e
runtime.adjustframe(0x2a9ffb58, 0x2a9ffc48, 0x43bbf20)
/usr/local/go/src/runtime/stack.go:641 +0x355 fp=0x2a9ff8e8 sp=0x2a9ff818 pc=0x44f9d5
runtime.gentraceback(0xffffffffffffffff, 0xffffffffffffffff, 0x0, 0xc000648180, 0x0, 0x0, 0x7fffffff, 0x29f79c8, 0x2a9ffc48, 0x0, ...)
/usr/local/go/src/runtime/traceback.go:334 +0x111c fp=0x2a9ffbc0 sp=0x2a9ff8e8 pc=0x45e3bc
runtime.copystack(0xc000648180, 0x4000)
/usr/local/go/src/runtime/stack.go:888 +0x298 fp=0x2a9ffd78 sp=0x2a9ffbc0 pc=0x4500f8
runtime.newstack()
/usr/local/go/src/runtime/stack.go:1043 +0x219 fp=0x2a9fff08 sp=0x2a9ffd78 pc=0x4503c9
runtime.morestack()
/usr/local/go/src/runtime/asm_amd64.s:449 +0x97 fp=0x2a9fff10 sp=0x2a9fff08 pc=0x467a57
goroutine 33 [copystack]:
runtime.concatstring2(0xc00064d3b0, 0x28e0d9b, 0xc, 0x28d0411, 0x1, 0x10, 0x0)
/usr/local/go/src/runtime/string.go:57 +0x71 fp=0xc00064d378 sp=0xc00064d370 pc=0x451e91
syscall.UTF16FromString(0x28e0d9b, 0xc, 0x0, 0x0, 0x13400000007, 0x0, 0xc000048ec0)
/usr/local/go/src/syscall/syscall_windows.go:45 +0xcc fp=0xc00064d460 sp=0xc00064d378 pc=0x48019c
syscall.UTF16PtrFromString(...)
/usr/local/go/src/syscall/syscall_windows.go:91
syscall.LoadDLL(0x28e0d9b, 0xc, 0xc000263558, 0x4426c3, 0xc000648180)
/usr/local/go/src/syscall/dll_windows.go:69 +0x54 fp=0xc00064d518 sp=0xc00064d460 pc=0x47a9b4
syscall.(*LazyDLL).Load(0xc000004660, 0x0, 0x0)
/usr/local/go/src/syscall/dll_windows.go:236 +0xc7 fp=0xc00064d568 sp=0xc00064d518 pc=0x47c7c7
syscall.(*LazyProc).Find(0xc000123ef0, 0x0, 0x0)
/usr/local/go/src/syscall/dll_windows.go:291 +0xbe fp=0xc00064d5c0 sp=0xc00064d568 pc=0x47cabe
syscall.(*LazyProc).mustFind(0xc000123ef0)
/usr/local/go/src/syscall/dll_windows.go:309 +0x32 fp=0xc00064d5e8 sp=0xc00064d5c0 pc=0x47cbe2
syscall.(*LazyProc).Call(0xc000123ef0, 0xc0003f9f90, 0x2, 0x2, 0x29f7d40, 0xc0002636b8, 0x486ba6, 0x7ff915022a90)
/usr/local/go/src/syscall/dll_windows.go:327 +0x36 fp=0xc00064d638 sp=0xc00064d5e8 pc=0x47ccb6
github.com/konsorten/go-windows-terminal-sequences.EnableVirtualTerminalProcessing(0x54, 0x1, 0x0, 0xc0002636ec)
/go/pkg/mod/github.com/konsorten/go-windows-terminal-sequences@v1.0.2/sequences.go:30 +0xcb fp=0xc00064d698 sp=0xc00064d638 pc=0x77b7ab
github.com/sirupsen/logrus.initTerminal(0x2dedb40, 0xc000006018)
/go/pkg/mod/github.com/sirupsen/logrus@v1.4.2/terminal_check_windows.go:16 +0x64 fp=0xc00064d6c8 sp=0xc00064d698 pc=0x782524
github.com/sirupsen/logrus.checkIfTerminal(0x2dedb40, 0xc000006018, 0x160108)
/go/pkg/mod/github.com/sirupsen/logrus@v1.4.2/terminal_check_windows.go:31 +0xb4 fp=0xc00064d700 sp=0xc00064d6c8 pc=0x782604
github.com/sirupsen/logrus.(*TextFormatter).init(...)
/go/pkg/mod/github.com/sirupsen/logrus@v1.4.2/text_formatter.go:86
github.com/sirupsen/logrus.(*TextFormatter).Format.func1()
/go/pkg/mod/github.com/sirupsen/logrus@v1.4.2/text_formatter.go:170 +0x58 fp=0xc00064d730 sp=0xc00064d700 pc=0x785df8
sync.(*Once).doSlow(0xc00009c4f0, 0xc000263960)
/usr/local/go/src/sync/once.go:66 +0xf3 fp=0xc00064d780 sp=0xc00064d730 pc=0x4787f3
sync.(*Once).Do(...)
/usr/local/go/src/sync/once.go:57
github.com/sirupsen/logrus.(*TextFormatter).Format(0xc00009c4b0, 0xc00056ccb0, 0xc000263d38, 0x785c94, 0x25e1940, 0xc00020c120, 0xc000263d80)
/go/pkg/mod/github.com/sirupsen/logrus@v1.4.2/text_formatter.go:170 +0xf1d fp=0xc00064dd08 sp=0xc00064d780 pc=0x7836dd
github.com/sirupsen/logrus.(*Entry).write(0xc00056ccb0)
/go/pkg/mod/github.com/sirupsen/logrus@v1.4.2/entry.go:255 +0x83 fp=0xc00064dd90 sp=0xc00064dd08 pc=0x77d063
github.com/sirupsen/logrus.Entry.log(0xc000168000, 0xc000215fb0, 0x0, 0x0, 0x0, 0x0, 0x0, 0x0, 0x0, 0x0, ...)
/go/pkg/mod/github.com/sirupsen/logrus@v1.4.2/entry.go:231 +0x1a5 fp=0xc00064de08 sp=0xc00064dd90 pc=0x77cd05
github.com/sirupsen/logrus.(*Entry).Log(0xc00056cfc0, 0x2, 0xc00023a680, 0x1, 0x1)
/go/pkg/mod/github.com/sirupsen/logrus@v1.4.2/entry.go:268 +0xf2 fp=0xc00064df10 sp=0xc00064de08 pc=0x77d2f2
github.com/sirupsen/logrus.(*Entry).Error(0xc00056cfc0, 0xc00023a680, 0x1, 0x1)
/go/pkg/mod/github.com/sirupsen/logrus@v1.4.2/entry.go:297 +0x58 fp=0xc00064df48 sp=0xc00064df10 pc=0x77d608
github.com/containous/traefik/v2/pkg/server.(*TCPEntryPoint).Start(0xc000644500, 0x2e52320, 0xc0000e0030)
/go/src/github.com/containous/traefik/pkg/server/server_entrypoint_tcp.go:168 +0x169 fp=0xc00064dfc8 sp=0xc00064df48 pc=0x20fa079
runtime.goexit()
/usr/local/go/src/runtime/asm_amd64.s:1373 +0x1 fp=0xc00064dfd0 sp=0xc00064dfc8 pc=0x469a81
created by github.com/containous/traefik/v2/pkg/server.TCPEntryPoints.Start
/go/src/github.com/containous/traefik/pkg/server/server_entrypoint_tcp.go:81 +0x143
goroutine 1 [chan receive]:
runtime.gopark(0x29f7a38, 0xc00019e2f8, 0x170e, 0x2)
/usr/local/go/src/runtime/proc.go:304 +0xf5 fp=0xc00069fba8 sp=0xc00069fb88 pc=0x43b195
runtime.chanrecv(0xc00019e2a0, 0x0, 0x1, 0x0)
/usr/local/go/src/runtime/chan.go:525 +0x2f5 fp=0xc00069fc38 sp=0xc00069fba8 pc=0x4062f5
runtime.chanrecv1(0xc00019e2a0, 0x0)
/usr/local/go/src/runtime/chan.go:407 +0x2b fp=0xc00069fc68 sp=0xc00069fc38 pc=0x405fab
github.com/containous/traefik/v2/pkg/server.(*Server).Wait(...)
/go/src/github.com/containous/traefik/pkg/server/server.go:69
main.runCmd(0xc00056ccb0, 0x0, 0x0)
/go/src/github.com/containous/traefik/cmd/traefik/traefik.go:159 +0x560 fp=0xc00069fd88 sp=0xc00069fc68 pc=0x2103840
main.main.func1(0xc0000521f0, 0x0, 0x0, 0x0, 0xc00017e380)
/go/src/github.com/containous/traefik/cmd/traefik/traefik.go:55 +0x33 fp=0xc00069fdb0 sp=0xc00069fd88 pc=0x2107793
github.com/containous/traefik/v2/pkg/cli.run(0xc00017e380, 0xc0000521f0, 0x0, 0x0, 0x8, 0xc000554430)
/go/src/github.com/containous/traefik/pkg/cli/commands.go:133 +0x173 fp=0xc00069fe28 sp=0xc00069fdb0 pc=0x1ff1ce3
github.com/containous/traefik/v2/pkg/cli.execute(0xc00017e380, 0xc0000521f0, 0x1, 0x1, 0x447a01, 0x439f2a0, 0xc000067f78)
/go/src/github.com/containous/traefik/pkg/cli/commands.go:57 +0x8f1 fp=0xc00069ff00 sp=0xc00069fe28 pc=0x1ff1a11
github.com/containous/traefik/v2/pkg/cli.Execute(...)
/go/src/github.com/containous/traefik/pkg/cli/commands.go:51
main.main()
/go/src/github.com/containous/traefik/cmd/traefik/traefik.go:71 +0x3f9 fp=0xc00069ff88 sp=0xc00069ff00 pc=0x2103159
runtime.main()
/usr/local/go/src/runtime/proc.go:203 +0x1fa fp=0xc00069ffe0 sp=0xc00069ff88 pc=0x43adda
runtime.goexit()
/usr/local/go/src/runtime/asm_amd64.s:1373 +0x1 fp=0xc00069ffe8 sp=0xc00069ffe0 pc=0x469a81
goroutine 2 [force gc (idle)]:
runtime.gopark(0x29f7c58, 0x47bd0c0, 0x1411, 0x1)
/usr/local/go/src/runtime/proc.go:304 +0xf5 fp=0xc000063fb0 sp=0xc000063f90 pc=0x43b195
runtime.goparkunlock(...)
/usr/local/go/src/runtime/proc.go:310
runtime.forcegchelper()
/usr/local/go/src/runtime/proc.go:253 +0xc5 fp=0xc000063fe0 sp=0xc000063fb0 pc=0x43b035
runtime.goexit()
/usr/local/go/src/runtime/asm_amd64.s:1373 +0x1 fp=0xc000063fe8 sp=0xc000063fe0 pc=0x469a81
created by runtime.init.6
/usr/local/go/src/runtime/proc.go:242 +0x3c
$ echo $?
235 |
Hello, we added this script because of the change of the validation process of the windows based official image. Those changes force us to remove Traefik v1 from the manifest (#8322) and to add this script. We are not Windows and PowerShell specialists, but we have to keep a consistent behavior to don't break our user infrastructure. Do you have a suggestion to follow your new validation rules and don't break our current behavior? |
I'd suggest we add the following in # https://github.com/docker-library/official-images/pull/8329#issuecomment-656383836
[traefik:windowsservercore_override-cmd]=1
ala: ...
[nats-streaming:windowsservercore_override-cmd]=1
# https://github.com/docker-library/official-images/pull/8329#issuecomment-656383836
[traefik:windowsservercore_override-cmd]=1
# TODO adjust MongoDB tests to use docker networks instead of links so they can work on Windows (and consider using PowerShell to generate appropriate certificates for TLS tests instead of openssl)
[mongo:windowsservercore_mongo-basics]=1
... (Then, revert to |
Thank you for the suggestion 👍 I will have to open another PR because I don't have write access to my colleague fork and it's 2:30am for us, I can not wake up my colleague. I will edit |
the new PR is #8333 |
Hello,
This PR updates Traefik to v2.2.3.
/cc @ldez @mmatur @SantoDE
Cheers