Skip to content
New issue

Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.

By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.

Already on GitHub? Sign in to your account

feat: call SetupStream and SetupMetrics from nginx configuration #105

Merged
merged 6 commits into from
Apr 3, 2025

Conversation

sabban
Copy link
Contributor

@sabban sabban commented Mar 27, 2025

Start the timers (SetupStream and SetupMetrics) from nginx configuration instead of when first request is being processed. In this way:

  1. Metrics timer is pinned to first worker
  2. Stream timer - one per worker

It also allows us not to wait for first request to populate cache etc.

sabban added 6 commits March 27, 2025 15:04
Removed the unused stream mode setup and metrics setup from the ~allowIp~ and ~Allow~ functions to clean up the code.
Added a new function ~csmod.get_mode~ to retrieve the runtime mode from the configuration. This function returns the value of the ~MODE~ key from the ~runtime.conf~ table.
Expose the SetupMetrics and SetupStream functions to make them accessible outside the module.
Corrected the function reference in the timer setup from ~Setup_metrics~ to ~csmod.SetupMetrics~ to ensure proper execution of the timer.
…lization

+ Added ~init_worker_by_lua_block~ to initialize stream mode and metrics for workers.
+ Ensured that stream mode is set up for workers when mode is "stream".
+ Metrics initialization is performed only by worker 0.
Ensure the debug cache entries are in the correct order in `t/05stream_and_ban.t`.
@sabban sabban merged commit cae926f into main Apr 3, 2025
1 check passed
@sabban sabban deleted the init/worker branch April 3, 2025 09:51
Sign up for free to join this conversation on GitHub. Already have an account? Sign in to comment
Labels
None yet
Projects
None yet
Development

Successfully merging this pull request may close these issues.

2 participants