Merge pull request #164 from stz184/implement-db-connection-retry
Added db connection retry logic
This commit is contained in:
commit
a10f8ad1ef
|
@ -1,9 +1,11 @@
|
|||
package database
|
||||
|
||||
import (
|
||||
"context"
|
||||
"log"
|
||||
"net/url"
|
||||
"os"
|
||||
"time"
|
||||
|
||||
"github.com/photoview/photoview/api/graphql/models"
|
||||
"github.com/pkg/errors"
|
||||
|
@ -39,11 +41,31 @@ func SetupDatabase() (*gorm.DB, error) {
|
|||
config.Logger = logger.Default.LogMode(logger.Info)
|
||||
|
||||
db, err := gorm.Open(mysql.Open(address.String()), &config)
|
||||
if err != nil {
|
||||
return nil, errors.Wrap(err, "could not connect to database")
|
||||
sqlDB, dbErr := db.DB()
|
||||
if dbErr != nil {
|
||||
log.Println(dbErr)
|
||||
return nil, dbErr
|
||||
}
|
||||
|
||||
// TODO: Add connection retries
|
||||
sqlDB.SetMaxOpenConns(80)
|
||||
|
||||
if err != nil {
|
||||
for retryCount := 1; retryCount <= 5; retryCount++ {
|
||||
ctx, cancel := context.WithTimeout(context.Background(), 5*time.Second)
|
||||
|
||||
if err := sqlDB.PingContext(ctx); err == nil {
|
||||
cancel()
|
||||
return db, nil
|
||||
}
|
||||
|
||||
cancel()
|
||||
|
||||
log.Printf("WARN: Could not ping database: %s. Will retry after 5 seconds\n", err)
|
||||
time.Sleep(time.Duration(5) * time.Second)
|
||||
}
|
||||
|
||||
return nil, err
|
||||
}
|
||||
|
||||
return db, nil
|
||||
}
|
||||
|
|
Loading…
Reference in New Issue