2022-07-07 00:19:05 +03:00
|
|
|
//go:build cgo
|
|
|
|
|
|
|
|
package core
|
|
|
|
|
|
|
|
import (
|
|
|
|
"fmt"
|
2022-11-01 22:02:38 +02:00
|
|
|
"time"
|
2022-07-07 00:19:05 +03:00
|
|
|
|
2022-07-09 22:17:41 +08:00
|
|
|
"github.com/pocketbase/dbx"
|
2022-11-02 21:44:23 +02:00
|
|
|
_ "github.com/mattn/go-sqlite3"
|
2022-07-07 00:19:05 +03:00
|
|
|
)
|
|
|
|
|
|
|
|
func connectDB(dbPath string) (*dbx.DB, error) {
|
2022-11-01 20:29:07 +02:00
|
|
|
// 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-07 00:19:05 +03: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)
|
2022-12-08 10:40:42 +02:00
|
|
|
db.DB().SetMaxOpenConns(800)
|
2022-11-01 22:02:38 +02:00
|
|
|
db.DB().SetMaxIdleConns(30)
|
|
|
|
db.DB().SetConnMaxIdleTime(5 * time.Minute)
|
|
|
|
|
2022-07-07 00:19:05 +03:00
|
|
|
// additional pragmas not supported through the dsn string
|
|
|
|
_, err := db.NewQuery(`
|
|
|
|
pragma journal_size_limit = 100000000;
|
|
|
|
`).Execute()
|
|
|
|
|
|
|
|
return db, err
|
|
|
|
}
|