package database import ( "context" "fmt" "time" "github.com/jackc/pgx/v5/pgxpool" ) func NewPool(ctx context.Context, databaseURL string) (*pgxpool.Pool, error) { config, err := pgxpool.ParseConfig(databaseURL) if err != nil { return nil, fmt.Errorf("parse config: %w", err) } config.MaxConns = 20 config.MinConns = 5 config.MaxConnLifetime = 30 * time.Minute config.MaxConnIdleTime = 5 * time.Minute pool, err := pgxpool.NewWithConfig(ctx, config) if err != nil { return nil, fmt.Errorf("create pool: %w", err) } if err := pool.Ping(ctx); err != nil { return nil, fmt.Errorf("ping: %w", err) } return pool, nil }