Jump to content

Recommended Posts

Posted

so 1 dedi in europe 1 dedi in russia 1 dedi in africa 1 dedi in canada 1 dedi in amurica 1 dedi in brasil and you have 0 lag globally according to your results: perhaps, maybe, could be, cause i dont see any other use the game data cache is still away from game servers so game server 1 to gameserver N+1 will still have lag to send player1 actions to player2

Posted (edited)

World data is unique to each server, while game data can be edited from server to server, depending type of server (faction, multiclass, etc) and rates. So until you want 100 servers clones - no usage at all, except experimenting for your personal usage. You still need a local db for each server, with unique modifications per server (by game data I assume you speak about all static data such as recipes, items, etc while world data would be "instanced" stuff such as spawns, players data, items, etc).

 

DB related, there is strictly no problem with L2J. At worst you got easy ways to fix them (db pooler change/tweak, MySQL server tweak, and at very very worst some edits to avoid db calls - which mean memory management using Java containers).

 

You should better find solutions for the network aspect.

Edited by Tryskell
Posted

Forget.

Cloud is not abstract thing, is a farm of servers who talks one to each other with network protocols.

And at end is still one database, even clustered in master-master replication.

I see here only lags and more lags.

Customer in web app can wait 500ms to response, but player not.

This whole diagram is only good for mass users, for example 1kk (horizontal scaling) with acceptable (for web users) response, not for fluent game for thousands players.

You theory (no lag) can  only fits consumables and movement, but not for player-player interactions (both players from DIFFERENT servers, Nightw0lf wrote about this) like pvp, trade, siege.

 

If  I can understand You idea(?), I suppouse interact one player from one server with another from another server?

 

But yes, decoupling game and cache is good idea (l2off has it), but cache should "talk" to server only in shared memory, not throgh network (lag)

Posted (edited)

As you said everything depends on data to run, even most simple request add friend packet have got many calls to check player state, his friendlist, target state. You would either have to send a lot of data each time to make a lot of calls.

 

Architecture seems to be a lot more complicated

Edited by vampir
Posted
22 hours ago, .Elfocrash said:

And you are probably well aware that "shared memory" is something like Redis which is a memory cache over the network. There is no such thing like shared memory without networking. It has to communicate somehow.

 

I can see that it runs pretty well on a local network anyway so just wait till i show you what i mean.

My bad, i'm thinking about sockets on same machine (100% not Redis or any other message broker)

Ok, i'm waiting.

Posted

Sounds very efficient, as efficient as connecting the CPU to a RAM stick a thousands of miles away with bonus noise and failure rates introduced by the network. Every single operation will involve a 200ms latency at best

Posted
30 minutes ago, .Elfocrash said:

Did you even read that this is meant for a local service fabric cluster and not for geolocation based traffic split? It literally replicates the CacheD logic of L2OFF so it's as efficient as L2OFF itself it.

 

Just saw the picture my bad

Posted

 

On 1/25/2018 at 5:23 PM, Nightw0lf said:

so 1 dedi in europe 1 dedi in russia 1 dedi in africa 1 dedi in canada 1 dedi in amurica 1 dedi in brasil and you have 0 lag globally according to your results: perhaps, maybe, could be, cause i dont see any other use the game data cache is still away from game servers so game server 1 to gameserver N+1 will still have lag to send player1 actions to player2

 

lmao

Posted
3 hours ago, .Elfocrash said:

Did you even read that this is meant for a local service fabric cluster and not for geolocation based traffic split? It literally replicates the CacheD logic of L2OFF so it's as efficient as L2OFF itself it.

It can easily be done with the right tools lol

Create an account or sign in to comment

You need to be a member in order to leave a comment

Create an account

Sign up for a new account in our community. It's easy!

Register a new account

Sign in

Already have an account? Sign in here.

Sign In Now


  • Posts

    • Hi, great work! Are there any bugs? And will it work with a high five?
    • For others that would like to understand in more details:   The login server also uses a protocol (sent by the server to the client in the very first packet). For instance, the C4 client (the one I'm developing my emulator for) expects the protocol number `50721` (or `0xc621`) which works as follow (from what I've gathered): Preamble: L2 packets are divided into two parts: size and payload; As mentioned, every packet starts with two bytes containing the whole packet size (thus including those two bytes, e.g. a packet of size 15 will have the number `15` written onto its first two bytes and a following payload of 13 bytes); For login server, first byte of the payload is the opcode (game server must deal with variable-sized opcodes); Next bytes are the packet content; Before sending the packet, its buffer size (minus the initial two bytes) is padded to 8 bytes (required by upcoming Blowfish encoding); A checksum of the packet is appended at the end, then the payload is again padded to 8 bytes; If the opcode is not `0` (also written as `0x00`), then the payload is encoded by Blowfish; Packet is sent over the network. You can have a look at my implementation (in C++) here (do note I'm assuming little-endian).   In this protocol, the auth packet (`0x00`) sent back by the client is RSA encrypted using the RSA modulus sent in the first server packet, inserted right after the protocol number.  
    • Hello guys I wanna buy some  Lessons for an L2J Developer
    • Let me give you something for inspiration and get you addicted to bot AI     And a siege 😛     What I have notice helps a lot the LLM to act real, is to give it a real-persons background. So for each LLM in the context beggining, besides the L2 facts, give it a real-life back story "You are a 67 years old retired nurse who plays Lineage 2 while her husband reads his newspaper, you are calm, collected but get mad if insulted". But that makes for a creative bot but its repetitive. So what you can also do, is pick random 20 news sites and for each bot every 2-3 days, initialize a context that is affected by the "news" the bot reads in the "real world".  So for example there's Iran - US war ok ? You take the news, put it in an LLM and ask it, extract the "abstract feelings" that this news piece invokes into you without mentioning anything related to the news. Then you take the result and inject it to the bots LLM prompt after its backstory.  This leads to some VERY human-like behavior from bots. 
  • Topics

×
×
  • Create New...

Important Information

This community uses essential cookies to function properly. Non-essential cookies and third-party services are used only with your consent. Read our Privacy Policy and We have placed cookies on your device to help make this website better. You can adjust your cookie settings, otherwise we'll assume you're okay to continue..