Greg Heartsfield
d929ae2752
improvement: define websocket send queue (unlimited->1024)
2023-01-02 15:39:28 -06:00
Greg Heartsfield
14fe9f9ee1
improvement: remove pauses for backups, likely not needed w/ WAL compaction
2023-01-02 15:38:30 -06:00
0xtr
7774db8c47
feat: add event kind blacklist
...
Adds a list to the config where you can specify which event kinds to blacklist.
The blacklist check will run right after verifying that the pubkey is allowed
to post events to the relay.
2022-12-27 17:10:34 -06:00
Greg Heartsfield
104ef2b9e1
build: bump version to 0.7.15
2022-12-27 17:04:48 -06:00
Greg Heartsfield
c06139ec99
docs: start of database maintenance tips
2022-12-27 17:00:14 -06:00
Greg Heartsfield
19ec89593d
improvement: drop queries that are running during a checkpoint
2022-12-27 15:24:10 -06:00
Greg Heartsfield
27902bc5f4
improvement: move reader mutex closer to DB connection acquisition
2022-12-27 10:28:56 -06:00
Greg Heartsfield
d2adddaee4
improvement: extend allowed wal_checkpoint timeout to 10 sec
2022-12-27 10:13:14 -06:00
Greg Heartsfield
b23b3ce8ec
improvement: block new readers when WAL is large
2022-12-27 09:48:07 -06:00
Greg Heartsfield
5f9fe1ce59
improvement: do not send realtime only filters to the DB (limit:0)
2022-12-26 12:20:36 -06:00
Greg Heartsfield
6a8c4ed1b5
build: bump version to 0.7.14
2022-12-26 11:26:48 -06:00
Greg Heartsfield
966c853700
docs: non-docker quick start
2022-12-26 10:34:09 -06:00
Greg Heartsfield
65fd0ed08b
feat: increase wal_checkpoint time when WAL is large
2022-12-26 10:03:51 -06:00
Greg Heartsfield
0b51675b38
improvement: change suggestion and default for max sqlite DB readers
2022-12-25 11:17:08 -06:00
Greg Heartsfield
2e22334631
refactor: formatting
2022-12-25 11:06:30 -06:00
Greg Heartsfield
cb2ac4bf0f
improvement: give threads unique names
2022-12-25 10:47:32 -06:00
Greg Heartsfield
38dc7789dc
improvement: cleaner slow query logs
2022-12-25 10:47:32 -06:00
Greg Heartsfield
ce0e00ffb3
feat: log reader DB pool stats every minute
2022-12-25 10:47:32 -06:00
Greg Heartsfield
3e4ae4aeec
feat: cache prepared statements and trace expanded SQL queries
2022-12-25 10:47:32 -06:00
Greg Heartsfield
c6a8807485
improvement: send error on empty-string prefix author/id searches
2022-12-25 10:47:32 -06:00
Greg Heartsfield
8137b6211c
refactor: clippy suggestions
2022-12-24 10:29:47 -06:00
Greg Heartsfield
29effaae23
build: remove pre-commit rustfmt check
2022-12-24 10:29:30 -06:00
Greg Heartsfield
e5074f2e46
feat(NIP-28): replaceable kind 41 channel metadata events
2022-12-24 10:14:43 -06:00
Blake Jakopovic
4fd7643907
feat: change pub(crate) to pub for use as a library
2022-12-23 07:14:58 -06:00
Greg Heartsfield
1e1ec69175
build: remove unnecessary dockerfile mod script
2022-12-23 06:52:09 -06:00
benthecarman
e08647867c
refactor: remove code duplication for simple_event
2022-12-23 06:39:50 -06:00
Greg Heartsfield
ae0f7171ed
build: remove digest-locked docker base images
2022-12-23 06:30:59 -06:00
Greg Heartsfield
4f1a912f36
feat: log origin header from websocket requests
...
fixes: https://todo.sr.ht/~gheartsfield/nostr-rs-relay/33
2022-12-22 16:55:53 -06:00
Greg Heartsfield
95748647f0
build: bump version to 0.7.13
2022-12-22 16:27:34 -06:00
Greg Heartsfield
25480e837f
fix: do not block writers for more than 1 second during checkpoints
2022-12-22 16:10:49 -06:00
Greg Heartsfield
b80b54cd9d
improvement: reduce logging, especially for database pool size
2022-12-22 15:47:33 -06:00
Greg Heartsfield
8ea732cbe5
feat: perform regular database maintenance (60sec), without blocking main writer thread
2022-12-22 15:16:21 -06:00
Greg Heartsfield
0f68c4e5c2
refactor: formatting
2022-12-22 15:15:45 -06:00
Greg Heartsfield
dab2cd5792
wip: future changes to rustfmt
2022-12-22 15:13:54 -06:00
Greg Heartsfield
f411aa6fc2
fix: do not re-verify NIP-05 entries where metadata was deleted
2022-12-22 13:01:48 -06:00
Greg Heartsfield
d31bbda087
improvement: reduce lifetime of database connections
2022-12-22 13:01:12 -06:00
Greg Heartsfield
5917bc53b2
improvement: run maintenance every 60 seconds instead of by event count
2022-12-22 11:40:17 -06:00
Greg Heartsfield
91177c61a1
improvement: log reason for new event creation from nip05
2022-12-22 10:48:30 -06:00
Greg Heartsfield
53c2a8051c
improvement: reduce logging
2022-12-22 10:29:27 -06:00
Greg Heartsfield
168cf513ac
feat: perform full checkpoints and truncate WAL every 2k events
2022-12-22 10:11:05 -06:00
Greg Heartsfield
ea204761c9
fix: do not show slow queries more than once per sub
2022-12-20 15:41:50 -06:00
Greg Heartsfield
c270ae1434
improvement: reduce event count for db writer pauses
2022-12-20 15:25:24 -06:00
Greg Heartsfield
64bd983cb6
perf: every 5000 persisted events, pause for 500ms for backups
...
I have observed backups running for a very long time under heavy load,
this introduces some artificial delay to give the online backup enough
time to make progress.
2022-12-20 15:05:04 -06:00
Greg Heartsfield
1c153bc784
perf: shed DB query load when queue gets large
2022-12-20 13:23:21 -06:00
Greg Heartsfield
dc11d9a619
improvement: explicitly rollback transaction on duplicate event
2022-12-20 13:23:04 -06:00
Greg Heartsfield
cd1557787b
improvement: log write pool
2022-12-20 13:21:57 -06:00
Greg Heartsfield
86bb7aeb9a
improvement: function to check pool capacity
2022-12-20 10:07:01 -06:00
Greg Heartsfield
ce37fc1a2d
build: bump version to 0.7.12
2022-12-19 14:50:42 -06:00
Greg Heartsfield
2cfd384339
perf: drop db handles that are not quickly read
2022-12-19 00:18:39 -06:00
Greg Heartsfield
8c013107f9
perf: increase upper bound for sqlite mmap
2022-12-18 23:19:43 -06:00