Out of curiousity ... are these deadlocks in the database or in the server ?
Regarding server cap ... it shouldn't be hard to add an extra check to the login server to see how many characters you already have logged in?? ( select from account where login=1 and account_id is same). Maybe add it as a parameter to the conf file so it can be set. With that you can limit the number of active characters per account.
|