This Helm chart deploys Linkwarden, a self-hosted, open-source collaborative bookmark manager to collect, organize and preserve webpages, on a Kubernetes cluster.
- Linkwarden Helm Chart (Unofficial) 🔗
Linkwarden is a self-hosted, open-source collaborative bookmark manager to collect, organize and archive webpages.
The objective is to organize useful webpages and articles you find across the web in one place, and since useful webpages can go away (see the inevitability of Link Rot), Linkwarden also saves a copy of each webpage as a Screenshot and PDF, ensuring accessibility even if the original content is no longer available.
Additionally, Linkwarden is designed with collaboration in mind, sharing links with the public and/or allowing multiple users to work together seamlessly. Linkwarden allows you to save, tag, and organize links, as well as automatically archive the content for future access.
This Helm chart simplifies the deployment of Linkwarden within a Kubernetes environment, providing flexibility in terms of storage, database, and network configuration.
If you find this chart helpful, please consider giving it a star on GitHub! ⭐ Your support is greatly appreciated!
- Simplified Deployment: Easily deploy Linkwarden on Kubernetes using Helm.
- Flexible Configuration: Customize the deployment with a wide range of options via the
values.yaml
file. - Built-in PostgreSQL Database: Optionally deploy Linkwarden with an integrated PostgreSQL database using the CNPG operator.
- External Database Support: Connect to an external PostgreSQL database.
- Filesystem or S3 Storage: Choose between local filesystem storage using a Persistent Volume Claim or S3-compatible object storage for data persistence.
- Ingress Support: Expose Linkwarden to the internet using Ingress rules.
- SSO Integration: Supports multiple SSO providers for user authentication.
- Resource Management: Configure CPU/memory resource requests and limits.
- Autoscaling: Automatically scale the number of Linkwarden replicas based on demand.
- Security Contexts: Configure pod and container security contexts for enhanced security.
- Customizable Probes: Configure liveness and readiness probes for health monitoring.
- Easy Upgrades: Easily upgrade the chart to newer versions with Helm.
- Secrets Management: Ensure that sensitive values (like
nextAuthSecret
, database passwords for external databases, and API keys) are properly handled, ideally using Kubernetes secrets and not directly invalues.yaml
. - Ingress Security: When using ingress, configure TLS/SSL to ensure secure connections.
- Resource Limits: Set appropriate resource limits to prevent denial-of-service situations and ensure stability.
- Pod Security Context: Use the
podSecurityContext
andcontainerSecurityContext
to apply principle of least privilege. - Network Policies: (Optional) Consider implementing network policies to restrict network access between pods and services, especially for the database if you are not using the internal one.
- Kubernetes 1.25+
- Helm 3+
- (Optional) For Ingress: An Ingress Controller (e.g., Nginx, Traefik)
- (Optional) CloudNativePG (CNPG) Operator if using the built-in PostgreSQL database.
-
Add the Helm repository (if necessary):
helm repo add shivam-charts https://shivamkumar2002.github.io/helm-charts helm repo update
-
Install the chart:
helm install linkwarden shivam-charts/linkwarden -f <values.yaml>
Replace
<values.yaml>
with the path to your values.yaml file or create one. See the Configuration section for details. -
Access Linkwarden:
- If you have an ingress configured, access it through the URL specified in your ingress configuration.
- If not, you may need to set up port forwarding. Please refer to your Kubernetes setup.
This section details the configurable values in the values.yaml
file and how they influence the deployment.
Here's a breakdown of each section in your values.yaml
:
Key | Description | Default Value |
---|---|---|
nameOverride |
Overrides the chart's name. | "" |
fullnameOverride |
Overrides the chart's full name for resource naming. | "" |
replicaCount |
The number of Linkwarden application replicas. | 1 |
image.repository |
The container image repository. | ghcr.io/linkwarden/linkwarden |
image.pullPolicy |
The policy for pulling images (IfNotPresent , Always , Never ). |
IfNotPresent |
image.tag |
Overrides the image tag. Defaults to chart app version if left empty. | "" |
imagePullSecrets |
Array of secrets used to pull images from private repositories. | [] |
serviceAccount.create |
Whether to create a service account. | true |
serviceAccount.automount |
Automatically mount the service account's API credentials. | true |
serviceAccount.annotations |
Annotations for the service account. | {} |
serviceAccount.name |
The name of the service account. If not set, one will be generated. | "" |
service.type |
The service type (ClusterIP , NodePort , LoadBalancer ). |
ClusterIP |
service.port |
The service port exposed by the Linkwarden application. | 3000 |
livenessProbe.path |
The path to check for liveness. | / |
livenessProbe.port |
The port to check for liveness. | http |
livenessProbe.initialDelaySeconds |
Delay before the first liveness probe. | 30 |
livenessProbe.periodSeconds |
Frequency of the liveness probe. | 30 |
readinessProbe.path |
The path to check for readiness. | / |
readinessProbe.port |
The port to check for readiness. | http |
readinessProbe.initialDelaySeconds |
Delay before the first readiness probe. | 30 |
readinessProbe.periodSeconds |
Frequency of the readiness probe. | 30 |
linkwarden.existingSecret |
If set, all other Linkwarden environment secrets will be ignored and taken from this secret. | "" |
linkwarden.nextAuthUrl |
The URL of the NextAuth API. | http://localhost:3000/api/v1/auth |
linkwarden.nextAuthSecret |
A secret used for NextAuth. You can generate with openssl rand -base64 32 . |
"" |
linkwarden.disableRegistration |
Disable user registration. | false |
linkwarden.credentialsEnabled |
Enable login with username and password. | true |
linkwarden.disableNewSSOUsers |
Disable new user login with SSO. | false |
linkwarden.paginationTakeCount |
Number of Links to fetch on the webpage. | 50 |
linkwarden.maxWorkers |
Max number of playwright workers. | 5 |
linkwarden.reArchiveLimit |
How often a user can trigger a new archive for each link (in minutes). | 5 |
linkwarden.autoScrollTimeout |
The amount of time to wait for the website to be archived (in seconds). | 30 |
linkwarden.browserTimeout |
Browser timeout for archiving in miliseconds. | 30000 |
linkwarden.ignoreUnauthorizedCA |
Ignore certificate verification. | false |
linkwarden.ignoreHttpsErrors |
Ignore HTTPS errors. | false |
linkwarden.disablePreservation |
Disable archiving links. | false |
linkwarden.emailProvider |
Enable email. Must set emailFrom and emailServer . |
"" |
linkwarden.emailFrom |
Email from address. Ignored if existingSecret is set. |
"" |
linkwarden.emailServer |
Email server configuration. | "" |
linkwarden.emailBaseUrl |
Base URL for links in emails. | "" |
linkwarden.environment |
Additional environment variables for Linkwarden. | {} |
linkwarden.storage.type |
Storage type: s3 or filesystem . |
filesystem |
linkwarden.storage.storageFolder |
Storage folder if using filesystem . |
/data/data |
linkwarden.storage.pvc.enabled |
Whether to create a Persistent Volume Claim for filesystem storage. | true |
linkwarden.storage.pvc.existingClaim |
If you are providing an existing PVC, add its name here. | "" |
linkwarden.storage.pvc.storageClass |
Storage class for the Persistent Volume Claim. | "" |
linkwarden.storage.pvc.accessModes |
Access modes for the Persistent Volume Claim. | ["ReadWriteOnce"] |
linkwarden.storage.pvc.size |
Size of the persistent volume. | 5Gi |
linkwarden.storage.s3.accessKey |
AWS S3 access key. | "" |
linkwarden.storage.s3.secretKey |
AWS S3 secret key. | "" |
linkwarden.storage.s3.endpoint |
AWS S3 endpoint. | "" |
linkwarden.storage.s3.bucketName |
AWS S3 bucket name. | "" |
linkwarden.storage.s3.region |
AWS S3 region. | "" |
linkwarden.storage.s3.forcePathStyle |
AWS S3 force path style (for Minio). | false |
linkwarden.externalDatabaseUrl |
URL to an external PostgreSQL database (Optional). | "" |
linkwarden.sso.existingSecret |
Name of the secret holding SSO environment variables. | "" |
linkwarden.sso.providers |
A map of SSO providers and their configurations. | {} |
postgresql.enabled |
Enables the integrated CNPG PostgreSQL database. | true |
postgresql.cluster.instances |
Number of PostgreSQL instances. | 1 |
postgresql.cluster.storage.size |
Size of the persistent volume for PostgreSQL. | 2Gi |
postgresql.cluster.storage.storageClass |
Storage class for the persistent volume. | "" |
ingress.enabled |
Enables or disables ingress. | false |
ingress.className |
Ingress class name. | "" |
ingress.annotations |
Annotations for ingress. | {} |
ingress.hosts |
List of host rules. | [] |
ingress.tls |
List of TLS configurations. | [] |
resources |
Resource limits and requests for the Linkwarden container. | {} |
podAnnotations |
Annotations to add to the Linkwarden pod. | {} |
podLabels |
Labels to add to the Linkwarden pod. | {} |
autoscaling.enabled |
Enables horizontal pod autoscaling. | false |
autoscaling.minReplicas |
Minimum number of replicas. | 1 |
autoscaling.maxReplicas |
Maximum number of replicas. | 100 |
autoscaling.targetCPUUtilizationPercentage |
Target CPU utilization for autoscaling. | 80 |
podSecurityContext |
Pod Security Context settings. | {} |
containerSecurityContext |
Container Security Context settings. | {} |
nodeSelector |
Node labels to select for scheduling pods. | {} |
tolerations |
Tolerations for scheduling pods. | [] |
affinity |
Affinity rules for scheduling pods. | {} |
This chart includes an optional inbuilt PostgreSQL database using the CloudNativePG (CNPG) Operator. This is enabled by default.
- If
postgresql.enabled
istrue
, a PostgreSQL cluster will be deployed within your Kubernetes cluster. - You can configure the number of instances, storage, and storage class in the
postgresql
section. - If you use the internal PostgreSQL database, you do not need to set the
linkwarden.externalDatabaseUrl
. - Important: If you enable the internal PostgreSQL database, you MUST have the CloudNativePG Operator installed in your cluster.
-
Add the CloudNativePG Helm repository:
helm repo add cnpg https://cloudnative-pg.github.io/charts helm repo update
-
Install the CNPG Operator:
helm install cnpg cnpg/cloudnative-pg -n cnpg-system --create-namespace
You can choose a different namespace than
cnpg-system
if you want. -
Wait for the operator to be ready.
kubectl -n cnpg-system get pods -l app.kubernetes.io/name=cloudnative-pg
Make sure the pod is in Running state.
The chart supports two main storage options for Linkwarden data:
- Filesystem Storage:
- Uses a Persistent Volume Claim (PVC) to store data in the specified folder:
/data/data
. - Enable by setting
linkwarden.storage.type
tofilesystem
. - Configure PVC settings under
linkwarden.storage.pvc
.
- Uses a Persistent Volume Claim (PVC) to store data in the specified folder:
- S3 Storage:
- Uses s3 compatible storage to store data.
- Enable by setting
linkwarden.storage.type
tos3
. - Configure S3 settings under
linkwarden.storage.s3
.
- To expose Linkwarden outside the cluster, you can enable the ingress by setting
ingress.enabled
totrue
. - You will need an Ingress controller (like Nginx or Traefik) installed in your cluster.
- Configure hostnames, paths, and TLS settings in the
ingress
section.
- To use an external PostgreSQL database, set
postgresql.enabled
tofalse
, and provide the database URL through thelinkwarden.externalDatabaseUrl
value. - Note: Ensure that the Linkwarden application can reach the database from within the Kubernetes cluster.
- The
sso
section allows you to configure various SSO providers. - Refer to the NextAuth.js documentation for the specific settings per provider.
- If
linkwarden.sso.existingSecret
is set all environment variables required for SSO will be taken from that secret. - Add your provider config to
linkwarden.sso.providers
to enable that provider.
- Install Kubernetes: Make sure you have a working Kubernetes cluster.
- Install Helm: Follow the official Helm installation guide.
- Create a
values.yaml
: Customize yourvalues.yaml
file. Start with the default file and customize based on the details in the Configuration section of this file.⚠️ You MUST set anextAuthSecret
. Generate withopenssl rand -base64 32
- You might want to change
linkwarden.nextAuthUrl
if you are not accessing the service athttp://localhost:3000
. - If you enable the internal PostgreSQL database you do not need to change any database related settings.
- If you use an external PostgreSQL database set
postgresql.enabled
tofalse
, and provide the database URL through thelinkwarden.externalDatabaseUrl
value. - If you enable email you MUST specify
emailProvider
,emailFrom
, andemailServer
. - If you are using an s3 compatible object storage provider, ensure you have all the correct
linkwarden.storage.s3
settings.
- Install the chart: Use the Helm command in the Quick Start section.
To upgrade the chart to a newer version:
- Update your Helm repository:
helm repo update
- Upgrade the release:
helm upgrade linkwarden shivam-charts/linkwarden -f <values.yaml>
- Check the logs of the Linkwarden pod for errors using
kubectl logs <pod-name>
. - Verify that all necessary Kubernetes objects were created successfully.
- Ensure the database is reachable and properly configured.
- If you have any issues, please open an issue on GitHub Issues.
Contributions are welcome! Please follow these steps:
- Fork the repository: https://github.com/shivamkumar2002/linkwarden-helm-chart
- Create a new branch.
- Implement your changes.
- Submit a pull request.
This chart is licensed under the MIT License.