-
Notifications
You must be signed in to change notification settings - Fork 366
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
ProxyService support for different contest RWS #1102
base: main
Are you sure you want to change the base?
Conversation
Codecov Report
@@ Coverage Diff @@
## master #1102 +/- ##
=========================================
- Coverage 62.02% 61.92% -0.1%
=========================================
Files 230 230
Lines 16587 16598 +11
=========================================
- Hits 10288 10279 -9
- Misses 6299 6319 +20
Continue to review full report at Codecov.
|
service.name == "ResourceService" or \ | ||
(self.contest_id is None and | ||
service.name == "ProxyService"): | ||
if service.name in ("LogService", "ResourceService"): |
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
It should be more conventional to use a list here.
"_help": "RWSs where the scores are to be sent. Don't include the", | ||
"_help": "load balancing proxy (if any), just the backends. If any", | ||
"_help": "of them uses HTTPS specify a file with the certificates", | ||
"_help": "you trust.", | ||
"rankings": ["http://usern4me:passw0rd@localhost:8890/"], | ||
"rankings": [[1, "http://usern4me:passw0rd@localhost:8890/"]], |
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
This somewhat breaks the current workflow, because now you have to update cms.conf
every time your contests change.
I suppose that the real fix would be to make RWS contest-aware, that is, serve multiple results pages under a prefix when multi-contest mode is on, similarly to how CWS works now. (Although this would interfere with RWS's feature of joining "day 1" and "day 2" contests…)
Maybe we could use a default of 0
or -1
here to indicate that the old behavior should be used, so that users with existing workflows don't need to do anything. I would appreciate opinions on this.
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
Additionally, with change to "rankings" property format in config file, cms/cmscontrib/RWSHelper.py
retrieving of ranking server urls needs to be fixed.
Did you consider changing the DB model so that a contest can provide a ranking_url as well as other fields already provided like title and description? If the field is null we can fallback to the ranking specified in cms.conf In this way, proxyservice could send contest data to the right URL for each contest. If there are multi-day contests we can easily support that by setting the same ranking_url value for both days |
Or leave the upload URL in the config file, but for the contest specify a "contest group" it belongs to, and use this group as the RWS prefix. Empty group would mean the current behavior. Very nice idea, @wil93 :) |
There is one more problem with multiple RankingWebServers, if you run them on the same machine. Not taking into account that each needs a different port number, they also need different log and data directories. By default they all try to use This can be worked around by specifying different |
To expand on the last idea: We can add a new "group" field to the contest in DB. Contests in one group would be temporally related, for example, day 1 and day 2. When ProxyService sends data to RWS, it would also send the contest's group along the data. When RWS receives the data, it would display it under the For example, for the Latvian olympiad with two days and junior/senior student groups, we would have
and there would be two scoreboards at http://rws/junior and http://rws/senior. This way there is no need to change A separate question is how to deal with the leaking of the task names from the second day. I think this can be handled in a different issue. |
ProxyService only supports one parallel contest when sending initial data to listed RWS. After that, it sends all submission changes (even from different contests). These changes are discarded by RWS because of data inconsistency.
This pull request adds support to ProxyService for sending scores to multiple RWS where each of them can show a different subset of contests.
This request fixes the problem where ProxyService sends unrelated contest submissions to RWS.
Additionally, this allows to easily set up RW servers for multiple contests that are run in parallel and keep their data unmerged if needed.
This change is