This repository has been archived by the owner on Oct 29, 2024. It is now read-only.
-
Notifications
You must be signed in to change notification settings - Fork 1
/
main.yml
135 lines (95 loc) · 4.28 KB
/
main.yml
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
122
123
124
125
126
127
128
129
130
131
132
133
134
135
---
strfry_version: beta
strfry_binary_path: /usr/local/bin/strfry
strfry_make_jobs: "{{ ansible_processor_cores }}"
strfry_skip_config: False
strfry_system_group: strfry
strfry_system_user: strfry
strfry_data_path: /var/lib/strfry
strfry_db: "./strfry-db/" # Becomes /var/lib/strfry/strfry-db
strfry_policies_enabled: true
strfry_dbParams:
# Maximum number of threads/processes that can simultaneously have LMDB transactions open (restart required)
maxreaders: 256
# Size of mmap() to use when loading LMDB (default is 10TB, does *not* correspond to disk-space used) (restart required)
mapsize: 10995116277760
# Disables read-ahead when accessing the LMDB mapping. Reduces IO activity when DB size is larger than RAM. (restart required)
noReadAhead: no
strfry_events:
# Maximum size of normalised JSON, in bytes
maxEventSize: 65536
# Events newer than this will be rejected
rejectEventsNewerThanSeconds: 900
# Events older than this will be rejected
rejectEventsOlderThanSeconds: 94608000
# Ephemeral events older than this will be rejected
rejectEphemeralEventsOlderThanSeconds: 60
# Ephemeral events will be deleted from the DB when older than this
ephemeralEventsLifetimeSeconds: 300
# Maximum number of tags allowed
maxNumTags: 2000
# Maximum size for tag values, in bytes
maxTagValSize: 1024
strfry_relay:
# Interface to listen on. Use 0.0.0.0 to listen on all interfaces (restart required)
bind: "127.0.0.1"
# Port to open for the nostr websocket protocol (restart required)
port: 7777
# Set OS-limit on maximum number of open files/sockets (if 0, don't attempt to set) (restart required)
nofiles: 1000000
# HTTP header that contains the client's real IP, before reverse proxying (ie x-real-ip) (MUST be all lower-case)
realIpHeader: ""
info:
# NIP-11: Name of this server. Short/descriptive (< 30 characters)
name: "strfry default"
# NIP-11: Detailed information about relay, free-form
description: "This is a strfry instance."
# NIP-11: Administrative nostr pubkey, for contact purposes
pubkey: "unset"
# NIP-11: Alternative administrative contact (email, website, etc)
contact: "unset"
# Maximum accepted incoming websocket frame size (should be larger than max event and yesstr msg) (restart required)
maxWebsocketPayloadSize: 131072
# Websocket-level PING message frequency (should be less than any reverse proxy idle timeouts) (restart required)
autoPingSeconds: 55
# If TCP keep-alive should be enabled (detect dropped connections to upstream reverse proxy)
enableTcpKeepalive: false
# How much uninterrupted CPU time a REQ query should get during its DB scan
queryTimesliceBudgetMicroseconds: 10000
# Maximum records that can be returned per filter
maxFilterLimit: 500
# Maximum number of subscriptions (concurrent REQs) a connection can have open at any time
maxSubsPerConnection: 20
writePolicy:
# If non-empty, path to an executable script that implements the writePolicy plugin logic
plugin: "{{ strfry_data_path }}/strfry-policy.ts"
compression:
# Use permessage-deflate compression if supported by client. Reduces bandwidth, but slight increase in CPU (restart required)
enabled: yes
# Maintain a sliding window buffer for each connection. Improves compression, but uses more memory (restart required)
slidingWindow: yes
logging:
# Dump all incoming messages
dumpInAll: no
# Dump all incoming EVENT messages
dumpInEvents: no
# Dump all incoming REQ/CLOSE messages
dumpInReqs: no
# Log performance metrics for initial REQ database scans
dbScanPerf: no
# Log reason for invalid event rejection? Can be disabled to silence excessive logging
invalidEvents: yes
numThreads:
# Ingester threads: route incoming requests, validate events/sigs (restart required)
ingester: 3
# reqWorker threads: Handle initial DB scan for events (restart required)
reqWorker: 3
# reqMonitor threads: Handle filtering of new events (restart required)
reqMonitor: 3
# negentropy threads: Handle negentropy protocol messages (restart required)
negentropy: 2
negentropy:
# Support negentropy protocol messages
enabled: yes
# Maximum records that sync will process before returning an error
maxSyncEvents: 1000000