19.0.0-next.2d02c32 • Published 9 months ago

@discordeno/gateway v19.0.0-next.2d02c32

Weekly downloads
-
License
Apache-2.0
Repository
github
Last release
9 months ago

Discordeno WS

Discord API library for Node.JS, Deno & Bun

Discord codecov action status

!WARNING Using a Standalone / Proxy WS is mean for advanced developers only

Standalone WebSocket to connect to the Discord API.

  • Zero Downtime Updates:

    • Your bot can be updated in a matter of seconds. With normal sharding, you have to restart which also has to process identifying all your shards with a 1/~5s rate limit. With WS handling moved to a proxy process, this allows you to instantly get the bot code restarted without any concerns of delays. If you have a bot on 200,000 servers normally this would mean a 20 minute delay to restart your bot if you made a small change and restarted.
  • Zero Downtime Resharding:

    • Discord stops letting your bot get added to new servers at certain points in time. For example, suppose you had 150,000 servers running 150 shards. The maximum amount of servers your shards could hold is 150 * 2500 = 375,000. If your bot reaches this, it can no longer join new servers until it re-shards.
    • DD proxy provides 2 types of re-sharding. Automated and manual. You can also have both.
      • Automated: This system will automatically begin a Zero-downtime resharding process behind the scenes when you reach 80% of your maximum servers allowed by your shards. For example, since 375,000 was the max, at 300,000 we would begin re-sharding behind the scenes with ZERO DOWNTIME.
        • 80% of maximum servers reached (The % of 80% is customizable.)
        • Identify limits have room to allow re-sharding. (Also customizable)
      • Manual: You can also trigger this manually should you choose.
  • Horizontal Scaling:

    • The proxy system allows you to scale the bot horizontally. When you reach a huge size, you can either keep spending more money to keep beefing up your server or you can buy several cheaper servers and scale horizontally. The proxy means you can have WS handling on a completely separate system.
  • No Loss Restarts:

    • When you restart a bot without the proxy system, normally you would lose many events. Users may be using commands or messages are sent that will not be filtered. As your bot's grow this number rises dramatically. Users may join who wont get the auto-roles or any other actions your bot should take. With the proxy system, you can keep restarting your bot and never lose any events. Events will be put into a queue while your bot is down(max size of queue is customizable), once the bot is available the queue will begin processing all events.
  • Controllers:

    • The controller aspect gives you full control over everything inside the proxy. You can provide a function to simply override the handler. For example, if you would like a certain function to do something different, instead of having to fork and maintain your fork, you can just provide a function to override.
  • Clustering With Workers:

    • Take full advantage of all your CPU cores by using workers to spread the load. Control how many shards per worker and how many workers to maximize efficiency!

Links

19.0.0-next.b85c6d5

10 months ago

19.0.0-next.92d717b

10 months ago

19.0.0-next.895cc17

12 months ago

19.0.0-next.45bfa05

11 months ago

19.0.0-next.6f601f0

10 months ago

19.0.0-next.d6898f2

12 months ago

19.0.0-next.2c6ad25

10 months ago

19.0.0-next.08a5e44

12 months ago

19.0.0-next.4899d0a

12 months ago

19.0.0-next.6584a3b

12 months ago

19.0.0-next.8dc6c3f

12 months ago

19.0.0-next.b706358

12 months ago

19.0.0-next.c1b0dc9

12 months ago

19.0.0-next.22a6117

12 months ago

19.0.0-next.9e516a0

12 months ago

19.0.0-next.76ad81d

10 months ago

19.0.0-next.48902bc

11 months ago

19.0.0-next.b9200cf

10 months ago

19.0.0-next.b1bfe94

11 months ago

19.0.0-next.985801c

12 months ago

19.0.0-next.bb6b8df

12 months ago

19.0.0-next.b3a8c86

12 months ago

19.0.0-next.1f142aa

10 months ago

19.0.0-next.62b3122

12 months ago

19.0.0-next.a0510da

12 months ago

19.0.0-next.c400009

12 months ago

19.0.0-next.304a61c

12 months ago

19.0.0-next.6098d68

10 months ago

19.0.0-next.943821f

12 months ago

19.0.0-next.57fa3d4

11 months ago

19.0.0-next.ce4eb2c

12 months ago

19.0.0-next.6ff0c9a

10 months ago

19.0.0-next.9e1ada6

12 months ago

19.0.0-next.a749905

10 months ago

19.0.0-next.40ad082

12 months ago

19.0.0-next.7303a20

10 months ago

19.0.0-next.352887c

12 months ago

19.0.0-next.746f0a9

12 months ago

19.0.0-next.ab2930c

12 months ago

19.0.0-next.14b0158

12 months ago

19.0.0-next.a80036f

12 months ago

19.0.0-next.df5d863

10 months ago