Jump to content

Recommended Posts

  • 3 weeks later...
Posted

New feature

 

Package installations:

  • Detects when its faster to use a specific package
  • Download many files in a custom tarball compressed with gzip
  • extracts only the needed data
  • detects first time installation to download faster a single package
  • 5 months later...
Posted (edited)

Working on this again, also decided to share a beta version so you can see how insanely fast this thing is.

 

Test Server

 

 

CPU: VPS 2vCore

SSD

Bandwidth: 100 mbps

HTTP daemon: Lighttpd

OS: Archlinux

 

 

 

Test Client

 

 

CPU: i7 6950X

SSD 850 Pro

Bandwidth 50mbps

OS: Win10 x64

 

File Scan: < 20ms

Full update: < 25 seconds

 

 

 

Beta client can be downloaded bellow, it will try to download a file patch of size ~= 120mb.

The executable is not signed and windows or chrome may warn you not to download it, but there's nothing to worry about Virus Total

 

The bellow client may go into non-working state any time because the instructions offsets may get updated

 

Download Link

 

The message Initializing...l means that the updater done it's work and waits for L2 client to launch but this feature is not yet implemented, just hit the Cancel button

Edited by xxdem
Posted (edited)

PS: ALL the files on this updater are automatically considered as "Critical updates" this updater in other words will force "Full Check" everytime its run. A "Full Check" scenario on an old-obsolete updater is about 5-8 minutes on an average patch size, this updater is able to use 100% of the available hardware resources and give's the ability to read/scan the same patch within 50-100 MS

Edited by xxdem
Posted

Update

 

After lots of work, succeeded onto making stream decompression n-memory while downloading. This feature is totally unique among all updaters and I will explain why.

 

Technical explanation of how it works

 

Old mainstream method

 

 

Download all bytes and append/write intto xxx.zip on the hard disk

Buffered reading of xxx.zip and decompressing in memory again

Stream de-compression of in-memory bytes back to the harddisk and appending into un-compressed file xxx.u

 

A total of 3 steps involving heavy IO operations

 

 

 

In memory (new method)

 

 

Download next available data chunk -> decompress in-memory -> append to xxx.u

 

A total of 1 step reducing IO about 66% in comparison with the old method. It won't bottleneck your download speed since it operates in different worker thread.

 

 

  • 2 weeks later...
Posted

Threading has nothing to do with bottlenecking the connection.

This connection bottleneck is caused because the download function is trying to use as much bandwidth as possible so it can be downloaded as fast as possible.

 

Isn't that correct?

 

In theory, if u put additional workload on the very same thread that downloads through a socket, you add latency on the connection eventually decreasing network efficiency

Posted (edited)

Isn't there a better way to throttle the bandwidth of the download tho?

 

There is no throttle involved during a normal download, the old version or even the standard updater we are all used to will download the file with the highest efficiency possible. But will then require to decompress the compressed file into a new file on the disk with it's own new size, this means delete the downloaded compressed file and decompress it into a new file, which I believe adds unnecessary IO.

My method is more simple, it will decompress the bytes as soon as they are downloaded from the socket while downloading, this method will introduce input lag on the download thread and will throttle the network down, so this was solved with a second worker thread that received job from the download thread, decompressing the bytes in a streamed writer who is also responsible of writing the decompressed bytes to the hardisk through another buffered writer

Edited by xxdem
Posted (edited)

yes its a virus, I want to scam your endless money

 

endgame antivirus

 

really you are so idiot ?

i said only you scan need update nothing more ...

i'm sure you don't have the Knowledge to create anything like this ...

Edited by pirama

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

    • TG Support: https://t.me/buyingproxysup | Channel: https://t.me/buyingproxycom Discord support: #buyingproxy | Server: Join the BuyingProxy Discord Server!  Create your free account here
    • Thank you for your feedback. To help me improve the system, please leave your comments or report any bugs. I will try to release weekly updates. 
    • Thank you for your feedback, SkyLord — even the negative kind.   Let me give you some context on who we actually are, since you asked. L2-Scripts has been around for nearly 20 years. Over that time, we've worked with a large number of developers — I've personally seen probably half of every serious (and not-so-serious) developer in this scene. The most significant figure in our studio's history was Bonux. Together with a small team of assistants, he was essentially the backbone of our old codebase, and we were the ones who brought virtually every chronicle to the community — Essence, Classic, Main — all of it came through us.   Back then, we worked at scale. That era is over. Today, L2-Scripts is no longer a studio in the traditional sense. It's more of a developer collective. I work alongside the best developers I've encountered in 20 years. Bonux is still with us on Classic. A new developer named Den has joined — in just 3 years he became one of the top Essence developers in the world. Every one of us works independently, but we're united by long-standing friendships and shared projects.   We no longer chase every chronicle or every client. For the past several years, we've been focused exclusively on specific long-term projects where we're paid a proper salary — and when you focus like that, with 20 years of experience behind you, the quality of what you produce is on a completely different level. Our code is currently running on nearly all top Essence and Classic servers. We're now bringing Main (Last Protocol) up to that same standard.   You mentioned Nexvil. Yes, he worked with us. That was a difficult period — the lead developer at the time was not up to the standard we hold ourselves to. It was a short period, and it's long behind us.   As for the prices — I'd ask you not to judge a product by whether you personally can afford it. That's not a fair measure of value. The people running top-tier servers understand what they're paying for. If our pricing doesn't fit your budget, that's completely fine — but downvoting a service simply because it feels expensive to you doesn't reflect well, and it certainly doesn't make the product worse.   A special thank you to eMommy and Zenith for the honest and fair words — it genuinely means a lot. It's good to know there are people in this community who judge things as they are.
    • Just because someone does professional sales doesn’t mean everything is overpriced. If the products he provides are stable and good quality, then I see nothing wrong with it, and those prices aren’t even bad. Remember, we’re living in 2026, not 10 years in the past. Your mindset is probably stuck on buying the cheapest products because maybe you can’t afford better ones. And of course, there’s always someone who likes blaming others. I think you should mind your own business instead of blaming someone for how they run theirs. If you really think his prices are too expensive, then do better than him.
  • 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..