2 Commits

Author SHA1 Message Date
6aab4fb44b 120 timeout if only one upstream 2023-11-08 20:42:36 +08:00
b932331bdc 20s timeout for large request 2023-11-08 20:18:55 +08:00
2 changed files with 10 additions and 3 deletions

View File

@@ -133,6 +133,10 @@ func main() {
shouldResponse := index == len(upstreams)-1
if len(upstreams) == 1 {
upstream.Timeout = 120
}
err = processRequest(c, &upstream, &record, shouldResponse)
if err != nil {
log.Println("Error from upstream", upstream.Endpoint, "should retry", err)

View File

@@ -62,13 +62,16 @@ func processRequest(c *gin.Context, upstream *OPENAI_UPSTREAM, record *Record, s
// set timeout, default is 60 second
timeout := 60 * time.Second
if requestBodyOK == nil && requestBody.Stream {
timeout = 5 * time.Second
}
if len(inBody) > 1024*128 {
timeout = 20 * time.Second
}
if upstream.Timeout > 0 {
// convert upstream.Timeout(second) to nanosecond
timeout = time.Duration(upstream.Timeout) * time.Second
}
if requestBodyOK == nil && requestBody.Stream {
timeout = 5 * time.Second
}
// timeout out request
go func() {