Merge pull request #130252 from fuweid/1.31-backport-130126
[release-1.31] proxy: should add PingPeriod for websocket translator
This commit is contained in:
		| @@ -21,6 +21,7 @@ import ( | |||||||
| 	"net/http" | 	"net/http" | ||||||
| 	"net/url" | 	"net/url" | ||||||
| 	"strconv" | 	"strconv" | ||||||
|  | 	"time" | ||||||
|  |  | ||||||
| 	"github.com/mxk/go-flowrate/flowrate" | 	"github.com/mxk/go-flowrate/flowrate" | ||||||
| 	apierrors "k8s.io/apimachinery/pkg/api/errors" | 	apierrors "k8s.io/apimachinery/pkg/api/errors" | ||||||
| @@ -70,7 +71,7 @@ func (h *StreamTranslatorHandler) ServeHTTP(w http.ResponseWriter, req *http.Req | |||||||
| 	defer websocketStreams.conn.Close() | 	defer websocketStreams.conn.Close() | ||||||
|  |  | ||||||
| 	// Creating SPDY executor, ensuring redirects are not followed. | 	// Creating SPDY executor, ensuring redirects are not followed. | ||||||
| 	spdyRoundTripper, err := spdy.NewRoundTripperWithConfig(spdy.RoundTripperConfig{UpgradeTransport: h.Transport}) | 	spdyRoundTripper, err := spdy.NewRoundTripperWithConfig(spdy.RoundTripperConfig{UpgradeTransport: h.Transport, PingPeriod: 5 * time.Second}) | ||||||
| 	if err != nil { | 	if err != nil { | ||||||
| 		websocketStreams.writeStatus(apierrors.NewInternalError(err)) //nolint:errcheck | 		websocketStreams.writeStatus(apierrors.NewInternalError(err)) //nolint:errcheck | ||||||
| 		metrics.IncStreamTranslatorRequest(req.Context(), strconv.Itoa(http.StatusInternalServerError)) | 		metrics.IncStreamTranslatorRequest(req.Context(), strconv.Itoa(http.StatusInternalServerError)) | ||||||
|   | |||||||
| @@ -500,6 +500,16 @@ var _ = SIGDescribe("Kubectl client", func() { | |||||||
| 			} | 			} | ||||||
| 		}) | 		}) | ||||||
|  |  | ||||||
|  | 		// https://issues.k8s.io/128314 | ||||||
|  | 		f.It(f.WithSlow(), "should support exec idle connections", func(ctx context.Context) { | ||||||
|  | 			ginkgo.By("executing a command in the container") | ||||||
|  |  | ||||||
|  | 			execOutput := e2ekubectl.RunKubectlOrDie(ns, "exec", podRunningTimeoutArg, simplePodName, "--", "/bin/sh", "-c", "sleep 320 && echo running in container") | ||||||
|  | 			if expected, got := "running in container", strings.TrimSpace(execOutput); expected != got { | ||||||
|  | 				framework.Failf("Unexpected kubectl exec output. Wanted %q, got %q", expected, got) | ||||||
|  | 			} | ||||||
|  | 		}) | ||||||
|  |  | ||||||
| 		ginkgo.It("should support exec through kubectl proxy", func(ctx context.Context) { | 		ginkgo.It("should support exec through kubectl proxy", func(ctx context.Context) { | ||||||
| 			_ = getTestContextHost() | 			_ = getTestContextHost() | ||||||
|  |  | ||||||
|   | |||||||
		Reference in New Issue
	
	Block a user
	 Kubernetes Prow Robot
					Kubernetes Prow Robot