71 lines
1.8 KiB
Markdown
71 lines
1.8 KiB
Markdown
---
|
|
title: Komga
|
|
---
|
|
|
|
## Create directories
|
|
`# mkdir -p /var/kavita/{config,content}`
|
|
`# mkdir -p /var/kavita/content/{manga,books,tech}`
|
|
|
|
## Run Kavita
|
|
```
|
|
# podman run --name kavita -p 5000:5000 \
|
|
-v /var/kavita/content:/content \
|
|
-v /var/kavita/config:/kavita/config \
|
|
--restart unless-stopped \
|
|
-d docker.io/kizaing/kavita:latest
|
|
```
|
|
|
|
## Nginx Config
|
|
```
|
|
server {
|
|
server_name kavita.exu.li;
|
|
|
|
# Security / XSS Mitigation Headers
|
|
add_header X-Frame-Options "SAMEORIGIN";
|
|
add_header X-XSS-Protection "1; mode=block";
|
|
add_header X-Content-Type-Options "nosniff";
|
|
add_header Strict-Transport-Security "max-age=31536000; includeSubDomains";
|
|
|
|
location / {
|
|
# Proxy main traffic
|
|
proxy_pass http://172.16.53.100:5000;
|
|
proxy_set_header Host $host;
|
|
proxy_set_header X-Real-IP $remote_addr;
|
|
proxy_set_header X-Forwarded-For $proxy_add_x_forwarded_for;
|
|
proxy_set_header X-Forwarded-Proto $scheme;
|
|
proxy_set_header X-Forwarded-Protocol $scheme;
|
|
proxy_set_header X-Forwarded-Host $http_host;
|
|
}
|
|
|
|
listen *:443 ssl http2; #set ipv6 address
|
|
ssl_certificate_key /etc/acme-sh/kavita.exu.li/key.pem;
|
|
ssl_certificate /etc/acme-sh/kavita.exu.li/cert.pem;
|
|
}
|
|
|
|
server {
|
|
if ($host = kavita.exu.li) {
|
|
return 301 https://$host$request_uri;
|
|
}
|
|
|
|
listen *:80; #set ipv6 address
|
|
server_name kavita.exu.li;
|
|
return 404;
|
|
}
|
|
```
|
|
|
|
## Systemd Service
|
|
*don't do this, use [Podman](/linux/services/podman) to generate a service file.*
|
|
`/etc/systemd/system/kavita.service`
|
|
```
|
|
[Unit]
|
|
Description=Kavita Podman container
|
|
[Service]
|
|
Restart=always
|
|
ExecStart=/usr/bin/podman start -a kavita
|
|
ExecStop=/usr/bin/podman stop -t 10 kavita
|
|
[Install]
|
|
WantedBy=multi-user.target
|
|
```
|
|
|
|
`# systemctl daemon-reload`
|
|
`# systemctl enable --now kavita` |