bug: Sharkey is not fully functioning within rootless podman
Created by: ecco8443
💡 Summary
When attempting to install Sharkey into a pod with rootless podman, most things seem to work perfectly. When attempting to import posts to my account, the frontend implies that it is working, but the imports never happen and the console throws [ECONNREFUSED]. Post importing is the only thing I've tested, but I'm sure it's not the only thing not working since this seems to be related to accessing files, not just the post import feature.
🥰 Expected Behavior
Imports should work.
🤬 Actual Behavior
Jan 19 16:44:42 coolserver tempfish-web[66390]: INFO 1 [queue import-notes] Starting note import of 9olvwc1s1m5p0001 ...
Jan 19 16:44:42 coolserver tempfish-web[66390]: INFO 1 [queue import-notes] Temp dir is /tmp/tmp-117-c5aD85ku0CO7
Jan 19 16:44:42 coolserver tempfish-web[66390]: INFO 1 [download] Downloading https://testing.coolwebsite.zone/files/8e193f52-14ba-4b06-b637-2aeaa8e6ebab to /tmp/tmp-117-c5aD85ku0CO7 ...
Jan 19 16:44:42 coolserver tempfish-web[66390]: ERR 1 [queue import-notes] RequestError
Jan 19 16:44:42 coolserver tempfish-web[66390]: {
Jan 19 16:44:42 coolserver tempfish-web[66390]: e: RequestError
Jan 19 16:44:42 coolserver tempfish-web[66390]: at ClientRequest.<anonymous> (file:///sharkey/node_modules/.pnpm/got@14.0.0/node_modules/got/dist/source/core/index.js:669:107)
Jan 19 16:44:42 coolserver tempfish-web[66390]: at Object.onceWrapper (node:events:634:26)
Jan 19 16:44:42 coolserver tempfish-web[66390]: at ClientRequest.emit (node:events:531:35)
Jan 19 16:44:42 coolserver tempfish-web[66390]: at TLSSocket.socketErrorListener (node:_http_client:495:9)
Jan 19 16:44:42 coolserver tempfish-web[66390]: at TLSSocket.emit (node:events:519:28)
Jan 19 16:44:42 coolserver tempfish-web[66390]: at emitErrorNT (node:internal/streams/destroy:169:8)
Jan 19 16:44:42 coolserver tempfish-web[66390]: at emitErrorCloseNT (node:internal/streams/destroy:128:3)
Jan 19 16:44:42 coolserver tempfish-web[66390]: at process.processTicksAndRejections (node:internal/process/task_queues:82:21)AggregateError [ECONNREFUSED]:
Jan 19 16:44:42 coolserver tempfish-web[66390]: at internalConnectMultiple (node:net:1114:18)
Jan 19 16:44:42 coolserver tempfish-web[66390]: at afterConnectMultiple (node:net:1667:5) {
Jan 19 16:44:42 coolserver tempfish-web[66390]: input: undefined,
Jan 19 16:44:42 coolserver tempfish-web[66390]: code: 'ECONNREFUSED',
Jan 19 16:44:42 coolserver tempfish-web[66390]: timings: {
Jan 19 16:44:42 coolserver tempfish-web[66390]: start: 1705682682854,
Jan 19 16:44:42 coolserver tempfish-web[66390]: socket: 1705682682858,
Jan 19 16:44:42 coolserver tempfish-web[66390]: lookup: 1705682682860,
Jan 19 16:44:42 coolserver tempfish-web[66390]: connect: undefined,
Jan 19 16:44:42 coolserver tempfish-web[66390]: secureConnect: undefined,
Jan 19 16:44:42 coolserver tempfish-web[66390]: upload: undefined,
Jan 19 16:44:42 coolserver tempfish-web[66390]: response: undefined,
Jan 19 16:44:42 coolserver tempfish-web[66390]: end: undefined,
Jan 19 16:44:42 coolserver tempfish-web[66390]: error: 1705682682862,
Jan 19 16:44:42 coolserver tempfish-web[66390]: abort: undefined,
Jan 19 16:44:42 coolserver tempfish-web[66390]: phases: [Object]
Jan 19 16:44:42 coolserver tempfish-web[66390]: },
Jan 19 16:44:42 coolserver tempfish-web[66390]: options: {
Jan 19 16:44:42 coolserver tempfish-web[66390]: request: undefined,
Jan 19 16:44:42 coolserver tempfish-web[66390]: agent: {
Jan 19 16:44:42 coolserver tempfish-web[66390]: http: Agent {
Jan 19 16:44:42 coolserver tempfish-web[66390]: _events: [Object: null prototype],
Jan 19 16:44:42 coolserver tempfish-web[66390]: _eventsCount: 2,
Jan 19 16:44:42 coolserver tempfish-web[66390]: _maxListeners: undefined,
Jan 19 16:44:42 coolserver tempfish-web[66390]: defaultPort: 80,
Jan 19 16:44:42 coolserver tempfish-web[66390]: protocol: 'http:',
Jan 19 16:44:42 coolserver tempfish-web[66390]: options: [Object: null prototype],
Jan 19 16:44:42 coolserver tempfish-web[66390]: requests: [Object: null prototype] {},
Jan 19 16:44:42 coolserver tempfish-web[66390]: sockets: [Object: null prototype] {},
Jan 19 16:44:42 coolserver tempfish-web[66390]: freeSockets: [Object: null prototype] {},
Jan 19 16:44:42 coolserver tempfish-web[66390]: keepAliveMsecs: 30000,
Jan 19 16:44:42 coolserver tempfish-web[66390]: keepAlive: true,
Jan 19 16:44:42 coolserver tempfish-web[66390]: maxSockets: Infinity,
Jan 19 16:44:42 coolserver tempfish-web[66390]: maxFreeSockets: 256,
Jan 19 16:44:42 coolserver tempfish-web[66390]: scheduling: 'lifo',
Jan 19 16:44:42 coolserver tempfish-web[66390]: maxTotalSockets: Infinity,
Jan 19 16:44:42 coolserver tempfish-web[66390]: totalSocketCount: 0,
Jan 19 16:44:42 coolserver tempfish-web[66390]: [Symbol(shapeMode)]: false,
Jan 19 16:44:42 coolserver tempfish-web[66390]: [Symbol(kCapture)]: false
Jan 19 16:44:42 coolserver tempfish-web[66390]: },
Jan 19 16:44:42 coolserver tempfish-web[66390]: https: Agent {
Jan 19 16:44:42 coolserver tempfish-web[66390]: _events: [Object: null prototype],
Jan 19 16:44:42 coolserver tempfish-web[66390]: _eventsCount: 2,
Jan 19 16:44:42 coolserver tempfish-web[66390]: _maxListeners: undefined,
Jan 19 16:44:42 coolserver tempfish-web[66390]: defaultPort: 443,
Jan 19 16:44:42 coolserver tempfish-web[66390]: protocol: 'https:',
Jan 19 16:44:42 coolserver tempfish-web[66390]: options: [Object: null prototype],
Jan 19 16:44:42 coolserver tempfish-web[66390]: requests: [Object: null prototype] {},
Jan 19 16:44:42 coolserver tempfish-web[66390]: sockets: [Object: null prototype],
Jan 19 16:44:42 coolserver tempfish-web[66390]: freeSockets: [Object: null prototype] {},
Jan 19 16:44:42 coolserver tempfish-web[66390]: keepAliveMsecs: 30000,
Jan 19 16:44:42 coolserver tempfish-web[66390]: keepAlive: true,
Jan 19 16:44:42 coolserver tempfish-web[66390]: maxSockets: Infinity,
Jan 19 16:44:42 coolserver tempfish-web[66390]: maxFreeSockets: 256,
Jan 19 16:44:42 coolserver tempfish-web[66390]: scheduling: 'lifo',
Jan 19 16:44:42 coolserver tempfish-web[66390]: maxTotalSockets: Infinity,
Jan 19 16:44:42 coolserver tempfish-web[66390]: totalSocketCount: 1,
Jan 19 16:44:42 coolserver tempfish-web[66390]: maxCachedSessions: 100,
Jan 19 16:44:42 coolserver tempfish-web[66390]: _sessionCache: [Object],
Jan 19 16:44:42 coolserver tempfish-web[66390]: [Symbol(shapeMode)]: false,
Jan 19 16:44:42 coolserver tempfish-web[66390]: [Symbol(kCapture)]: false
Jan 19 16:44:42 coolserver tempfish-web[66390]: },
Jan 19 16:44:42 coolserver tempfish-web[66390]: http2: undefined
Jan 19 16:44:42 coolserver tempfish-web[66390]: },
Jan 19 16:44:42 coolserver tempfish-web[66390]: h2session: undefined,
Jan 19 16:44:42 coolserver tempfish-web[66390]: decompress: true,
Jan 19 16:44:42 coolserver tempfish-web[66390]: timeout: {
Jan 19 16:44:42 coolserver tempfish-web[66390]: connect: 30000,
Jan 19 16:44:42 coolserver tempfish-web[66390]: lookup: 30000,
Jan 19 16:44:42 coolserver tempfish-web[66390]: read: undefined,
Jan 19 16:44:42 coolserver tempfish-web[66390]: request: 60000,
Jan 19 16:44:42 coolserver tempfish-web[66390]: response: 30000,
Jan 19 16:44:42 coolserver tempfish-web[66390]: secureConnect: 30000,
Jan 19 16:44:42 coolserver tempfish-web[66390]: send: 30000,
Jan 19 16:44:42 coolserver tempfish-web[66390]: socket: 30000
Jan 19 16:44:42 coolserver tempfish-web[66390]: },
Jan 19 16:44:42 coolserver tempfish-web[66390]: prefixUrl: '',
Jan 19 16:44:42 coolserver tempfish-web[66390]: body: undefined,
Jan 19 16:44:42 coolserver tempfish-web[66390]: form: undefined,
Jan 19 16:44:42 coolserver tempfish-web[66390]: json: undefined,
Jan 19 16:44:42 coolserver tempfish-web[66390]: cookieJar: undefined,
Jan 19 16:44:42 coolserver tempfish-web[66390]: ignoreInvalidCookies: false,
Jan 19 16:44:42 coolserver tempfish-web[66390]: searchParams: undefined,
Jan 19 16:44:42 coolserver tempfish-web[66390]: dnsLookup: undefined,
Jan 19 16:44:42 coolserver tempfish-web[66390]: dnsCache: undefined,
Jan 19 16:44:42 coolserver tempfish-web[66390]: context: {},
Jan 19 16:44:42 coolserver tempfish-web[66390]: hooks: {
Jan 19 16:44:42 coolserver tempfish-web[66390]: init: [],
Jan 19 16:44:42 coolserver tempfish-web[66390]: beforeRequest: [],
Jan 19 16:44:42 coolserver tempfish-web[66390]: beforeError: [],
Jan 19 16:44:42 coolserver tempfish-web[66390]: beforeRedirect: [],
Jan 19 16:44:42 coolserver tempfish-web[66390]: beforeRetry: [],
Jan 19 16:44:42 coolserver tempfish-web[66390]: afterResponse: []
Jan 19 16:44:42 coolserver tempfish-web[66390]: },
Jan 19 16:44:42 coolserver tempfish-web[66390]: followRedirect: true,
Jan 19 16:44:42 coolserver tempfish-web[66390]: maxRedirects: 10,
Jan 19 16:44:42 coolserver tempfish-web[66390]: cache: undefined,
Jan 19 16:44:42 coolserver tempfish-web[66390]: throwHttpErrors: true,
Jan 19 16:44:42 coolserver tempfish-web[66390]: username: '',
Jan 19 16:44:42 coolserver tempfish-web[66390]: password: '',
Jan 19 16:44:42 coolserver tempfish-web[66390]: http2: false,
Jan 19 16:44:42 coolserver tempfish-web[66390]: allowGetBody: false,
Jan 19 16:44:42 coolserver tempfish-web[66390]: headers: {
Jan 19 16:44:42 coolserver tempfish-web[66390]: 'user-agent': 'Misskey/2023.12.0 (https://testing.coolwebsite.zone/)',
Jan 19 16:44:42 coolserver tempfish-web[66390]: 'accept-encoding': 'gzip, deflate, br'
Jan 19 16:44:42 coolserver tempfish-web[66390]: },
Jan 19 16:44:42 coolserver tempfish-web[66390]: methodRewriting: false,
Jan 19 16:44:42 coolserver tempfish-web[66390]: dnsLookupIpVersion: undefined,
Jan 19 16:44:42 coolserver tempfish-web[66390]: parseJson: [Function: parse],
Jan 19 16:44:42 coolserver tempfish-web[66390]: stringifyJson: [Function: stringify],
Jan 19 16:44:42 coolserver tempfish-web[66390]: retry: {
Jan 19 16:44:42 coolserver tempfish-web[66390]: limit: 0,
Jan 19 16:44:42 coolserver tempfish-web[66390]: methods: [ 'GET', 'PUT', 'HEAD', 'DELETE', 'OPTIONS', 'TRACE' ],
Jan 19 16:44:42 coolserver tempfish-web[66390]: statusCodes: [
Jan 19 16:44:42 coolserver tempfish-web[66390]: 408, 413, 429, 500,
Jan 19 16:44:42 coolserver tempfish-web[66390]: 502, 503, 504, 521,
Jan 19 16:44:42 coolserver tempfish-web[66390]: 522, 524
Jan 19 16:44:42 coolserver tempfish-web[66390]: ],
Jan 19 16:44:42 coolserver tempfish-web[66390]: errorCodes: [
Jan 19 16:44:42 coolserver tempfish-web[66390]: 'ETIMEDOUT',
Jan 19 16:44:42 coolserver tempfish-web[66390]: 'ECONNRESET',
Jan 19 16:44:42 coolserver tempfish-web[66390]: 'EADDRINUSE',
Jan 19 16:44:42 coolserver tempfish-web[66390]: 'ECONNREFUSED',
Jan 19 16:44:42 coolserver tempfish-web[66390]: 'EPIPE',
Jan 19 16:44:42 coolserver tempfish-web[66390]: 'ENOTFOUND',
Jan 19 16:44:42 coolserver tempfish-web[66390]: 'ENETUNREACH',
Jan 19 16:44:42 coolserver tempfish-web[66390]: 'EAI_AGAIN'
Jan 19 16:44:42 coolserver tempfish-web[66390]: ],
Jan 19 16:44:42 coolserver tempfish-web[66390]: maxRetryAfter: undefined,
Jan 19 16:44:42 coolserver tempfish-web[66390]: calculateDelay: [Function: calculateDelay],
Jan 19 16:44:42 coolserver tempfish-web[66390]: backoffLimit: Infinity,
Jan 19 16:44:42 coolserver tempfish-web[66390]: noise: 100
Jan 19 16:44:42 coolserver tempfish-web[66390]: },
Jan 19 16:44:42 coolserver tempfish-web[66390]: localAddress: undefined,
Jan 19 16:44:42 coolserver tempfish-web[66390]: method: 'GET',
Jan 19 16:44:42 coolserver tempfish-web[66390]: createConnection: undefined,
Jan 19 16:44:42 coolserver tempfish-web[66390]: cacheOptions: {
Jan 19 16:44:42 coolserver tempfish-web[66390]: shared: undefined,
Jan 19 16:44:42 coolserver tempfish-web[66390]: cacheHeuristic: undefined,
Jan 19 16:44:42 coolserver tempfish-web[66390]: immutableMinTimeToLive: undefined,
Jan 19 16:44:42 coolserver tempfish-web[66390]: ignoreCargoCult: undefined
Jan 19 16:44:42 coolserver tempfish-web[66390]: },
Jan 19 16:44:42 coolserver tempfish-web[66390]: https: {
Jan 19 16:44:42 coolserver tempfish-web[66390]: alpnProtocols: undefined,
Jan 19 16:44:42 coolserver tempfish-web[66390]: rejectUnauthorized: undefined,
Jan 19 16:44:42 coolserver tempfish-web[66390]: checkServerIdentity: undefined,
Jan 19 16:44:42 coolserver tempfish-web[66390]: certificateAuthority: undefined,
Jan 19 16:44:42 coolserver tempfish-web[66390]: key: undefined,
Jan 19 16:44:42 coolserver tempfish-web[66390]: certificate: undefined,
Jan 19 16:44:42 coolserver tempfish-web[66390]: passphrase: undefined,
Jan 19 16:44:42 coolserver tempfish-web[66390]: pfx: undefined,
Jan 19 16:44:42 coolserver tempfish-web[66390]: ciphers: undefined,
Jan 19 16:44:42 coolserver tempfish-web[66390]: honorCipherOrder: undefined,
Jan 19 16:44:42 coolserver tempfish-web[66390]: minVersion: undefined,
Jan 19 16:44:42 coolserver tempfish-web[66390]: maxVersion: undefined,
Jan 19 16:44:42 coolserver tempfish-web[66390]: signatureAlgorithms: undefined,
Jan 19 16:44:42 coolserver tempfish-web[66390]: tlsSessionLifetime: undefined,
Jan 19 16:44:42 coolserver tempfish-web[66390]: dhparam: undefined,
Jan 19 16:44:42 coolserver tempfish-web[66390]: ecdhCurve: undefined,
Jan 19 16:44:42 coolserver tempfish-web[66390]: certificateRevocationLists: undefined
Jan 19 16:44:42 coolserver tempfish-web[66390]: },
Jan 19 16:44:42 coolserver tempfish-web[66390]: encoding: undefined,
Jan 19 16:44:42 coolserver tempfish-web[66390]: resolveBodyOnly: false,
Jan 19 16:44:42 coolserver tempfish-web[66390]: isStream: true,
Jan 19 16:44:42 coolserver tempfish-web[66390]: responseType: 'text',
Jan 19 16:44:42 coolserver tempfish-web[66390]: url: URL {
Jan 19 16:44:42 coolserver tempfish-web[66390]: href: 'https://testing.coolwebsite.zone/files/8e193f52-14ba-4b06-b637-2aeaa8e6ebab',
Jan 19 16:44:42 coolserver tempfish-web[66390]: origin: 'https://testing.coolwebsite.zone',
Jan 19 16:44:42 coolserver tempfish-web[66390]: protocol: 'https:',
Jan 19 16:44:42 coolserver tempfish-web[66390]: username: '',
Jan 19 16:44:42 coolserver tempfish-web[66390]: password: '',
Jan 19 16:44:42 coolserver tempfish-web[66390]: host: 'testing.coolwebsite.zone',
Jan 19 16:44:42 coolserver tempfish-web[66390]: hostname: 'testing.coolwebsite.zone',
Jan 19 16:44:42 coolserver tempfish-web[66390]: port: '',
Jan 19 16:44:42 coolserver tempfish-web[66390]: pathname: '/files/8e193f52-14ba-4b06-b637-2aeaa8e6ebab',
Jan 19 16:44:42 coolserver tempfish-web[66390]: search: '',
Jan 19 16:44:42 coolserver tempfish-web[66390]: searchParams: URLSearchParams {},
Jan 19 16:44:42 coolserver tempfish-web[66390]: hash: ''
Jan 19 16:44:42 coolserver tempfish-web[66390]: },
Jan 19 16:44:42 coolserver tempfish-web[66390]: pagination: {
Jan 19 16:44:42 coolserver tempfish-web[66390]: transform: [Function: transform],
Jan 19 16:44:42 coolserver tempfish-web[66390]: paginate: [Function: paginate],
Jan 19 16:44:42 coolserver tempfish-web[66390]: filter: [Function: filter],
Jan 19 16:44:42 coolserver tempfish-web[66390]: shouldContinue: [Function: shouldContinue],
Jan 19 16:44:42 coolserver tempfish-web[66390]: countLimit: Infinity,
Jan 19 16:44:42 coolserver tempfish-web[66390]: backoff: 0,
Jan 19 16:44:42 coolserver tempfish-web[66390]: requestLimit: 10000,
Jan 19 16:44:42 coolserver tempfish-web[66390]: stackAllItems: false
Jan 19 16:44:42 coolserver tempfish-web[66390]: },
Jan 19 16:44:42 coolserver tempfish-web[66390]: setHost: true,
Jan 19 16:44:42 coolserver tempfish-web[66390]: maxHeaderSize: undefined,
Jan 19 16:44:42 coolserver tempfish-web[66390]: signal: undefined,
Jan 19 16:44:42 coolserver tempfish-web[66390]: enableUnixSockets: false
Jan 19 16:44:42 coolserver tempfish-web[66390]: }
Jan 19 16:44:42 coolserver tempfish-web[66390]: }
Jan 19 16:44:42 coolserver tempfish-web[66390]: }
Jan 19 16:44:42 coolserver tempfish-web[66390]: WARN 1 [queue db] failed(RequestError
Jan 19 16:44:42 coolserver tempfish-web[66390]: at ClientRequest.<anonymous> (file:///sharkey/node_modules/.pnpm/got@14.0.0/node_modules/got/dist/source/core/index.js:669:107)
Jan 19 16:44:42 coolserver tempfish-web[66390]: at Object.onceWrapper (node:events:634:26)
Jan 19 16:44:42 coolserver tempfish-web[66390]: at ClientRequest.emit (node:events:531:35)
Jan 19 16:44:42 coolserver tempfish-web[66390]: at TLSSocket.socketErrorListener (node:_http_client:495:9)
Jan 19 16:44:42 coolserver tempfish-web[66390]: at TLSSocket.emit (node:events:519:28)
Jan 19 16:44:42 coolserver tempfish-web[66390]: at emitErrorNT (node:internal/streams/destroy:169:8)
Jan 19 16:44:42 coolserver tempfish-web[66390]: at emitErrorCloseNT (node:internal/streams/destroy:128:3)
Jan 19 16:44:42 coolserver tempfish-web[66390]: at process.processTicksAndRejections (node:internal/process/task_queues:82:21)AggregateError [ECONNREFUSED]:
Jan 19 16:44:42 coolserver tempfish-web[66390]: at internalConnectMultiple (node:net:1114:18)
Jan 19 16:44:42 coolserver tempfish-web[66390]: at afterConnectMultiple (node:net:1667:5)) id=59
Result of podman info
:
host:
arch: arm64
buildahVersion: 1.31.3
cgroupControllers:
- cpuset
- cpu
- io
- memory
- pids
cgroupManager: systemd
cgroupVersion: v2
conmon:
package: conmon-2.1.8-1.el9.aarch64
path: /usr/bin/conmon
version: 'conmon version 2.1.8, commit: 810a257df0be127ca4068b805d0810cea5e9468a'
cpuUtilization:
idlePercent: 99.12
systemPercent: 0.34
userPercent: 0.55
cpus: 8
databaseBackend: boltdb
distribution:
distribution: '"almalinux"'
version: "9.3"
eventLogger: journald
freeLocks: 2040
hostname: coolserver
idMappings:
gidmap:
- container_id: 0
host_id: 1000
size: 1
- container_id: 1
host_id: 100000
size: 65536
uidmap:
- container_id: 0
host_id: 1000
size: 1
- container_id: 1
host_id: 100000
size: 65536
kernel: 5.14.0-362.13.1.el9_3.aarch64
linkmode: dynamic
logDriver: journald
memFree: 13564891136
memTotal: 16001363968
networkBackend: netavark
networkBackendInfo:
backend: netavark
dns:
package: aardvark-dns-1.7.0-1.el9.aarch64
path: /usr/libexec/podman/aardvark-dns
version: aardvark-dns 1.7.0
package: netavark-1.7.0-2.el9_3.aarch64
path: /usr/libexec/podman/netavark
version: netavark 1.7.0
ociRuntime:
name: crun
package: crun-1.8.7-1.el9.aarch64
path: /usr/bin/crun
version: |-
crun version 1.8.7
commit: 53a9996ce82d1ee818349bdcc64797a1fa0433c4
rundir: /run/user/1000/crun
spec: 1.0.0
+SYSTEMD +SELINUX +APPARMOR +CAP +SECCOMP +EBPF +CRIU +YAJL
os: linux
pasta:
executable: /usr/bin/pasta
package: passt-0^20230818.g0af928e-4.el9.aarch64
version: |
pasta 0^20230818.g0af928e-4.el9.aarch64
Copyright Red Hat
GNU Affero GPL version 3 or later <https://www.gnu.org/licenses/agpl-3.0.html>
This is free software: you are free to change and redistribute it.
There is NO WARRANTY, to the extent permitted by law.
remoteSocket:
exists: true
path: /run/user/1000/podman/podman.sock
security:
apparmorEnabled: false
capabilities: CAP_CHOWN,CAP_DAC_OVERRIDE,CAP_FOWNER,CAP_FSETID,CAP_KILL,CAP_NET_BIND_SERVICE,CAP_SETFCAP,CAP_SETGID,CAP_SETPCAP,CAP_SETUID,CAP_SYS_CHROOT
rootless: true
seccompEnabled: true
seccompProfilePath: /usr/share/containers/seccomp.json
selinuxEnabled: true
serviceIsRemote: false
slirp4netns:
executable: /usr/bin/slirp4netns
package: slirp4netns-1.2.1-1.el9.aarch64
version: |-
slirp4netns version 1.2.1
commit: 09e31e92fa3d2a1d3ca261adaeb012c8d75a8194
libslirp: 4.4.0
SLIRP_CONFIG_VERSION_MAX: 3
libseccomp: 2.5.2
swapFree: 24001900544
swapTotal: 24001900544
uptime: 0h 53m 4.00s
plugins:
authorization: null
log:
- k8s-file
- none
- passthrough
- journald
network:
- bridge
- macvlan
- ipvlan
volume:
- local
registries:
search:
- registry.access.redhat.com
- registry.redhat.io
- docker.io
store:
configFile: /home/$user/.config/containers/storage.conf
containerStore:
number: 1
paused: 0
running: 1
stopped: 0
graphDriverName: overlay
graphOptions: {}
graphRoot: /home/$user/.local/share/containers/storage
graphRootAllocated: 161123659776
graphRootUsed: 3257196544
graphStatus:
Backing Filesystem: extfs
Native Overlay Diff: "true"
Supports d_type: "true"
Using metacopy: "false"
imageCopyTmpDir: /var/tmp
imageStore:
number: 5
runRoot: /run/user/1000/containers
transientStore: false
volumePath: /home/$user/.local/share/containers/storage/volumes
version:
APIVersion: 4.6.1
Built: 1702419128
BuiltTime: Tue Dec 12 22:12:08 2023
GitCommit: ""
GoVersion: go1.20.10
Os: linux
OsArch: linux/arm64
Version: 4.6.1
Results of podman inspect
on the pod:
{
"Id": "09b3eca204fb48689eb2bd9faf7768f8dc3b2d0824a8660cb2fc18f18ff02d52",
"Name": "tempfish",
"Created": "2024-01-19T17:54:44.209372874Z",
"CreateCommand": [
"podman",
"pod",
"create",
"--name=tempfish",
"--infra",
"--replace",
"--network=pasta:--map-gw,--mtu=1500",
"-p=6665:6665",
"--memory=6g",
"--cpu-shares=2048"
],
"ExitPolicy": "continue",
"State": "Running",
"Hostname": "",
"CreateCgroup": true,
"CgroupParent": "user.slice",
"CgroupPath": "user.slice/user-libpod_pod_09b3eca204fb48689eb2bd9faf7768f8dc3b2d0824a8660cb2fc18f18ff02d52.slice",
"CreateInfra": true,
"InfraContainerID": "939141af4bec1d80811030b97a9b8bceb474fd5e69ed09bf7456448b533ce724",
"InfraConfig": {
"PortBindings": {
"6665/tcp": [
{
"HostIp": "",
"HostPort": "6665"
}
]
},
"HostNetwork": false,
"StaticIP": "",
"StaticMAC": "",
"NoManageResolvConf": false,
"DNSServer": null,
"DNSSearch": null,
"DNSOption": null,
"NoManageHosts": false,
"HostAdd": null,
"Networks": null,
"NetworkOptions": {
"pasta": [
"--map-gw",
"--mtu=1500"
]
},
"pid_ns": "private",
"userns": "host",
"uts_ns": "private"
},
"SharedNamespaces": [
"ipc",
"net",
"uts"
],
"NumContainers": 5,
"Containers": [
{
"Id": "218979ac49f63a9b5f8c6e376516ff4da548dd41a0bb28af4af8f68f4926534f",
"Name": "tempfish-web",
"State": "running"
},
{
"Id": "7d2ebff23491bfb174138b98c929fc18c75061aa20317afa88e38576b2bf5524",
"Name": "tempfish-db",
"State": "running"
},
{
"Id": "939141af4bec1d80811030b97a9b8bceb474fd5e69ed09bf7456448b533ce724",
"Name": "09b3eca204fb-infra",
"State": "running"
},
{
"Id": "df329081e3287f82a2f5dccda9d65959b932848aa55088f07ea5b17fddd02eb4",
"Name": "tempfish-redis",
"State": "running"
},
{
"Id": "f1df23db1c72489ed189ca9afe10b17b5e2660071a48e815f37e750889c6a1d7",
"Name": "tempfish-postfix",
"State": "running"
}
],
"cpu_shares": 2048,
"memory_limit": 6442450944,
"memory_swap": 12884901888,
"LockNumber": 47
}
Result of podman inspect
on the Sharkey container:
[
{
"Id": "218979ac49f63a9b5f8c6e376516ff4da548dd41a0bb28af4af8f68f4926534f",
"Created": "2024-01-19T17:54:45.293916304Z",
"Path": "/sbin/tini",
"Args": [
"--",
"pnpm",
"run",
"migrateandstart"
],
"State": {
"OciVersion": "1.1.0-rc.3",
"Status": "running",
"Running": true,
"Paused": false,
"Restarting": false,
"OOMKilled": false,
"Dead": false,
"Pid": 114250,
"ConmonPid": 114248,
"ExitCode": 0,
"Error": "",
"StartedAt": "2024-01-19T17:54:45.36098498Z",
"FinishedAt": "0001-01-01T00:00:00Z",
"Health": {
"Status": "",
"FailingStreak": 0,
"Log": null
},
"CgroupPath": "/user.slice/user-1000.slice/user@1000.service/user.slice/user-libpod_pod_09b3eca204fb48689eb2bd9faf7768f8dc3b2d0824a8660cb2fc18f18ff02d52.slice/libpod-218979ac49f63a9b5f8c6e376516ff4da548dd41a0bb28af4af8f68f4926534f.scope",
"CheckpointedAt": "0001-01-01T00:00:00Z",
"RestoredAt": "0001-01-01T00:00:00Z"
},
"Image": "d28efdbdfe0b2474f35cc01d23a7a63b42878f3ce00663235e777d5eb7bb0e19",
"ImageDigest": "sha256:6ed0a885c52c2eb3feefc91ff67fa6c19c4c191a9851584dd8a8a3fa6f8d3e70",
"ImageName": "git.joinsharkey.org/sharkey/sharkey:stable",
"Rootfs": "",
"Pod": "09b3eca204fb48689eb2bd9faf7768f8dc3b2d0824a8660cb2fc18f18ff02d52",
"ResolvConfPath": "/run/user/1000/containers/overlay-containers/939141af4bec1d80811030b97a9b8bceb474fd5e69ed09bf7456448b533ce724/userdata/resolv.conf",
"HostnamePath": "/run/user/1000/containers/overlay-containers/218979ac49f63a9b5f8c6e376516ff4da548dd41a0bb28af4af8f68f4926534f/userdata/hostname",
"HostsPath": "/run/user/1000/containers/overlay-containers/939141af4bec1d80811030b97a9b8bceb474fd5e69ed09bf7456448b533ce724/userdata/hosts",
"StaticDir": "/home/$user/.local/share/containers/storage/overlay-containers/218979ac49f63a9b5f8c6e376516ff4da548dd41a0bb28af4af8f68f4926534f/userdata",
"OCIConfigPath": "/home/$user/.local/share/containers/storage/overlay-containers/218979ac49f63a9b5f8c6e376516ff4da548dd41a0bb28af4af8f68f4926534f/userdata/config.json",
"OCIRuntime": "crun",
"ConmonPidFile": "/run/user/1000/containers/overlay-containers/218979ac49f63a9b5f8c6e376516ff4da548dd41a0bb28af4af8f68f4926534f/userdata/conmon.pid",
"PidFile": "/run/user/1000/containers/overlay-containers/218979ac49f63a9b5f8c6e376516ff4da548dd41a0bb28af4af8f68f4926534f/userdata/pidfile",
"Name": "tempfish-web",
"RestartCount": 0,
"Driver": "overlay",
"MountLabel": "system_u:object_r:container_file_t:s0:c716,c883",
"ProcessLabel": "system_u:system_r:container_t:s0:c716,c883",
"AppArmorProfile": "",
"EffectiveCaps": [
"CAP_CHOWN",
"CAP_DAC_OVERRIDE",
"CAP_FOWNER",
"CAP_FSETID",
"CAP_KILL",
"CAP_NET_BIND_SERVICE",
"CAP_SETFCAP",
"CAP_SETGID",
"CAP_SETPCAP",
"CAP_SETUID",
"CAP_SYS_CHROOT"
],
"BoundingCaps": [
"CAP_CHOWN",
"CAP_DAC_OVERRIDE",
"CAP_FOWNER",
"CAP_FSETID",
"CAP_KILL",
"CAP_NET_BIND_SERVICE",
"CAP_SETFCAP",
"CAP_SETGID",
"CAP_SETPCAP",
"CAP_SETUID",
"CAP_SYS_CHROOT"
],
"ExecIDs": [],
"GraphDriver": {
"Name": "overlay",
"Data": {
"LowerDir": "/home/$user/.local/share/containers/storage/overlay/e80fa2f6ff041ecb4c32c560b70a25ed08e597f4f3dbb3f292bdb1e085ac4567/diff:/home/$user/.local/share/containers/storage/overlay/aa611beb273abe937e652a19854f1158ba091400aac800707c501a1c8a6b42b0/diff:/home/$user/.local/share/containers/storage/overlay/21a9dbdc0524e751b1c35087233045a13139c4080da5625bea7359f22e601f45/diff:/home/$user/.local/share/containers/storage/overlay/f3b8e22e621b5a84ef3f065ef256dad3fdd414c19a1cab271647419b46251182/diff:/home/$user/.local/share/containers/storage/overlay/bba1418f552ef375900fda47fe41c91e3d03455cac4d61999fc62de50780996c/diff:/home/$user/.local/share/containers/storage/overlay/88645f04cf4c7125749804d7ae07b78c25959a0a29da87e579b70d964e5aa02d/diff:/home/$user/.local/share/containers/storage/overlay/0aef0fbade3c59e24d43878349d6cc275d166172d4662e7ba4dd754a17aa8497/diff:/home/$user/.local/share/containers/storage/overlay/aedc1bb08e75f6a0deae7bb6f791202a1e8f8279db8b2a01fc0ba3c9038bde87/diff:/home/$user/.local/share/containers/storage/overlay/269ac36e055b63ebdab94fdc45cbee6d61e0fcfb6b121b3a468262e346a09006/diff:/home/$user/.local/share/containers/storage/overlay/2083d8571b109973fe77ff0905fea91e1de548aff8fad988bcde7d3470879fa0/diff:/home/$user/.local/share/containers/storage/overlay/de412219ca61a504ea6e15f9e359eee135ae0bdd82f1138d7292c4c055b883a0/diff:/home/$user/.local/share/containers/storage/overlay/4616523d06eacc9d0b70bab56947e5458bca3319575f44650e674f011698b6d8/diff:/home/$user/.local/share/containers/storage/overlay/ae0b9a950e2e299fa29802ea6c85ba160932d81d7578c27a32d1dedf4699e723/diff:/home/$user/.local/share/containers/storage/overlay/719fc960a299689672a91f66f1c4b549f5d084bbc141bdcddc34bc5f47ade49b/diff:/home/$user/.local/share/containers/storage/overlay/79c3eb2857c871a5717cbf4417dd2b547ad6807d25798ed45be91e1ed8e66be2/diff:/home/$user/.local/share/containers/storage/overlay/4f0b61344e0338ac875d0f257ea5b159e86bf80472dc2851372bfc7392f5868e/diff:/home/$user/.local/share/containers/storage/overlay/61061a8540f0a0da7c0437ded314e3d832b32ad2c83f06e65fef6d250cda2d1e/diff:/home/$user/.local/share/containers/storage/overlay/e044d0920300e9fd63dd6c26be5a4c9f8f15d89c7fecb94aa107a518cbd55fa6/diff:/home/$user/.local/share/containers/storage/overlay/51e4f3f82af83abf98965534930029464aca2483d58fa81ac4cdbdffdc199738/diff:/home/$user/.local/share/containers/storage/overlay/27f8802fd67e0aeec6b8f01aa863cc82f5eeb5ec5e02e2680ebfc4f2f7db1dc9/diff:/home/$user/.local/share/containers/storage/overlay/9a5636492093cd121d5031e66801553559fc5c98b034e80ae108d3d6dd49db6b/diff:/home/$user/.local/share/containers/storage/overlay/1dcdeb34f9f2583c7b06cc39db6878f2c0a93c20c8245708c980c30f0da84e0c/diff:/home/$user/.local/share/containers/storage/overlay/a30bc022b2298912695fc3768b9ce12ab3712dc473f2c613a30102c0daefddf5/diff:/home/$user/.local/share/containers/storage/overlay/c81a2947c3c3e60574a26c382c7e6b97fcf057b68b3007138497774d37a3fb7f/diff:/home/$user/.local/share/containers/storage/overlay/737ee409dd1d262c339f47a3d7ed2bfe3b239f4a39ea3d36324aee5770989e08/diff:/home/$user/.local/share/containers/storage/overlay/0faf9b67be60a76d473c955d4de2849da5e99e07fcefb753219631e1e7b608fb/diff",
"MergedDir": "/home/$user/.local/share/containers/storage/overlay/c951d362915b7c4416f55817600bb4d43ee3437355378a6e9498f3a57f056494/merged",
"UpperDir": "/home/$user/.local/share/containers/storage/overlay/c951d362915b7c4416f55817600bb4d43ee3437355378a6e9498f3a57f056494/diff",
"WorkDir": "/home/$user/.local/share/containers/storage/overlay/c951d362915b7c4416f55817600bb4d43ee3437355378a6e9498f3a57f056494/work"
}
},
"Mounts": [
{
"Type": "volume",
"Name": "tempfish-files",
"Source": "/home/$user/.local/share/containers/storage/volumes/tempfish-files/_data",
"Destination": "/sharkey/files",
"Driver": "local",
"Mode": "z",
"Options": [
"nosuid",
"nodev",
"rbind"
],
"RW": true,
"Propagation": "rprivate"
},
{
"Type": "bind",
"Source": "/home/$user/.tempconf/.config",
"Destination": "/sharkey/.config",
"Driver": "",
"Mode": "",
"Options": [
"rbind"
],
"RW": false,
"Propagation": "rprivate"
}
],
"Dependencies": [
"7d2ebff23491bfb174138b98c929fc18c75061aa20317afa88e38576b2bf5524",
"df329081e3287f82a2f5dccda9d65959b932848aa55088f07ea5b17fddd02eb4",
"939141af4bec1d80811030b97a9b8bceb474fd5e69ed09bf7456448b533ce724"
],
"NetworkSettings": {
"EndpointID": "",
"Gateway": "",
"IPAddress": "",
"IPPrefixLen": 0,
"IPv6Gateway": "",
"GlobalIPv6Address": "",
"GlobalIPv6PrefixLen": 0,
"MacAddress": "",
"Bridge": "",
"SandboxID": "",
"HairpinMode": false,
"LinkLocalIPv6Address": "",
"LinkLocalIPv6PrefixLen": 0,
"Ports": {
"6665/tcp": [
{
"HostIp": "",
"HostPort": "6665"
}
]
},
"SandboxKey": "/run/user/1000/netns/netns-922cc4a7-257a-ab31-5611-2afb41b3983d"
},
"Namespace": "",
"IsInfra": false,
"IsService": false,
"KubeExitCodePropagation": "invalid",
"lockNumber": 51,
"Config": {
"Hostname": "tempfish",
"Domainname": "",
"User": "",
"AttachStdin": false,
"AttachStdout": false,
"AttachStderr": false,
"Tty": false,
"OpenStdin": false,
"StdinOnce": false,
"Env": [
"NODE_VERSION=21.4.0",
"YARN_VERSION=1.22.19",
"NODE_ENV=production",
"PATH=/usr/local/sbin:/usr/local/bin:/usr/sbin:/usr/bin:/sbin:/bin",
"TERM=xterm",
"container=podman",
"HOME=/root",
"HOSTNAME=tempfish"
],
"Cmd": [
"pnpm",
"run",
"migrateandstart"
],
"Image": "git.joinsharkey.org/sharkey/sharkey:stable",
"Volumes": null,
"WorkingDir": "/sharkey",
"Entrypoint": "/sbin/tini --",
"OnBuild": null,
"Labels": {
"org.opencontainers.image.created": "2023-12-31T22:24:24.262Z",
"org.opencontainers.image.description": "🌎 A Sharkish microblogging platform 🚀",
"org.opencontainers.image.licenses": "",
"org.opencontainers.image.revision": "b81448edf6e6dde9a3e5ffcbb840bb64f6bc6621",
"org.opencontainers.image.source": "https://git.joinsharkey.org/Sharkey/Sharkey",
"org.opencontainers.image.title": "Sharkey",
"org.opencontainers.image.url": "https://git.joinsharkey.org/Sharkey/Sharkey",
"org.opencontainers.image.version": "2023.12.0"
},
"Annotations": {
"io.container.manager": "libpod",
"io.kubernetes.cri-o.SandboxID": "939141af4bec1d80811030b97a9b8bceb474fd5e69ed09bf7456448b533ce724",
"org.opencontainers.image.stopSignal": "15"
},
"StopSignal": 15,
"HealthcheckOnFailureAction": "none",
"CreateCommand": [
"podman",
"run",
"--pod=tempfish",
"--name=tempfish-web",
"--requires=tempfish-db,tempfish-redis",
"-v=tempfish-files:/sharkey/files:z",
"-v=/home/$user/.tempconf/.config:/sharkey/.config:z,ro",
"--restart=always",
"--pull=newer",
"--replace",
"-d",
"git.joinsharkey.org/sharkey/sharkey:stable"
],
"Umask": "0022",
"Timeout": 0,
"StopTimeout": 10,
"Passwd": true,
"sdNotifyMode": "container"
},
"HostConfig": {
"Binds": [
"tempfish-files:/sharkey/files:z,rw,rprivate,nosuid,nodev,rbind",
"/home/$user/.tempconf/.config:/sharkey/.config:ro,rprivate,rbind"
],
"CgroupManager": "systemd",
"CgroupMode": "private",
"ContainerIDFile": "",
"LogConfig": {
"Type": "journald",
"Config": null,
"Path": "",
"Tag": "",
"Size": "0B"
},
"NetworkMode": "container:939141af4bec1d80811030b97a9b8bceb474fd5e69ed09bf7456448b533ce724",
"PortBindings": {},
"RestartPolicy": {
"Name": "always",
"MaximumRetryCount": 0
},
"AutoRemove": false,
"VolumeDriver": "",
"VolumesFrom": null,
"CapAdd": [],
"CapDrop": [],
"Dns": [],
"DnsOptions": [],
"DnsSearch": [],
"ExtraHosts": [],
"GroupAdd": [],
"IpcMode": "container:939141af4bec1d80811030b97a9b8bceb474fd5e69ed09bf7456448b533ce724",
"Cgroup": "",
"Cgroups": "default",
"Links": null,
"OomScoreAdj": 0,
"PidMode": "private",
"Privileged": false,
"PublishAllPorts": false,
"ReadonlyRootfs": false,
"SecurityOpt": [],
"Tmpfs": {},
"UTSMode": "container:939141af4bec1d80811030b97a9b8bceb474fd5e69ed09bf7456448b533ce724",
"UsernsMode": "",
"ShmSize": 65536000,
"Runtime": "oci",
"ConsoleSize": [
0,
0
],
"Isolation": "",
"CpuShares": 0,
"Memory": 0,
"NanoCpus": 0,
"CgroupParent": "user.slice/user-libpod_pod_09b3eca204fb48689eb2bd9faf7768f8dc3b2d0824a8660cb2fc18f18ff02d52.slice",
"BlkioWeight": 0,
"BlkioWeightDevice": null,
"BlkioDeviceReadBps": null,
"BlkioDeviceWriteBps": null,
"BlkioDeviceReadIOps": null,
"BlkioDeviceWriteIOps": null,
"CpuPeriod": 0,
"CpuQuota": 0,
"CpuRealtimePeriod": 0,
"CpuRealtimeRuntime": 0,
"CpusetCpus": "",
"CpusetMems": "",
"Devices": [],
"DiskQuota": 0,
"KernelMemory": 0,
"MemoryReservation": 0,
"MemorySwap": 0,
"MemorySwappiness": 0,
"OomKillDisable": false,
"PidsLimit": 2048,
"Ulimits": [
{
"Name": "RLIMIT_NOFILE",
"Soft": 524288,
"Hard": 524288
},
{
"Name": "RLIMIT_NPROC",
"Soft": 60905,
"Hard": 60905
}
],
"CpuCount": 0,
"CpuPercent": 0,
"IOMaximumIOps": 0,
"IOMaximumBandwidth": 0,
"CgroupConf": null
}
}
]
📝 Steps to Reproduce
Here is the script I used to deploy.
#!/bin/bash
# tempfish.sh
set -e
podman pod create --name=tempfish --infra --replace \
--network=pasta:--map-gw,--mtu=1500 -p=3000:3000 \
--memory=6g --cpu-shares=2048
podman run --pod=tempfish --name=tempfish-db \
-e=POSTGRES_DB="misskey" \
-e=POSTGRES_USER="example-misskey-user" \
-e=POSTGRES_PASSWORD="example-misskey-pass" \
-e=DATABASE_URL="postgres://${POSTGRES_USER}:${POSTGRES_PASSWORD}@127.0.0.1:5432/${POSTGRES_DB}" \
-v=tempfish-db:/var/lib/postgresql/data:Z \
--health-cmd="CMD-SHELL pg_isready -U example-misskey-user -d misskey" \
--health-interval=300s --health-timeout=3s --health-retries=4 \
--restart=always --replace -d docker.io/postgres:16-alpine
podman run --pod=tempfish --name=tempfish-redis \
-v=tempfish-redis:/data:Z \
--health-cmd="CMD-SHELL redis-cli ping" \
--health-interval=300s --health-timeout=3s --health-retries=4 \
--restart=always --replace -d docker.io/redis:7-alpine
podman run --pod=tempfish --name=tempfish-web \
--requires=tempfish-db,tempfish-redis \
-v=tempfish-files:/sharkey/files:z \
-v=/home/$user/.tempconf/.config:/sharkey/.config:z,ro \
--restart=always --pull=newer --replace -d git.joinsharkey.org/sharkey/sharkey:stable`
In default.yml, I changed the db and redis hosts to 127.0.0.1 for this to work properly. I am using Caddy in another container as my webserver, caddyfile is as follows:
https://testing.coolwebsite.zone {
reverse_proxy 172.31.1.1:3000
}
I should clarify that the postgres and redis containers are completely fine. Only the Sharkey container has any issues.
Things I've tried:
- Setting the
--privileged
flag on the containers - Every other network driver
- ipv4 only
- Setting
pid
uts
ipc
to host - Every
userns
option - Setting
--cap-add=all
- Changed the
:Z
flag on the db and redis volume mounts to:z
- Disabling SELinux and seccomp with
--security-opt
- Disabling SELinux entirely
- Running everything in the script as sudo, then everything already mentioned again that way
In hindsight, that was probably all unnecessary, because looking closer at the error, I realized it's complaining about TLS, and the error was the same no matter what I tried. I have no experience with Node.js and have no idea how to troubleshoot it.
Interestingly, I did have it working one time by running that script mostly as-is as sudo, but with the network set to bridge. Unfortunately, I really wanted to get it working rootless, so I deleted the working container and kept trying to figure this out. When I decided to give up and just run it with sudo since it worked before, the Sharkey container crashed immediately with this error:
Internal Error: Error when performing the request to https://registry.npmjs.org/pnpm; for troubleshooting help, see https://github.com/nodejs/corepack#troubleshooting
at ClientRequest.<anonymous> (/usr/local/lib/node_modules/corepack/dist/lib/corepack.cjs:42195:14)
at ClientRequest.emit (node:events:519:28)
at TLSSocket.socketErrorListener (node:_http_client:495:9)
at TLSSocket.emit (node:events:519:28)
at emitErrorNT (node:internal/streams/destroy:169:8)
at emitErrorCloseNT (node:internal/streams/destroy:128:3)
at process.processTicksAndRejections (node:internal/process/task_queues:82:21)
TLS again. At this point, I found out about the HTTP_PROXY and HTTPS_PROXY environment variables, so I tried setting those to localhost, 127.0.0.1, and 0.0.0.0, but it crashed immediately with the same error minus the TLSSocket lines.
If you set up a fresh AlmaLinux system, install podman, and run this script as sudo with --network=bridge
, it might work perfectly. I have no idea what changed on my system to cause that to stop working. But since the error is the same with every other network driver, with or without root, this should be easily reproducible, and the fix will likely affect both rootful and rootless podman, so I don't believe simply running it as root is the answer.
I am assuming that the root cause of this problem has something to do with the way Node is configured in the image, rather than it being a problem with podman, because every other container I've used with rootless podman has worked without issue.
Sorry if this report is missing something you need, but I must admit that I am not knowledgeable on any of this. My background is entirely outside of this realm, I have limited experience with podman, and no experience at all with self-hosting Sharkey or Misskey, so I am lacking in my troubleshooting ability, and have no ability at all to create and contribute fixes myself.
💻 Frontend Environment
Irrelevant
🛰 Backend Environment (for server admin)
* Installation Method or Hosting Service: rootless podman, stable image
* Sharkey: 2023.12.0
* Node: 21.4.0
* PostgreSQL: 16.1
* Redis: 7.2.4
* OS and Architecture: AlmaLinux 9.3 aarch64
Do you want to address this bug yourself?
- Yes, I will patch the bug myself and send a pull request