Kubernetes-Helm

  • helm部署
    准备安装文件和get脚本:
    helm-v3.3.0-linux-amd64.tar.gz#软件
    helm-v3.3.0-linux-amd64.tar.gz.sha256#验证文件
    get # shell部署脚本
trnuser@k8s:~/pod/helm$ ls
get  helm-v3.3.0-linux-amd64.tar.gz  helm-v3.3.0-linux-amd64.tar.gz.sha256
#!/usr/bin/env bash

# Copyright The Helm Authors.
#
# 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.

# The install script is based off of the MIT-licensed script from glide,
# the package manager for Go: https://github.com/Masterminds/glide.sh/blob/master/get

PROJECT_NAME="helm"
TILLER_NAME="tiller"

: ${USE_SUDO:="true"}
: ${HELM_INSTALL_DIR:="/usr/local/bin"}

# initArch discovers the architecture for this system.
initArch() {
  ARCH=$(uname -m)
  case $ARCH in
    armv5*) ARCH="armv5";;
    armv6*) ARCH="armv6";;
    armv7*) ARCH="arm";;
    aarch64) ARCH="arm64";;
    x86) ARCH="386";;
    x86_64) ARCH="amd64";;
    i686) ARCH="386";;
    i386) ARCH="386";;
  esac
}

# initOS discovers the operating system for this system.
initOS() {
  OS=$(echo `uname`|tr '[:upper:]' '[:lower:]')

  case "$OS" in
    # Minimalist GNU for Windows
    mingw*) OS='windows';;
  esac
}

# runs the given command as root (detects if we are root already)
runAsRoot() {
  local CMD="$*"

  if [ $EUID -ne 0 -a $USE_SUDO = "true" ]; then
    CMD="sudo $CMD"
  fi

  $CMD
}

# verifySupported checks that the os/arch combination is supported for
# binary builds.
verifySupported() {
  local supported="darwin-386\ndarwin-amd64\nlinux-386\nlinux-amd64\nlinux-arm\nlinux-arm64\nlinux-ppc64le\nwindows-386\nwindows-amd64"
  if ! echo "${supported}" | grep -q "${OS}-${ARCH}"; then
    echo "No prebuilt binary for ${OS}-${ARCH}."
    echo "To build from source, go to https://github.com/helm/helm"
    exit 1
  fi

  if ! type "curl" > /dev/null && ! type "wget" > /dev/null; then
    echo "Either curl or wget is required"
    exit 1
  fi
}

# checkDesiredVersion checks if the desired version is available.
checkDesiredVersion() {
  if [ "x$DESIRED_VERSION" == "x" ]; then
    # Get tag from release URL
    local latest_release_url="https://github.com/helm/helm/releases/latest"
    if type "curl" > /dev/null; then
      TAG=$(curl -Ls -o /dev/null -w %{url_effective} $latest_release_url | grep -oE "[^/]+$" )
    elif type "wget" > /dev/null; then
      TAG=$(wget $latest_release_url --server-response -O /dev/null 2>&1 | awk '/^  Location: /{DEST=$2} END{ print DEST}' | grep -oE "[^/]+$")
    fi
   TAG=v3.3.0
  else
    TAG=$DESIRED_VERSION
  fi
}

# checkHelmInstalledVersion checks which version of helm is installed and
# if it needs to be changed.
checkHelmInstalledVersion() {
  if [[ -f "${HELM_INSTALL_DIR}/${PROJECT_NAME}" ]]; then
    local version=$(helm version -c | grep '^Client' | cut -d'"' -f2)
    if [[ "$version" == "$TAG" ]]; then
      echo "Helm ${version} is already ${DESIRED_VERSION:-latest}"
      return 0
    else
      echo "Helm ${TAG} is available. Changing from version ${version}."
      return 1
    fi
  else
    return 1
  fi
}

# downloadFile downloads the latest binary package and also the checksum
# for that binary.
downloadFile() {
  HELM_DIST="helm-$TAG-$OS-$ARCH.tar.gz"
  DOWNLOAD_URL="https://get.helm.sh/$HELM_DIST"
  CHECKSUM_URL="$DOWNLOAD_URL.sha256"
  HELM_TMP_ROOT="$(mktemp -dt helm-installer-XXXXXX)"
  HELM_TMP_FILE="$HELM_TMP_ROOT/$HELM_DIST"
  HELM_SUM_FILE="$HELM_TMP_ROOT/$HELM_DIST.sha256"
  echo "Downloading $DOWNLOAD_URL"
  cp helm* $HELM_TMP_ROOT
#  if type "curl" > /dev/null; then
#    curl -SsL "$CHECKSUM_URL" -o "$HELM_SUM_FILE"
#  elif type "wget" > /dev/null; then
#    wget -q -O "$HELM_SUM_FILE" "$CHECKSUM_URL"
#  fi
#  if type "curl" > /dev/null; then
#    curl -SsL "$DOWNLOAD_URL" -o "$HELM_TMP_FILE"
#  elif type "wget" > /dev/null; then
#    wget -q -O "$HELM_TMP_FILE" "$DOWNLOAD_URL"
#  fi
}

