From ebf4c447bb5a72261ba9086eef056c5c0434e443 Mon Sep 17 00:00:00 2001 From: Nitish Tiwari Date: Mon, 24 Apr 2017 09:20:51 -0700 Subject: [PATCH] docs: Add Minikube deployment to k8s docs (#4133) --- docs/orchestration/kubernetes/README.md | 13 ++- docs/orchestration/minikube/README.md | 47 +++++++++++ .../minikube/minio_distributed.sh | 58 +++++++++++++ docs/orchestration/minikube/statefulset.yaml | 81 +++++++++++++++++++ 4 files changed, 195 insertions(+), 4 deletions(-) create mode 100644 docs/orchestration/minikube/README.md create mode 100755 docs/orchestration/minikube/minio_distributed.sh create mode 100644 docs/orchestration/minikube/statefulset.yaml diff --git a/docs/orchestration/kubernetes/README.md b/docs/orchestration/kubernetes/README.md index 5871069b3..b4f3d91fd 100644 --- a/docs/orchestration/kubernetes/README.md +++ b/docs/orchestration/kubernetes/README.md @@ -1,15 +1,20 @@ # Deploy Minio on Kubernetes [![Slack](https://slack.minio.io/slack?type=svg)](https://slack.minio.io) [![Go Report Card](https://goreportcard.com/badge/minio/minio)](https://goreportcard.com/report/minio/minio) [![Docker Pulls](https://img.shields.io/docker/pulls/minio/minio.svg?maxAge=604800)](https://hub.docker.com/r/minio/minio/) [![codecov](https://codecov.io/gh/minio/minio/branch/master/graph/badge.svg)](https://codecov.io/gh/minio/minio) -Kubernetes constructs like Deployments and StatefulSets provide perfect platform to deploy Minio server in standalone, distributed or shared mode. In addition, using Minio [Helm](https://helm.sh) Chart, you can deploy Minio server with a single command on your cluster. +Kubernetes concepts like Deployments and StatefulSets provide perfect platform to deploy Minio server in standalone, distributed or shared mode. There are multiple options to deploy Minio on Kubernetes, you can choose the one that suits you the most. -Minio Helm Chart offers great deal of [customizability](#configuration), still if you'd rather like to deploy Minio using custom config files, you can do that as well. This [blog post](https://blog.minio.io/build-aws-s3-compatible-cloud-storage-on-gcp-with-minio-and-kubernetes-159cc99caea8#.8zesfh6tc) offers an introduction to running Minio on Kubernetes using .yaml configuration files. +- Minio [Helm](https://helm.sh) Chart offers a customizable and easy Minio deployment, with a single command. Read more about Minio Helm deployment [here](#prerequisites). +- You can also explore Kubernetes [Minio example](https://github.com/kubernetes/kubernetes/blob/master/examples/storage/minio/README.md) to deploy Minio using `.yaml` files. + +- If you'd like to get started with Minio on Kubernetes without having to create a real container cluster, you can also [deploy Minio locally](https://raw.githubusercontent.com/minio/minio/master/docs/orchestration/minikube/README.md) with MiniKube. + + ## 1. Prerequisites * Kubernetes 1.4+ with Beta APIs enabled for default standalone mode. * Kubernetes 1.5+ with Beta APIs enabled to run Minio in [distributed mode](#distributed-minio). -* PV provisioner support in the underlying infrastructure. -* Helm package manager [installed](https://github.com/kubernetes/helm#install) on your Kubernetes cluster. +* PV provisioner support in the underlying infrastructure. +* Helm package manager [installed](https://github.com/kubernetes/helm#install) on your Kubernetes cluster. ## 2. Deploy Minio using Helm Chart diff --git a/docs/orchestration/minikube/README.md b/docs/orchestration/minikube/README.md new file mode 100644 index 000000000..d8cf7bdf4 --- /dev/null +++ b/docs/orchestration/minikube/README.md @@ -0,0 +1,47 @@ +# Deploy distributed Minio locally with minikube [![Slack](https://slack.minio.io/slack?type=svg)](https://slack.minio.io) [![Go Report Card](https://goreportcard.com/badge/minio/minio)](https://goreportcard.com/report/minio/minio) [![Docker Pulls](https://img.shields.io/docker/pulls/minio/minio.svg?maxAge=604800)](https://hub.docker.com/r/minio/minio/) [![codecov](https://codecov.io/gh/minio/minio/branch/master/graph/badge.svg)](https://codecov.io/gh/minio/minio) + +Minikube runs a single-node Kubernetes cluster inside a VM on your computer. This makes it easy to deploy distributed Minio server on +Kubernetes running locally on your computer. + +## 1. Prerequisites + +[Minikube](https://github.com/kubernetes/minikube/blob/master/README.md#installation) and [`kubectl`](https://kubernetes.io/docs/user-guide/prereqs/) +installed on your system. + +## 2. Steps + +* Download `minio_distributed.sh` and `statefulset.yaml` + +```sh +wget https://raw.githubusercontent.com/minio/minio/master/docs/orchestration/minikube/minio_distributed.sh +wget https://raw.githubusercontent.com/minio/minio/master/docs/orchestration/minikube/statefulset.yaml +``` + +* Execute the `minio_distributed.sh` script in command prompt. + +```sh +./minio_distributed.sh +``` + +After the script is executed successfully, you should get an output like this + +```sh +service "minio-public" created +service "minio" created +statefulset "minio" created +``` +This means Minio is deployed on your local Minikube installation. + +Note that the service `minio-public` is a [clusterIP](https://kubernetes.io/docs/user-guide/services/#publishing-services---service-types) service. It exposes the service on a cluster-internal IP. To connect to your Minio instances via `kubectl port-forward` command, execute + +``` +kubectl port-forward minio-0 9000:9000 +``` + +Minio server can now be accessed at `http://localhost:9000`, with accessKey and secretKey as mentioned in the `statefulset.yaml` file. + +## 3. Notes + +Minikube currently does not support dynamic provisioning, so we manually create PersistentVolumes(PV) and PersistentVolumeClaims(PVC). Once the PVs and PVCs are created, we call the `statefulset.yaml` configuration file to create the distributed Minio setup. + +This setup runs on a laptop/computer. Hence only one disk is used as the backend for all the minio instance PVs. Minio sees these PVs as separate disks and reports the available storage incorrectly. diff --git a/docs/orchestration/minikube/minio_distributed.sh b/docs/orchestration/minikube/minio_distributed.sh new file mode 100755 index 000000000..6349f9733 --- /dev/null +++ b/docs/orchestration/minikube/minio_distributed.sh @@ -0,0 +1,58 @@ +#!/usr/bin/env bash + +# Minio Cloud Storage, (C) 2014, 2015, 2016, 2017 Minio, Inc. +# Licensed under the Apache License, Version 2.0 (the "License"); +# you may not use this file except in compliance with the License. +# You may obtain a copy of the License at +# +# http://www.apache.org/licenses/LICENSE-2.0 +# +# Unless required by applicable law or agreed to in writing, software +# distributed under the License is distributed on an "AS IS" BASIS, +# WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. +# See the License for the specific language governing permissions and +# limitations under the License. + +set -exuo pipefail + +# Clean up anything from a prior run: +kubectl delete statefulsets,persistentvolumes,persistentvolumeclaims,services,poddisruptionbudget -l app=minio + +# Make persistent volumes and (correctly named) claims. We must create the +# claims here manually even though that sounds counter-intuitive. For details +# see https://github.com/kubernetes/contrib/pull/1295#issuecomment-230180894. +for i in $(seq 0 3); do + cat <