1
0
mirror of https://github.com/pocketbase/pocketbase.git synced 2025-01-10 00:43:36 +02:00
pocketbase/core/db_cgo.go

38 lines
1005 B
Go
Raw Normal View History

2022-07-06 23:19:05 +02:00
//go:build cgo
package core
import (
"fmt"
2022-11-01 22:02:38 +02:00
"time"
2022-07-06 23:19:05 +02:00
_ "github.com/mattn/go-sqlite3"
"github.com/pocketbase/dbx"
2022-07-06 23:19:05 +02:00
)
func connectDB(dbPath string) (*dbx.DB, error) {
// note: the busy_timeout pragma must be first because
// the connection needs to be set to block on busy before WAL mode
// is set in case it hasn't been already set by another connection
pragmas := "_busy_timeout=10000&_journal_mode=WAL&_foreign_keys=1&_synchronous=NORMAL"
2022-07-06 23:19:05 +02:00
db, openErr := dbx.MustOpen("sqlite3", fmt.Sprintf("%s?%s", dbPath, pragmas))
if openErr != nil {
return nil, openErr
}
2022-11-01 22:02:38 +02:00
// use a fixed connection pool to limit the SQLITE_BUSY errors
// and reduce the open file descriptors
// (the limits are arbitrary and may change in the future)
db.DB().SetMaxOpenConns(500)
db.DB().SetMaxIdleConns(30)
db.DB().SetConnMaxIdleTime(5 * time.Minute)
2022-07-06 23:19:05 +02:00
// additional pragmas not supported through the dsn string
_, err := db.NewQuery(`
pragma journal_size_limit = 100000000;
`).Execute()
return db, err
}