Commit Graph

31 Commits

Author SHA1 Message Date
4bf064056c reorganize but crashing
not sure why, seems like i'm using the right allocators everywhere?
need to take another pass at this later.
2026-01-02 04:01:03 +00:00
5a395bdadf Use group to make it easier to clean up client tasks on exit 2026-01-01 22:14:36 +00:00
a3e026ebf1 Cleanup for deinitializing 2026-01-01 22:14:36 +00:00
fc68749669 gracefully exit
simplify code
clean up dead code
2026-01-01 20:26:41 +00:00
987dc492a6 97 mbps !!! super fast
dosen't flush every message, pulls batches from the queue to send, and flushes at the end of each batch.
batches are a min of 1 message, but may be more.
2026-01-01 19:16:58 +00:00
86558986ef Slower, but probably more correct 2026-01-01 18:50:52 +00:00
ca95c9a06c Lock subs when reading it
should probably make a copy instead of doing io in the mutex
2026-01-01 18:50:03 +00:00
ec1912ba7e Use a small stack buffer for client io 2026-01-01 16:55:04 +00:00
45bd63dbe1 Actually fast again???
way faster than before even??

coder@08714a4174bb:~$ nats bench pub foo -s localhost:4223
05:12:23 Starting Core NATS publisher benchmark [clients=1, msg-size=128 B, msgs=100,000, multi-subject=false, multi-subject-max=100,000, sleep=0s, subject=foo]
05:12:23 [1] Starting Core NATS publisher, publishing 100,000 messages
Finished      0s [====================================================================================] 100%

NATS Core NATS publisher stats: 574,666 msgs/sec ~ 70 MiB/sec ~ 1.74us

So cool.

src/server/client.zig JJ: M src/server/main.zig JJ: JJ: Lines starting with "JJ:" (like this one) will be 
removed.
2026-01-01 05:22:03 +00:00
5dea33367e reorganize some things 2026-01-01 05:22:03 +00:00
f289ab7893 Rename ClientState to Client 2026-01-01 05:22:03 +00:00
4fcb9e3943 Heap allocate client buffers 2026-01-01 05:22:02 +00:00
0233bc278c Avoid queues completely
This is quite slow
2026-01-01 05:22:02 +00:00
b447883d10 Reorganized things 2026-01-01 05:22:02 +00:00
7af7a30ed2 things are running quite smoothly!!!
coder@08714a4174bb:~$ nats bench sub foo -s localhost:4223
03:28:04 Starting Core NATS subscriber benchmark [clients=1, msg-size=128 B, msgs=100,000, multi-subject=false, subject=foo]
03:28:04 [1] Starting Core NATS subscriber, expecting 100,000 messages
Finished      6s [====================================================================================] 100%

NATS Core NATS subscriber stats: 14,691 msgs/sec ~ 1.8 MiB/sec ~ 68.06us
2026-01-01 05:22:02 +00:00
a781876038 Simplified a ton of things and cleaned up ownership 2026-01-01 05:22:02 +00:00
0f138e5984 some cleanup and freeing 2026-01-01 05:22:02 +00:00
e60a566a7c Cleanup client
Break up creating and starting the client process.
I think this should simplify storing the std.Io.Queue on the stack.
Before I was storing it on the heap because it was hard to make it point to the same location if I was initializing the client on the stack.
2026-01-01 05:22:02 +00:00
d4566eba52 Reuse port
This lets me dev cycle faster
Shouldn't have to do this though, should be cleaning up properly
2025-12-31 00:55:38 +00:00
fe4c1d410b More cleanup 2025-12-29 04:56:54 +00:00
4bf5ddca15 publish works
starting to use errors instead of unreachable for stream parsing
2025-12-29 04:23:16 +00:00
335c4aa092 2025-12-29 00:35:06 +00:00
50870da1d9 made some progress on subscriptions 2025-12-10 00:11:12 -05:00
45e8c4cc08 sending errors on pub sub! 2025-12-09 18:22:41 -05:00
30cc017081 The issue was the writer is not working to send pong ?? 2025-12-09 17:56:07 -05:00
1eeb55ff4d Made progress, but not perfect.
the message isn't crossing container boundaries, but it works in the
test!
2025-12-08 21:09:16 -05:00
826da348a5 2025-12-06 19:45:05 -05:00
4afdf32beb 2025-12-02 22:03:17 -05:00
aceb671ddc 2025-12-02 19:53:03 -05:00
41f4ee721b Switch from clap to yazap
This is compatible with the latest 0.16.0 nightly build.
It is also a bit less magic than clap.
2025-11-29 22:46:29 -05:00
bd9ed88e5c 2025-11-29 18:30:39 -05:00