GlobalSemaphore

CI

Cluster-wide semaphore with a dead-simple API.

# config :global_semaphore, :limits, pdf_api: 3

GlobalSemaphore.with_permit(:pdf_api, fn ->
  generate_pdf()  # max 3 concurrent calls across the entire cluster
end)

Why?

Installation

def deps do
  [{:global_semaphore, "~> 0.1.0"}]
end

Usage

# config/runtime.exs
config :global_semaphore, :limits,
  pdf_api: 3,
  email_api: 5
# Recommended: automatic acquire/release
GlobalSemaphore.with_permit(:pdf_api, fn ->
  call_pdf_api()
end)

# Manual control when needed
GlobalSemaphore.acquire(:pdf_api)
try do
  call_pdf_api()
after
  GlobalSemaphore.release(:pdf_api)
end

Limitations

License

MIT