aboutsummaryrefslogtreecommitdiffstats
path: root/modules
diff options
context:
space:
mode:
authorzeripath <art27@cantab.net>2020-04-27 01:01:06 +0100
committerGitHub <noreply@github.com>2020-04-26 21:01:06 -0300
commit0e799c26ba322e8e1dd1e5acd1367341c0452987 (patch)
tree4fef486d5db4e7463563bf3ba327bd9f906ba11b /modules
parent9f959ac0641821148e46d0899b74cc714c858879 (diff)
downloadgitea-0e799c26ba322e8e1dd1e5acd1367341c0452987.tar.gz
gitea-0e799c26ba322e8e1dd1e5acd1367341c0452987.zip
Prevent panic during wrappedConn close at hammertime (#11219)
* Prevent panic during wrappedConn close at hammertime Signed-off-by: Andrew Thornton <art27@cantab.net> * Update modules/graceful/server.go * Fix extraneous debug in goldmark.go Signed-off-by: Andrew Thornton <art27@cantab.net>
Diffstat (limited to 'modules')
-rw-r--r--modules/graceful/server.go11
-rw-r--r--modules/markup/markdown/goldmark.go1
2 files changed, 11 insertions, 1 deletions
diff --git a/modules/graceful/server.go b/modules/graceful/server.go
index 09be933999..4d0d8677f0 100644
--- a/modules/graceful/server.go
+++ b/modules/graceful/server.go
@@ -250,6 +250,17 @@ type wrappedConn struct {
func (w wrappedConn) Close() error {
if atomic.CompareAndSwapInt32(w.closed, 0, 1) {
+ defer func() {
+ if err := recover(); err != nil {
+ select {
+ case <-GetManager().IsHammer():
+ // Likely deadlocked request released at hammertime
+ log.Warn("Panic during connection close! %v. Likely there has been a deadlocked request which has been released by forced shutdown.", err)
+ default:
+ log.Error("Panic during connection close! %v", err)
+ }
+ }
+ }()
w.server.wg.Done()
}
return w.Conn.Close()
diff --git a/modules/markup/markdown/goldmark.go b/modules/markup/markdown/goldmark.go
index 8974504a79..6a40a86836 100644
--- a/modules/markup/markdown/goldmark.go
+++ b/modules/markup/markdown/goldmark.go
@@ -328,7 +328,6 @@ func (r *HTMLRenderer) renderIcon(w util.BufWriter, source []byte, node ast.Node
func (r *HTMLRenderer) renderTaskCheckBoxListItem(w util.BufWriter, source []byte, node ast.Node, entering bool) (ast.WalkStatus, error) {
n := node.(*TaskCheckBoxListItem)
if entering {
- n.Dump(source, 0)
if n.Attributes() != nil {
_, _ = w.WriteString("<li")
html.RenderAttributes(w, n, html.ListItemAttributeFilter)