# installFile verifies the SHA256 for the file, then unpacks and
# installs it.
installFile() {
  HELM_TMP="$HELM_TMP_ROOT/$PROJECT_NAME"
  local sum=$(openssl sha1 -sha256 ${HELM_TMP_FILE} | awk '{print $2}')
  local expected_sum=$(cat ${HELM_SUM_FILE})
#  if [ "$sum" != "$expected_sum" ]; then
#    echo "SHA sum of ${HELM_TMP_FILE} does not match. Aborting."
#    exit 1
#  fi

  mkdir -p "$HELM_TMP"
  tar xf "$HELM_TMP_FILE" -C "$HELM_TMP"
  HELM_TMP_BIN="$HELM_TMP/$OS-$ARCH/$PROJECT_NAME"
  TILLER_TMP_BIN="$HELM_TMP/$OS-$ARCH/$TILLER_NAME"
  echo "Preparing to install $PROJECT_NAME and $TILLER_NAME into ${HELM_INSTALL_DIR}"
  runAsRoot cp "$HELM_TMP_BIN" "$HELM_INSTALL_DIR"
  echo "$PROJECT_NAME installed into $HELM_INSTALL_DIR/$PROJECT_NAME"
  if [ -x "$TILLER_TMP_BIN" ]; then
    runAsRoot cp "$TILLER_TMP_BIN" "$HELM_INSTALL_DIR"
    echo "$TILLER_NAME installed into $HELM_INSTALL_DIR/$TILLER_NAME"
  else
    echo "info: $TILLER_NAME binary was not found in this release; skipping $TILLER_NAME installation"
  fi
}

# fail_trap is executed if an error occurs.
fail_trap() {
  result=$?
  if [ "$result" != "0" ]; then
    if [[ -n "$INPUT_ARGUMENTS" ]]; then
      echo "Failed to install $PROJECT_NAME with the arguments provided: $INPUT_ARGUMENTS"
      help
    else
      echo "Failed to install $PROJECT_NAME"
    fi
    echo -e "\tFor support, go to https://github.com/helm/helm."
  fi
  cleanup
  exit $result
}

# testVersion tests the installed client to make sure it is working.
testVersion() {
  set +e
  HELM="$(which $PROJECT_NAME)"
  if [ "$?" = "1" ]; then
    echo "$PROJECT_NAME not found. Is $HELM_INSTALL_DIR on your "'$PATH?'
    exit 1
  fi
  set -e
  echo "Run '$PROJECT_NAME init' to configure $PROJECT_NAME."
}

# help provides possible cli installation arguments
help () {
  echo "Accepted cli arguments are:"
  echo -e "\t[--help|-h ] ->> prints this help"
  echo -e "\t[--version|-v <desired_version>] . When not defined it defaults to latest"
  echo -e "\te.g. --version v2.4.0  or -v latest"
  echo -e "\t[--no-sudo]  ->> install without sudo"
}

# cleanup temporary files to avoid https://github.com/helm/helm/issues/2977
cleanup() {
  if [[ -d "${HELM_TMP_ROOT:-}" ]]; then
    rm -rf "$HELM_TMP_ROOT"
  fi
}

# Execution

#Stop execution on any error
trap "fail_trap" EXIT
set -e

# Parsing input arguments (if any)
export INPUT_ARGUMENTS="${@}"
set -u
while [[ $# -gt 0 ]]; do
  case $1 in
    '--version'|-v)
       shift
       if [[ $# -ne 0 ]]; then
           export DESIRED_VERSION="${1}"
       else
           echo -e "Please provide the desired version. e.g. --version v2.4.0 or -v latest"
           exit 0
       fi
       ;;
    '--no-sudo')
       USE_SUDO="false"
       ;;
    '--help'|-h)
       help
       exit 0
       ;;
    *) exit 1
       ;;
  esac
  shift
done
set +u

initArch
initOS
verifySupported
checkDesiredVersion
if ! checkHelmInstalledVersion; then
  downloadFile
  installFile
fi
testVersion
cleanup
  • 安装
./get
----
trnuser@k8s:~/pod/helm$ helm version
version.BuildInfo{Version:"v3.3.0-rc.1", GitCommit:"5c2dfaad847df2ac8f289d278186d048f446c70c", GitTreeState:"dirty", GoVersion:"go1.14.4"}
  • helm子命令添加tab键补全
helm completion bash > ~/.helmrc
echo "source ~/.helmrc >> ~/.bashrc"
source ~/.bashrc
  • 添加helm仓库
helm repo add azure http://mirror.azure.cn/kubernetes/charts
helm repo add aliyun https://apphub.aliyuncs.com 
  • 列出仓库
