mirror of
https://github.com/fosrl/pangolin.git
synced 2026-05-06 12:27:39 +00:00
fix: memory improvements
- SQLite: enable WAL mode and PRAGMA performance settings - ws.ts (public + private): fix clientConfigVersions memory leak - internal server: add rate limiting and request timeouts - audit log: fix flush re-queue feedback loop - memory: add monitoring instrumentation - security: remove debug log of full request body
This commit is contained in:
@@ -10,6 +10,8 @@ import {
|
||||
} from "@server/middlewares";
|
||||
import { internalRouter } from "#dynamic/routers/internal";
|
||||
import { stripDuplicateSesions } from "./middlewares/stripDuplicateSessions";
|
||||
import { requestTimeoutMiddleware } from "./middlewares/requestTimeout";
|
||||
import rateLimit from "express-rate-limit";
|
||||
|
||||
const internalPort = config.getRawConfig().server.internal_port;
|
||||
|
||||
@@ -27,6 +29,25 @@ export function createInternalServer() {
|
||||
internalServer.use(cookieParser());
|
||||
internalServer.use(express.json());
|
||||
|
||||
// Prevent requests from hanging indefinitely. Without this, if a
|
||||
// database query blocks (especially on SQLite), pending requests
|
||||
// accumulate in memory with no upper bound on lifetime.
|
||||
internalServer.use(requestTimeoutMiddleware(30000)); // 30 second timeout
|
||||
|
||||
// Rate-limit the internal verify-session endpoint. This server
|
||||
// handles forward-auth requests from Traefik/Badger. Under heavy
|
||||
// monitoring (e.g. Uptime Kuma), requests can arrive faster than
|
||||
// SQLite can serve them, causing unbounded request queuing and
|
||||
// memory growth.
|
||||
internalServer.use(
|
||||
rateLimit({
|
||||
windowMs: 60 * 1000, // 1 minute window
|
||||
max: 1000, // generous limit: ~17 req/s
|
||||
standardHeaders: true,
|
||||
legacyHeaders: false
|
||||
})
|
||||
);
|
||||
|
||||
const prefix = `/api/v1`;
|
||||
internalServer.use(prefix, internalRouter);
|
||||
|
||||
|
||||
Reference in New Issue
Block a user