mirror of
https://github.com/nbd-wtf/go-nostr.git
synced 2025-03-17 13:22:56 +01:00
add readme.
This commit is contained in:
parent
cfdfba3bdd
commit
62e0068373
37
nson/README.md
Normal file
37
nson/README.md
Normal file
@ -0,0 +1,37 @@
|
||||
# NSON
|
||||
|
||||
A crazy way to encode Nostr events into valid JSON that is also much faster to decode as long as they are actually
|
||||
encoded using the strict NSON encoding and the decoder is prepared to read it using a NSON decoder.
|
||||
|
||||
See https://github.com/nostr-protocol/nips/pull/515.
|
||||
|
||||
Some benchmarks:
|
||||
|
||||
```
|
||||
goos: linux
|
||||
goarch: amd64
|
||||
pkg: github.com/nbd-wtf/go-nostr/nson
|
||||
cpu: AMD Ryzen 3 3200G with Radeon Vega Graphics
|
||||
BenchmarkNSONEncoding/json.Marshal-4 6214 230680 ns/op
|
||||
BenchmarkNSONEncoding/nson.Marshal-4 4520 319058 ns/op
|
||||
BenchmarkNSONDecoding/json.Unmarshal-4 3741 280641 ns/op
|
||||
BenchmarkNSONDecoding/nson.Unmarshal-4 46519 23762 ns/op
|
||||
BenchmarkNSONDecoding/json.Unmarshal_+_sig_verification-4 352 3218583 ns/op
|
||||
BenchmarkNSONDecoding/nson.Unmarshal_+_sig_verification-4 451 2739238 ns/op
|
||||
PASS
|
||||
ok github.com/nbd-wtf/go-nostr/nson 8.291s
|
||||
```
|
||||
|
||||
It takes a little while more to encode (although it's probably possible to optimize that), but decodes at 10x the
|
||||
speed of normal JSON.
|
||||
|
||||
The performance gain is real, but negligible once you add hash validation and signature verification, so it should
|
||||
be used wisely, mostly for situations in which the reader wouldn't care about the signature, e.g. reading from a
|
||||
local database.
|
||||
|
||||
## How it works
|
||||
|
||||
It's explained better in the NIP proposal linked above, but the idea is that we encode field offset and sizes into
|
||||
a special JSON attribute called `"nson"`, and then the reader can just pull the strings directly from the JSON blob
|
||||
without having to parse the full JSON syntax. Also for fields of static size we don't even need that. This is only
|
||||
possible because Nostr events have a static and strict format.
|
Loading…
x
Reference in New Issue
Block a user