{"id":16215985,"url":"https://github.com/kc596/priorityworkerpool","last_synced_at":"2025-03-19T10:30:29.605Z","repository":{"id":57550815,"uuid":"309128920","full_name":"kc596/priorityworkerpool","owner":"kc596","description":"A worker pool in GoLang which schedules job according to priority.","archived":false,"fork":false,"pushed_at":"2021-09-02T12:24:41.000Z","size":28,"stargazers_count":6,"open_issues_count":0,"forks_count":2,"subscribers_count":2,"default_branch":"master","last_synced_at":"2025-02-28T17:50:54.910Z","etag":null,"topics":["go","golang","golang-library","goroutine","goroutine-pool","goroutinemanager","goroutines","worker-pool"],"latest_commit_sha":null,"homepage":"","language":"Go","has_issues":true,"has_wiki":null,"has_pages":null,"mirror_url":null,"source_name":null,"license":"mit","status":null,"scm":"git","pull_requests_enabled":true,"icon_url":"https://github.com/kc596.png","metadata":{"files":{"readme":"README.md","changelog":null,"contributing":null,"funding":null,"license":"LICENSE","code_of_conduct":null,"threat_model":null,"audit":null,"citation":null,"codeowners":null,"security":null,"support":null}},"created_at":"2020-11-01T15:42:50.000Z","updated_at":"2025-01-15T19:34:14.000Z","dependencies_parsed_at":"2022-09-26T18:41:56.923Z","dependency_job_id":null,"html_url":"https://github.com/kc596/priorityworkerpool","commit_stats":null,"previous_names":[],"tags_count":10,"template":false,"template_full_name":null,"repository_url":"https://repos.ecosyste.ms/api/v1/hosts/GitHub/repositories/kc596%2Fpriorityworkerpool","tags_url":"https://repos.ecosyste.ms/api/v1/hosts/GitHub/repositories/kc596%2Fpriorityworkerpool/tags","releases_url":"https://repos.ecosyste.ms/api/v1/hosts/GitHub/repositories/kc596%2Fpriorityworkerpool/releases","manifests_url":"https://repos.ecosyste.ms/api/v1/hosts/GitHub/repositories/kc596%2Fpriorityworkerpool/manifests","owner_url":"https://repos.ecosyste.ms/api/v1/hosts/GitHub/owners/kc596","download_url":"https://codeload.github.com/kc596/priorityworkerpool/tar.gz/refs/heads/master","host":{"name":"GitHub","url":"https://github.com","kind":"github","repositories_count":243982177,"owners_count":20378604,"icon_url":"https://github.com/github.png","version":null,"created_at":"2022-05-30T11:31:42.601Z","updated_at":"2022-07-04T15:15:14.044Z","host_url":"https://repos.ecosyste.ms/api/v1/hosts/GitHub","repositories_url":"https://repos.ecosyste.ms/api/v1/hosts/GitHub/repositories","repository_names_url":"https://repos.ecosyste.ms/api/v1/hosts/GitHub/repository_names","owners_url":"https://repos.ecosyste.ms/api/v1/hosts/GitHub/owners"}},"keywords":["go","golang","golang-library","goroutine","goroutine-pool","goroutinemanager","goroutines","worker-pool"],"created_at":"2024-10-10T11:17:37.957Z","updated_at":"2025-03-19T10:30:29.342Z","avatar_url":"https://github.com/kc596.png","language":"Go","readme":"## Priority Worker Pool\n\n[![Build Status](https://travis-ci.org/kc596/priorityworkerpool.svg?branch=master)](https://travis-ci.org/kc596/priorityworkerpool)\n[![codecov](https://codecov.io/gh/kc596/priorityworkerpool/branch/master/graph/badge.svg?token=4TOHO1P4XV)](https://codecov.io/gh/kc596/priorityworkerpool)\n[![Go Report Card](https://goreportcard.com/badge/github.com/kc596/priorityworkerpool?kill_cache=1)](https://goreportcard.com/report/github.com/kc596/priorityworkerpool)\n[![Maintainability](https://api.codeclimate.com/v1/badges/a51cd48917a2ffc56aba/maintainability)](https://codeclimate.com/github/kc596/priorityworkerpool/maintainability)\n\nA worker pool in GoLang which schedules job according to priority.\n\n### Installation\n\n\u003e go get github.com/kc596/priorityworkerpool\n\n### Quickstart\n\n```go\nimport \"github.com/kc596/priorityworkerpool\"\n\nconst (\n\tpoolName   = \"testPool\"\n\tnumWorkers = 1000\n)\n\nvar panicHandler = func(alias string, err interface{}) {\n\tfmt.Println(alias, err) // or use logger\n}\n\npool := priorityworkerpool.New(poolName, numWorkers, panicHandler)\n\njob := func() {\n\t// code to execute\n}\n\npool.Submit(job, 1+rand.Float64())\n```\n\nA complete example : [Here](https://goplay.space/#DIM2U6jBjwY)\n\n### APIs\n\nMethod | Return Type | Description\n---|---|---\n` New(name string, workers int, panicHandler func(alias string, err interface{})`|`*Pool` | Returns a new worker pool\n`Submit(job func(), priority float64)` | `void` | Submit a new job to worker pool\n`WaitGroup()` | `*sync.WaitGroup` | Returns waitgroup to wait for all jobs submitted to finish\n`ShutDown()` | `void` | Delete queue and prevents pickup of next job from the queue\n","funding_links":[],"categories":[],"sub_categories":[],"project_url":"https://awesome.ecosyste.ms/api/v1/projects/github.com%2Fkc596%2Fpriorityworkerpool","html_url":"https://awesome.ecosyste.ms/projects/github.com%2Fkc596%2Fpriorityworkerpool","lists_url":"https://awesome.ecosyste.ms/api/v1/projects/github.com%2Fkc596%2Fpriorityworkerpool/lists"}