123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596 |
- // Copyright GoFrame Author(https://goframe.org). All Rights Reserved.
- //
- // This Source Code Form is subject to the terms of the MIT License.
- // If a copy of the MIT was not distributed with this file,
- // You can obtain one at https://github.com/gogf/gf.
- // Package grpool implements a goroutine reusable pool.
- package grpool
- import (
- "context"
- "time"
- "github.com/gogf/gf/v2/container/glist"
- "github.com/gogf/gf/v2/container/gtype"
- "github.com/gogf/gf/v2/os/gtimer"
- "github.com/gogf/gf/v2/util/grand"
- )
- // Func is the pool function which contains context parameter.
- type Func func(ctx context.Context)
- // RecoverFunc is the pool runtime panic recover function which contains context parameter.
- type RecoverFunc func(ctx context.Context, exception error)
- // Pool manages the goroutines using pool.
- type Pool struct {
- limit int // Max goroutine count limit.
- count *gtype.Int // Current running goroutine count.
- list *glist.List // List for asynchronous job adding purpose.
- closed *gtype.Bool // Is pool closed or not.
- }
- // localPoolItem is the job item storing in job list.
- type localPoolItem struct {
- Ctx context.Context // Context.
- Func Func // Job function.
- }
- const (
- minSupervisorTimerDuration = 500 * time.Millisecond
- maxSupervisorTimerDuration = 1500 * time.Millisecond
- )
- // Default goroutine pool.
- var (
- defaultPool = New()
- )
- // New creates and returns a new goroutine pool object.
- // The parameter `limit` is used to limit the max goroutine count,
- // which is not limited in default.
- func New(limit ...int) *Pool {
- var (
- pool = &Pool{
- limit: -1,
- count: gtype.NewInt(),
- list: glist.New(true),
- closed: gtype.NewBool(),
- }
- timerDuration = grand.D(
- minSupervisorTimerDuration,
- maxSupervisorTimerDuration,
- )
- )
- if len(limit) > 0 && limit[0] > 0 {
- pool.limit = limit[0]
- }
- gtimer.Add(context.Background(), timerDuration, pool.supervisor)
- return pool
- }
- // Add pushes a new job to the default goroutine pool.
- // The job will be executed asynchronously.
- func Add(ctx context.Context, f Func) error {
- return defaultPool.Add(ctx, f)
- }
- // AddWithRecover pushes a new job to the default pool with specified recover function.
- //
- // The optional `recoverFunc` is called when any panic during executing of `userFunc`.
- // If `recoverFunc` is not passed or given nil, it ignores the panic from `userFunc`.
- // The job will be executed asynchronously.
- func AddWithRecover(ctx context.Context, userFunc Func, recoverFunc RecoverFunc) error {
- return defaultPool.AddWithRecover(ctx, userFunc, recoverFunc)
- }
- // Size returns current goroutine count of default goroutine pool.
- func Size() int {
- return defaultPool.Size()
- }
- // Jobs returns current job count of default goroutine pool.
- func Jobs() int {
- return defaultPool.Jobs()
- }
|