- 
                Notifications
    You must be signed in to change notification settings 
- Fork 12
Allow to set up load balancing when installing DOMjudge. #59
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
base: main
Are you sure you want to change the base?
Conversation
| You change the order of some roles so does 
 | 
        
          
                provision-contest/ansible/roles/domserver/templates/nginx-domjudge.conf.j2
              
                Outdated
          
            Show resolved
            Hide resolved
        
      | 
 Yes | 
22cb208    to
    4698e39      
    Compare
  
    | location / { | ||
| proxy_pass https://domjudge-loadbalanced; | ||
| proxy_http_version 1.1; | ||
| proxy_set_header Connection ""; | 
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.
| proxy_set_header Connection ""; | |
| proxy_set_header Connection ""; | 
…hosts and use SSL for LB communication.
4698e39    to
    125f924      
    Compare
  
    | A caution note: in the WF setup each server runs its own master-master replicated DB, so if you use load balancing this way, then you write to both masters and replication will happen both ways. I'd make sure to stress test this, as I don't know if there's a guarantee that both servers will end up with the exact same replication log or how MySQL performance is impacted if it does some kind of locking to guarantee this. I guess the alternative would be to redirect only read-only traffic to the "secondary" server, which would also have to include any login/out actions due to the session management. | 
| 
 No, when this feature is enabled I explicitly write to only one of the database servers. Or well, I write to the keepalived IP, so if the IP moves, then indeed it writes to the other one. But it should never write to both 'at the same time'. 
 Sessions are stored in the databse, so they are not read-only? | 
| 
 Ah, ok. Then ignore my remarks. 
 Never mind this part, it's not relevant anymore given the above. And I made a typo and should have written "exclude any login/out actions". | 
When DOMjudge/domjudge#1654 is merged, we store sessions in the database and thus we can have a real loadbalanced set up. This PR enables this, put behind a feature flag (since it doesn't make sense if you only have one machine).
This PR does a couple of things:
localhostto connect to the database in the laodbalancing scenario.domjudgeDB user can also connect from external IP's in the configured range.I tested this on the DB sessions branch and it seems to work.
Since we already had this keepalived floating IP for the database, we can use that as the 'frontend IP' teams and the judgehost uses, but we already did that.
nginx itself takes care of not sending traffic to a loadbalanced server if it is down, so we don't have to do anything for that.
I would like to use this at the World Finals in Dhaka, and test it earlier (at EAPC and BAPC if we have > 1 server there or otherwise at the integration test).