nostr-rs-relay.patch
· 2.9 KiB · Diff
原始文件
bf6abd3 (HEAD -> master, homelab/master) feat: json logging
diff --git a/Cargo.lock b/Cargo.lock
index c8354d2..3ca8556 100644
--- a/Cargo.lock
+++ b/Cargo.lock
@@ -3671,6 +3671,16 @@ dependencies = [
"tracing-core",
]
+[[package]]
+name = "tracing-serde"
+version = "0.2.0"
+source = "registry+https://github.com/rust-lang/crates.io-index"
+checksum = "704b1aeb7be0d0a84fc9828cae51dab5970fee5088f83d1dd7ee6f6246fc6ff1"
+dependencies = [
+ "serde",
+ "tracing-core",
+]
+
[[package]]
name = "tracing-subscriber"
version = "0.3.19"
@@ -3681,12 +3691,15 @@ dependencies = [
"nu-ansi-term",
"once_cell",
"regex",
+ "serde",
+ "serde_json",
"sharded-slab",
"smallvec",
"thread_local",
"tracing",
"tracing-core",
"tracing-log",
+ "tracing-serde",
]
[[package]]
diff --git a/Cargo.toml b/Cargo.toml
index 7f0ce2e..4a72c91 100644
--- a/Cargo.toml
+++ b/Cargo.toml
@@ -15,7 +15,7 @@ categories = ["network-programming", "web-programming"]
clap = { version = "4.0.32", features = ["env", "default", "derive"]}
tracing = "0.1.37"
tracing-appender = "0.2.2"
-tracing-subscriber = "0.3.16"
+tracing-subscriber = { version = "0.3.16", features = ["fmt", "json"] }
tokio = { version = "1", features = ["full", "tracing", "signal"] }
prost = "0.11"
tonic = "0.8.3"
diff --git a/Dockerfile b/Dockerfile
index 0b0083e..27a36eb 100644
--- a/Dockerfile
+++ b/Dockerfile
@@ -8,7 +8,7 @@ WORKDIR ./nostr-rs-relay
COPY ./Cargo.toml ./Cargo.toml
COPY ./Cargo.lock ./Cargo.lock
# build dependencies only (caching)
-RUN cargo auditable build --release --locked
+RUN cargo auditable build --release
# get rid of starter project code
RUN rm src/*.rs
@@ -19,7 +19,7 @@ COPY ./build.rs ./build.rs
# build auditable release using locked deps
RUN rm ./target/release/deps/nostr*relay*
-RUN cargo auditable build --release --locked
+RUN cargo auditable build --release
FROM docker.io/library/debian:bookworm-slim
@@ -48,5 +48,6 @@ WORKDIR ${APP}
ENV RUST_LOG=info,nostr_rs_relay=info
ENV APP_DATA=${APP_DATA}
+COPY ./my_config.toml /usr/src/app/config.toml
CMD ./nostr-rs-relay --db ${APP_DATA}
diff --git a/README.md b/README.md
index d56b665..92bc3d4 100644
--- a/README.md
+++ b/README.md
@@ -1,3 +1,8 @@
+# nostr-rs-relay Fork with JSON logging
+
+Made this because I wanted logs in Loki
+
+
# [nostr-rs-relay](https://git.sr.ht/~gheartsfield/nostr-rs-relay)
This is a [nostr](https://github.com/nostr-protocol/nostr) relay,
diff --git a/src/main.rs b/src/main.rs
index feadf2c..f59427d 100644
--- a/src/main.rs
+++ b/src/main.rs
@@ -81,8 +81,10 @@ fn main() {
.try_init()
.unwrap();
} else {
- // write to stdout
- tracing_subscriber::fmt::try_init().unwrap();
+ tracing_subscriber::fmt()
+ .json()
+ .flatten_event(true) // optional: flattens fields into top-level JSON
+ .init()
}
}
info!("Starting up from main");
1 | bf6abd3 (HEAD -> master, homelab/master) feat: json logging |
2 | diff --git a/Cargo.lock b/Cargo.lock |
3 | index c8354d2..3ca8556 100644 |
4 | --- a/Cargo.lock |
5 | +++ b/Cargo.lock |
6 | @@ -3671,6 +3671,16 @@ dependencies = [ |
7 | "tracing-core", |
8 | ] |
9 | |
10 | +[[package]] |
11 | +name = "tracing-serde" |
12 | +version = "0.2.0" |
13 | +source = "registry+https://github.com/rust-lang/crates.io-index" |
14 | +checksum = "704b1aeb7be0d0a84fc9828cae51dab5970fee5088f83d1dd7ee6f6246fc6ff1" |
15 | +dependencies = [ |
16 | + "serde", |
17 | + "tracing-core", |
18 | +] |
19 | + |
20 | [[package]] |
21 | name = "tracing-subscriber" |
22 | version = "0.3.19" |
23 | @@ -3681,12 +3691,15 @@ dependencies = [ |
24 | "nu-ansi-term", |
25 | "once_cell", |
26 | "regex", |
27 | + "serde", |
28 | + "serde_json", |
29 | "sharded-slab", |
30 | "smallvec", |
31 | "thread_local", |
32 | "tracing", |
33 | "tracing-core", |
34 | "tracing-log", |
35 | + "tracing-serde", |
36 | ] |
37 | |
38 | [[package]] |
39 | diff --git a/Cargo.toml b/Cargo.toml |
40 | index 7f0ce2e..4a72c91 100644 |
41 | --- a/Cargo.toml |
42 | +++ b/Cargo.toml |
43 | @@ -15,7 +15,7 @@ categories = ["network-programming", "web-programming"] |
44 | clap = { version = "4.0.32", features = ["env", "default", "derive"]} |
45 | tracing = "0.1.37" |
46 | tracing-appender = "0.2.2" |
47 | -tracing-subscriber = "0.3.16" |
48 | +tracing-subscriber = { version = "0.3.16", features = ["fmt", "json"] } |
49 | tokio = { version = "1", features = ["full", "tracing", "signal"] } |
50 | prost = "0.11" |
51 | tonic = "0.8.3" |
52 | diff --git a/Dockerfile b/Dockerfile |
53 | index 0b0083e..27a36eb 100644 |
54 | --- a/Dockerfile |
55 | +++ b/Dockerfile |
56 | @@ -8,7 +8,7 @@ WORKDIR ./nostr-rs-relay |
57 | COPY ./Cargo.toml ./Cargo.toml |
58 | COPY ./Cargo.lock ./Cargo.lock |
59 | # build dependencies only (caching) |
60 | -RUN cargo auditable build --release --locked |
61 | +RUN cargo auditable build --release |
62 | # get rid of starter project code |
63 | RUN rm src/*.rs |
64 | |
65 | @@ -19,7 +19,7 @@ COPY ./build.rs ./build.rs |
66 | |
67 | # build auditable release using locked deps |
68 | RUN rm ./target/release/deps/nostr*relay* |
69 | -RUN cargo auditable build --release --locked |
70 | +RUN cargo auditable build --release |
71 | |
72 | FROM docker.io/library/debian:bookworm-slim |
73 | |
74 | @@ -48,5 +48,6 @@ WORKDIR ${APP} |
75 | |
76 | ENV RUST_LOG=info,nostr_rs_relay=info |
77 | ENV APP_DATA=${APP_DATA} |
78 | +COPY ./my_config.toml /usr/src/app/config.toml |
79 | |
80 | CMD ./nostr-rs-relay --db ${APP_DATA} |
81 | diff --git a/README.md b/README.md |
82 | index d56b665..92bc3d4 100644 |
83 | --- a/README.md |
84 | +++ b/README.md |
85 | @@ -1,3 +1,8 @@ |
86 | +# nostr-rs-relay Fork with JSON logging |
87 | + |
88 | +Made this because I wanted logs in Loki |
89 | + |
90 | + |
91 | # [nostr-rs-relay](https://git.sr.ht/~gheartsfield/nostr-rs-relay) |
92 | |
93 | This is a [nostr](https://github.com/nostr-protocol/nostr) relay, |
94 | diff --git a/src/main.rs b/src/main.rs |
95 | index feadf2c..f59427d 100644 |
96 | --- a/src/main.rs |
97 | +++ b/src/main.rs |
98 | @@ -81,8 +81,10 @@ fn main() { |
99 | .try_init() |
100 | .unwrap(); |
101 | } else { |
102 | - // write to stdout |
103 | - tracing_subscriber::fmt::try_init().unwrap(); |
104 | + tracing_subscriber::fmt() |
105 | + .json() |
106 | + .flatten_event(true) // optional: flattens fields into top-level JSON |
107 | + .init() |
108 | } |
109 | } |
110 | info!("Starting up from main"); |
111 |