# helm repo list
# helm search repo mysql
root@k8s:~# helm search repo mysql
NAME                            	CHART VERSION	APP VERSION	DESCRIPTION                                       
aliyun/mysql                    	6.8.0        	8.0.19     	Chart to create a Highly available MySQL cluster  
aliyun/mysqldump                	2.6.0        	2.4.1      	A Helm chart to help backup MySQL databases usi...
aliyun/mysqlha                  	1.0.0        	5.7.13     	MySQL cluster with a single master and zero or ...
aliyun/prometheus-mysql-exporter	0.5.2        	v0.11.0    	A Helm chart for prometheus mysql exporter with...
azure/mysql                     	1.6.9        	5.7.30     	DEPRECATED - Fast, reliable, scalable, and easy...
azure/mysqldump                 	2.6.2        	2.4.1      	DEPRECATED! - A Helm chart to help backup MySQL...
azure/prometheus-mysql-exporter 	0.7.1        	v0.11.0    	DEPRECATED A Helm chart for prometheus mysql ex...
aliyun/percona                  	1.2.0        	5.7.17     	free, fully compatible, enhanced, open source d...
aliyun/percona-xtradb-cluster   	1.0.3        	5.7.19     	free, fully compatible, enhanced, open source d...
aliyun/phpmyadmin               	4.2.12       	5.0.1      	phpMyAdmin is an mysql administration frontend    
azure/percona                   	1.2.3        	5.7.26     	DEPRECATED - free, fully compatible, enhanced, ...
azure/percona-xtradb-cluster    	1.0.8        	5.7.19     	DEPRECATED - free, fully compatible, enhanced, ...
azure/phpmyadmin                	4.3.5        	5.0.1      	DEPRECATED phpMyAdmin is an mysql administratio...
aliyun/mariadb                  	7.3.9        	10.3.22    	Fast, reliable, scalable, and easy to use open-...
aliyun/mariadb-galera           	0.8.1        	10.4.12    	MariaDB Galera is a multi-master database clust...
azure/gcloud-sqlproxy           	0.6.1        	1.11       	DEPRECATED Google Cloud SQL Proxy                 
azure/mariadb                   	7.3.14       	10.3.22    	DEPRECATED Fast, reliable, scalable, and easy t...
root@k8s:~# 
  • 下载安装包
helm pull aliyun/mysql
  • 修改values.yaml的passwd
root@k8s:/home/trnuser/helm/mysql# cat values.yaml | grep password
## Use existing secret (ignores root, db and replication passwords)
  ## MySQL admin password
  ## ref: https://github.com/bitnami/bitnami-docker-mysql#setting-the-root-password-on-first-run
  password: redhat
  ## Option to force users to specify a password. That is required for 'helm upgrade' to work properly.
  ## If it is not force, a random password will be generated.
  ## Mount admin password as a file instead of using an environment variable
  ## MySQL username and password
  password:
  ## Option to force users to specify a password. That is required for 'helm upgrade' to work properly.
  ## If it is not force, a random password will be generated.
  ## Mount replication user password as a file instead of using an environment variable
  ## MySQL replication user password
  password:
  ## Option to force users to specify a password. That is required for 'helm upgrade' to work properly.
  ## If it is not force, a random password will be generated.
  ## Mount replication user password as a file instead of using an environment variable
    default_authentication_plugin=mysql_native_password
    default_authentication_plugin=mysql_native_password 
  • 部署mysql应用
heml install mysql-test .
  • 查看已部署helm应用
# helm ls
root@k8s:/home/trnuser/helm/mysql# kubectl get pod -n helm-mysql
NAME             READY   STATUS    RESTARTS   AGE
mysql-master-0   1/1     Running   0          7d6h
mysql-slave-0    1/1     Running   0          7d6h
root@k8s:/home/trnuser/helm/mysql# kubectl get svc -n helm-mysql
NAME          TYPE           CLUSTER-IP    EXTERNAL-IP      PORT(S)          AGE
mysql         LoadBalancer   10.1.52.191   10.250.101.241   3306:30228/TCP   7d6h
mysql-slave   ClusterIP      10.1.12.158   <none>           3306/TCP         7d6h
  • 删除helm应用
helm uninstall mysql
  • 搭建私有源
docker run -dit --name=myhelmrepo -p 8080:80 -v /data:/usr/share/nginx/html/charts ngin
mkdir mychar
cd mychar
helm create chart1
helm package mysql/
helm package chart1
  • 给目录下的两个包建立索引文件,并指定仓库地址
helm repo index . --url http://192.168.55.254:8080/charts 
  • 把当前目录下 index.yaml 和后缀为 tgz 的包全部拷贝 192.168.55.254 的/data 目录里
scp index.yaml *.tgz 192.168.55.254:/data 
  • 添加私有源作为仓库
helm repo add myrepo http://192.168.55.254:8080/charts 
  • 删除本地私有参考地址
helm repo remove myrepo
posted @ 2021-03-12 16:50  独孤云翔  阅读(129)  评论(0)    收藏  举报