Sounds like you need to understand your defer issue before making any
changes or updating versions.

On Oct 28, 2016 6:33 AM, "Nigel Vickers" <rhed...@gmail.com> wrote:

> Hallo Brad,
>
> ... thanks for the reply. The original post went under 6 weeks ago and I
> had forgotten it, sorry. We currently have a culprit and a work around, and
> your half right.  The postgres in the backend was running out of
> connections and the errors were not getting to the client. The culprit is
> that a defer db.Close() that was working with 1.4.2 and under certain
> conditions didn't under 1.6.2. The workaround was to explicitly close the
> database connection after every request which works but is not optimal. The
> question is why the defer no longer functioned? Previously each request
> from the client triggered the backend request to the db and completed. We
> can see when it functions but haven't found a way to trap when it should
> but didn't. We can see that the proxy is packing everything into a single
> stream but don't see the relevance. HTTP2 is new for us. If you have any
> immediate suggestions they would gratefully received. However, as Andras
> has indicated, we should be moving to Gowut 1.x.x. This means moving 70000+
> LOC to a new naming system. We have been delaying hoping to use the new
> "alias" feature. This could take some months. We have a workaround and if
> the problems is present after the update we can take it up again.
>
> Rgs, Nigel Vickers
>
>
> On Thursday, 27 October 2016 23:17:38 UTC+2, bradfitz wrote:
>>
>> That isn't an http2 panic. That's just the http2 code recovering your
>> Handler's panic and printing it, the same as the http1 server does.
>>
>> Your panic is actually somewhere in:
>>
>> lib.setupC5Tab(0x7f6fbe169d20, 0xc8201b0d20, 0xc820436d98,
>> 0x7f6fbe169d20, 0xc8201b0dc0, 0x7f6fbe16a2a8, 0xc820339e60, 0x7f6fbe16a5f8,
>> 0xc8201b0e60, 0xc82047be20)
>>         /home/sysop/go/src/lib/rhewocompstatus.go:1310 +0x3976
>> lib.BuildRhewoStatus.func4(0x7f6fbe117538, 0xc8205bc300)
>>         /home/sysop/go/src/lib/rhewocompstatus.go:168 +0xc8
>> github.com/icza/gowut/gwu.handlerFuncWrapper.HandleEvent(0xc82040b5c0,
>> 0x7f6fbe117538, 0xc8205bc300)
>>         /home/sysop/go/src/github.com/icza/gowut/gwu/event.go:441 +0x3e
>> github.com/icza/gowut/gwu.(*compImpl).dispatchEvent(0xc820158770,
>> 0x7f6fbe117538, 0xc8205bc300)
>>         /home/sysop/go/src/github.com/icza/gowut/gwu/comp.go:307 +0x167
>> github.com/icza/gowut/gwu.(*timerImpl).dispatchEvent(0xc820158770,
>> 0x7f6fbe117538, 0xc8205bc300)
>>         <autogenerated>:1302 +0x60
>> github.com/icza/gowut/gwu.(*serverImpl).handleEvent(0xc82019e900,
>> 0x7f6fbe1172c0, 0xc8202fa7e0, 0x7f6fbe169998, 0xc8202b4ff0, 0x7f6fbe117170,
>> 0xc82007c2a0, 0xc820148460)
>>         /home/sysop/go/src/github.com/icza/gowut/gwu/server.go:815
>> +0x103e
>> github.com/icza/gowut/gwu.(*serverImpl).serveHTTP(0xc82019e900,
>> 0x7f6fbe117170, 0xc82007c2a0, 0xc820148460)
>>         /home/sysop/go/src/github.com/icza/gowut/gwu/server.go:683
>> +0x1544
>> github.com/icza/gowut/gwu.(*serverImpl).Start.func1(0x7f6fbe117170,
>> 0xc82007c2a0, 0xc820148460)
>>         /home/sysop/go/src/github.com/icza/gowut/gwu/server.go:483 +0x4c
>>
>>
>> On Thu, Oct 6, 2016 at 3:29 AM, Nigel Vickers <rhe...@gmail.com> wrote:
>>
>>> We are migrating an application from go 1.4.1 to 1.6.2. The application
>>> uses a modified Gowut 0.9 as the framework and initially moved without
>>> issue. The application server runs behind a tls sni
>>> proxy/loadbalancer(slt). While running slt at 1.4.1 and the server at 1.6.2
>>> no problems were encountered. We assume because 1.4.1 couldn’t http2. After
>>> moving the slt to 1.6.2 we are experiencing runtime panics with
>>> http2(protocol attached). Two questions:
>>>
>>> Is the statement that http2 should just run still applicable?
>>> And
>>> Are use cases that fail still of interest as issues?
>>>
>>> We have a “provisional trigger” .  A client xmlHttpRequest triggered by
>>> an attached javascript timer requests a component update and reload from
>>> the server. Currently at 10 second intervals.
>>> Irregularly, between the 90th and 99th request the server panics.
>>>
>>> We are bit stuck because we have no experience with http2. Any
>>> suggestions on how to proceed would be welcome.
>>>
>>> Nigel Vickers
>>>
>>>
>>> Rhewo Dev2016/10/05 14:14:24 serveHTTP Incoming: request Path
>>>  /mainAppWin/e
>>> Rhewo Dev2016/10/05 14:14:24 serveHTTP Incoming: request Body
>>>  &{0xc8205ba120 0xc8200f5180 false 0xc8204e8d00 false}
>>> SessionDump &{LUP_NiaDLsjBFLOpsSUKLa false {63611263456 268951715
>>> 0xf36ee0} {63611266464 12850383 0xf36ee0} map[mainAppWin:0xc8202b4ff0]
>>> map[groups:[free admin] module:Status Lang:de hiddenPan:0xc820476000
>>> ips:xx.xx.xx.xx user:fred2 auth:auth] 14400000000000 0xc820303f20}
>>> Rhewo Dev2016/10/05 14:14:24 serveHTTP appName Parts   3 [ mainAppWin e]
>>> Rhewo Dev2016/10/05 14:14:24    Event from comp: 932  event: 15
>>> 2016/10/05 14:14:24 http2: panic serving xxx.xxx.xxx.xxx:49337: runtime
>>> error: index out of range
>>> goroutine 2962 [running]:
>>> net/http.(*http2serverConn).runHandler.func1(0xc82053df3f,
>>> 0xc8200f5180, 0xc82007c2a0)
>>>         /usr/local/go/src/net/http/h2_bundle.go:4050 +0xde
>>> panic(0xb24060, 0xc82000e0d0)
>>>         /usr/local/go/src/runtime/panic.go:443 +0x521
>>> lib.setupC5Tab(0x7f6fbe169d20, 0xc8201b0d20, 0xc820436d98,
>>> 0x7f6fbe169d20, 0xc8201b0dc0, 0x7f6fbe16a2a8, 0xc820339e60, 0x7f6fbe16a5f8,
>>> 0xc8201b0e60, 0xc82047be20)
>>>         /home/sysop/go/src/lib/rhewocompstatus.go:1310 +0x3976
>>> lib.BuildRhewoStatus.func4(0x7f6fbe117538, 0xc8205bc300)
>>>         /home/sysop/go/src/lib/rhewocompstatus.go:168 +0xc8
>>> github.com/icza/gowut/gwu.handlerFuncWrapper.HandleEvent(0xc82040b5c0,
>>> 0x7f6fbe117538, 0xc8205bc300)
>>>         /home/sysop/go/src/github.com/icza/gowut/gwu/event.go:441 +0x3e
>>> github.com/icza/gowut/gwu.(*compImpl).dispatchEvent(0xc820158770,
>>> 0x7f6fbe117538, 0xc8205bc300)
>>>         /home/sysop/go/src/github.com/icza/gowut/gwu/comp.go:307 +0x167
>>> github.com/icza/gowut/gwu.(*timerImpl).dispatchEvent(0xc820158770,
>>> 0x7f6fbe117538, 0xc8205bc300)
>>>         <autogenerated>:1302 +0x60
>>> github.com/icza/gowut/gwu.(*serverImpl).handleEvent(0xc82019e900,
>>> 0x7f6fbe1172c0, 0xc8202fa7e0, 0x7f6fbe169998, 0xc8202b4ff0, 0x7f6fbe117170,
>>> 0xc82007c2a0, 0xc820148460)
>>>         /home/sysop/go/src/github.com/icza/gowut/gwu/server.go:815
>>> +0x103e
>>> github.com/icza/gowut/gwu.(*serverImpl).serveHTTP(0xc82019e900,
>>> 0x7f6fbe117170, 0xc82007c2a0, 0xc820148460)
>>>         /home/sysop/go/src/github.com/icza/gowut/gwu/server.go:683
>>> +0x1544
>>> github.com/icza/gowut/gwu.(*serverImpl).Start.func1(0x7f6fbe117170,
>>> 0xc82007c2a0, 0xc820148460)
>>>         /home/sysop/go/src/github.com/icza/gowut/gwu/server.go:483 +0x4c
>>> net/http.HandlerFunc.ServeHTTP(0xc82006d450, 0x7f6fbe117170,
>>> 0xc82007c2a0, 0xc820148460)
>>>         /usr/local/go/src/net/http/server.go:1618 +0x48
>>> net/http.(*ServeMux).ServeHTTP(0xc820070b10, 0x7f6fbe117170,
>>> 0xc82007c2a0, 0xc820148460)
>>>         /usr/local/go/src/net/http/server.go:1910 +0x213
>>> net/http.serverHandler.ServeHTTP(0xc8200e4200, 0x7f6fbe117170,
>>> 0xc82007c2a0, 0xc820148460)
>>>         /usr/local/go/src/net/http/server.go:2081 +0x207
>>> net/http.initNPNRequest.ServeHTTP(0xc8201d4300, 0xc8200e4200,
>>> 0x7f6fbe117170, 0xc82007c2a0, 0xc820148460)
>>>         /usr/local/go/src/net/http/server.go:2489 +0x351
>>> net/http.(*initNPNRequest).ServeHTTP(0xc8201d8b20, 0x7f6fbe117170,
>>> 0xc82007c2a0, 0xc820148460)
>>>         <autogenerated>:253 +0xdb
>>> net/http.(Handler).ServeHTTP-fm(0x7f6fbe117170, 0xc82007c2a0, 0xc820
>>>         /usr/local/go/src/net/http/h2_bundle.go:3847 +0x5e
>>> net/http.(*http2serverConn).runHandler(0xc8200f5180, 0xc82007c2a0, 0
>>>         /usr/local/go/src/net/http/h2_bundle.go:4060 +0xad
>>> created by net/http.(*http2serverConn).processHeaderBlockFragment
>>>         /usr/local/go/src/net/http/h2_bundle.go:3853 +0x7c3
>>>
>>> --
>>> You received this message because you are subscribed to the Google
>>> Groups "golang-nuts" group.
>>> To unsubscribe from this group and stop receiving emails from it, send
>>> an email to golang-nuts...@googlegroups.com.
>>> For more options, visit https://groups.google.com/d/optout.
>>>
>>
>> --
> You received this message because you are subscribed to the Google Groups
> "golang-nuts" group.
> To unsubscribe from this group and stop receiving emails from it, send an
> email to golang-nuts+unsubscr...@googlegroups.com.
> For more options, visit https://groups.google.com/d/optout.
>

-- 
You received this message because you are subscribed to the Google Groups 
"golang-nuts" group.
To unsubscribe from this group and stop receiving emails from it, send an email 
to golang-nuts+unsubscr...@googlegroups.com.
For more options, visit https://groups.google.com/d/optout.

Reply via email to