Giter VIP home page Giter VIP logo

ansible-role-kubernetes-nextcloud's Introduction

Ansible Role: Nextcloud for Kubernetes

Ansible role to install Nextcloud on Kubernetes.

Role Variables

# Namespace
kubernetes_nextcloud_namespace: "default"
# App name (used as selector)
kubernetes_nextcloud_app: "nextcloud"
# Deployment name
kubernetes_nextcloud_deployment: "nextcloud-deployment"
# Cronjob name
kubernetes_nextcloud_cronjob: "nextcloud-cron"
# Configmap name
kubernetes_nextcloud_configmap: "nextcloud"
# Service name
kubernetes_nextcloud_service: "nextcloud"

# Number of replicas
kubernetes_nextcloud_replicas: 1
kubernetes_nextcloud_revision_history: 1

# Node selector
kubernetes_nextcloud_node_selector: {}

# Add custom labels in the deployment metadata section
kubernetes_nextcloud_deployment_labels: {}
# Add custom annotations in the deployment metadata section
kubernetes_nextcloud_deployment_annotations: {}

kubernetes_nextcloud_resources:
  limits:
    memory: "512Mi"
  requests:
    memory: "256Mi"

kubernetes_nextcloud_nginx_resources:
  limits:
    memory: "256Mi"
  requests:
    memory: "64Mi"

# Cronjob period
kubernetes_nextcloud_cron_period: "*/15 * * * *"

# Useful when nextcloud restrict the requests to some hostnames
# IF NOT SET CORRECTLY, CRON AND HEALTHCHECKS CAN BREAK
kubernetes_nextcloud_hostname: "nextcloud.example.com"

# Setup ingress for nextcloud
kubernetes_nextcloud_setup_ingress: false
kubernetes_nextcloud_ingress:
  name: "nextcloud-ingress"
  host: "nextcloud.example.com"
  annotations:
  tls:

### Volumes ###

# For each volume, `definition` and `subPath` can be used. Their content is
# exactly what would be in a Kkubernetes pod manifest.

## Required volumes ##

# Nextcloud data volume, mounted as /var/www/html/data (see examples for more
# details)
kubernetes_nextcloud_data_volume:
  definition:

# Nextcloud config volume, mounted as /var/www/html/config (see examples for
# more details)
kubernetes_nextcloud_config_volume:
  definition:

## Optional volumes ##

# Next volumes are optional, and are setup as emptyDir by default. They are
# useful to customize Nextcloud, and also to share the same apps between
# multiple Nextcloud instances.

# Nextcloud base directory, mounted as /var/www/html, useful to share apps
# between multiple instances
kubernetes_nextcloud_base_volume:
  definition:
    emptyDir: {}

# Nextcloud custom-apps directory, mounted as /var/www/html/custom_apps
kubernetes_nextcloud_custom_apps_volume:
  definition:
    emptyDir: {}

# Nextcloud theme directory, mounted as /var/www/html/themes
kubernetes_nextcloud_theme_volume:
  definition:
    emptyDir: {}

Dependencies

Kubectl needs to be installed on the host targeted by the role.

Example Playbook

- hosts: kube-master
  run_once: true
  vars:
    kubernetes_nextcloud_config_volume:
      subPath: config
      definition:
        glusterfs:
          endpoints: gluster-example-cluster
          path: nextcloud
          readOnly: false

    kubernetes_nextcloud_data_volume:
      subPath: data
      definition:
        glusterfs:
          endpoints: gluster-example-cluster
          path: nextcloud
          readOnly: false

    kubernetes_nextcloud_base_volume:
      subPath: basedir
      definition:
        glusterfs:
          endpoints: gluster-example-cluster
          path: nextcloud
          readOnly: false

    kubernetes_nextcloud_setup_ingress: true
    kubernetes_nextcloud_ingress:
      name: "nextcloud-ingress"
      host: "nextcloud.example.com"
      annotations:
        kubernetes.io/tls-acme: "true"
      tls:
        - secretName: "nextcloud-ingress-tls"
          hosts:
            - "nextcloud.example.com"

    kubernetes_nextcloud_hostname: "{{ kubernetes_nextcloud_ingress.host }}"
  roles:
    - role: Anthony25.kubernetes-nextcloud

Use run_once to run the role on only one available master in the cluster.

License

Tool under the BSD license. Do not hesitate to report bugs, ask me some questions or do some pull request if you want to!

ansible-role-kubernetes-nextcloud's People

Contributors

aruhier avatar wulf avatar

Stargazers

 avatar  avatar  avatar  avatar  avatar  avatar

Watchers

 avatar  avatar  avatar

Recommend Projects

  • React photo React

    A declarative, efficient, and flexible JavaScript library for building user interfaces.

  • Vue.js photo Vue.js

    ๐Ÿ–– Vue.js is a progressive, incrementally-adoptable JavaScript framework for building UI on the web.

  • Typescript photo Typescript

    TypeScript is a superset of JavaScript that compiles to clean JavaScript output.

  • TensorFlow photo TensorFlow

    An Open Source Machine Learning Framework for Everyone

  • Django photo Django

    The Web framework for perfectionists with deadlines.

  • D3 photo D3

    Bring data to life with SVG, Canvas and HTML. ๐Ÿ“Š๐Ÿ“ˆ๐ŸŽ‰

Recommend Topics

  • javascript

    JavaScript (JS) is a lightweight interpreted programming language with first-class functions.

  • web

    Some thing interesting about web. New door for the world.

  • server

    A server is a program made to process requests and deliver data to clients.

  • Machine learning

    Machine learning is a way of modeling and interpreting data that allows a piece of software to respond intelligently.

  • Game

    Some thing interesting about game, make everyone happy.

Recommend Org

  • Facebook photo Facebook

    We are working to build community through open source technology. NB: members must have two-factor auth.

  • Microsoft photo Microsoft

    Open source projects and samples from Microsoft.

  • Google photo Google

    Google โค๏ธ Open Source for everyone.

  • D3 photo D3

    Data-Driven Documents codes.