OpenWhisk рд╕рдВрдЧ рд╕рд░реНрднрд░рд▓реЗрд╕ рдХрдореНрдкреНрдпреБрдЯрд┐рдЩ, рднрд╛рдЧ 4

OpenWhisk рд╕рдВрдЧ рд╕рд░реНрднрд░рд▓реЗрд╕ рдХрдореНрдкреНрдпреБрдЯрд┐рдЩ, рднрд╛рдЧ 4

рдпрд╕ рд▓реЗрдЦрд▓реЗ рд▓реЗрдЦрдХрдмрд╛рдЯ OpenWhisk рдмрд╛рд░реЗ рдЕрдиреБрд╡рд╛рджрд┐рдд рдиреЛрдЯрд╣рд░реВрдХреЛ рд╢реНрд░реГрдВрдЦрд▓рд╛ рд╕рдорд╛рдкреНрдд рдЧрд░реНрджрдЫ рдкреНрд░рд┐рддрд┐ рджреЗрд╕рд╛рдИред рдЖрдЬ рд╣рд╛рдореА рдЕрдиреБрдкреНрд░рдпреЛрдЧрд╣рд░реВрдХреЛ рд╣рд╛рд▓рдХреЛ рд╕рдВрд╕реНрдХрд░рдгрд╣рд░реВрд╕рдБрдЧ рдХрд╛рдо рдЧрд░реНрдирдХреЛ рд▓рд╛рдЧрд┐ рд╕рд╣реА рдЖрджреЗрд╢рд╣рд░реВ рд╕рд╣рд┐рдд Kubernetes рдорд╛ OpenWhisk рдкреНрд░рдпреЛрдЧ рдЧрд░реНрдиреЗ рдкреНрд░рдХреНрд░рд┐рдпрд╛рд▓рд╛рдИ рд╣реЗрд░реНрдиреЗрдЫреМрдВред рдпрд╕рд▓реЗ Nodejs рд░рдирдЯрд╛рдЗрдо рдкреНрд░рдпреЛрдЧ рдЧрд░реЗрд░ Kubernetes рдорд╛ Knative рд░ TektonCD рдкреНрд░рдпреЛрдЧ рдЧрд░реЗрд░ OpenWhisk рдкреНрд░рдХрд╛рд░реНрдпрд╣рд░реВ рдЪрд▓рд╛рдЙрдиреЗ рдкреНрд░рдХреНрд░рд┐рдпрд╛рд▓рд╛рдИ рдкрдирд┐ рд╕рдореЗрдЯреНрдЫред

Kubernetes рдорд╛ OpenWhisk рддреИрдирд╛рдд рдЧрд░реНрджреИ

рдХреЗрд╣реА рджрд┐рдирдХреЛ рджреМрдбрд╛рди, рдореИрд▓реЗ рдПрдХ рд╕рд░рд▓ рд░ рдЫрд┐рдЯреЛ рдкрд░реАрдХреНрд╖рдг рдореИрджрд╛рди рд╕рд┐рд░реНрдЬрдирд╛ рдЧрд░реНрди рдХреБрдмреЗрд░рдиреЗрдЯрдорд╛ рдУрдкрдирд╡рд┐рд╕реНрдХ рдкреНрд░рдпреЛрдЧ рдЧрд░реНрдиреЗ рдкреНрд░рдпреЛрдЧ рдЧрд░реЗрдВред рд░ рдо Kubernetes рдорд╛ рдирдпрд╛рдБ рднрдПрдХреЛрд▓реЗ, рдорд▓рд╛рдИ рд╡рд┐рд╢реНрд╡рд╛рд╕ рдЫ рдХрд┐ рдбреЗрдв рджрд┐рди рд╕рдлрд▓ рдкрд░рд┐рдирд┐рдпреЛрдЬрдирдорд╛ рдЦрд░реНрдЪ рднрдпреЛред IN рдпреЛ рд░рд┐рдкреЛрдЬрд┐рдЯрд░реАрд╣рд░реВрд╕рдБрдЧ Kubernetes рдорд╛ OpenWhisk рдкреНрд░рдпреЛрдЧ рдЧрд░реНрдирдХрд╛ рд▓рд╛рдЧрд┐ рдзреЗрд░реИ рд╕реНрдкрд╖реНрдЯ рдирд┐рд░реНрджреЗрд╢рдирд╣рд░реВ рдЫрдиреНред рдпрд╣рд╛рдБ рдореНрдпрд╛рдХ (рдо рд▓рд┐рдирдХреНрд╕рдорд╛ рдкрдирд┐ рд╕рдмреИ рдХрд╛рдо рдЧрд░реНрдиреЗрдЫреБ рдХрд┐рдирднрдиреЗ рдо рд▓рд┐рдирдХреНрд╕рд▓рд╛рдИ рдкреНрд░рд╛рдердорд┐рдХрддрд╛ рджрд┐рдиреНрдЫреБред - рд▓рдЧрднрдЧред рдЕрдиреБрд╡рд╛рджрдХ)ред

  1. рдкреНрдпрд╛рдХреЗрдЬ рдкреНрд░рдмрдиреНрдзрдХ рд╕реНрдерд╛рдкрдирд╛ рдЧрд░реНрджреИ asdf, рдЬрд╕ рдкрдЫрд┐ рд╣рд╛рдореА рд╕реНрд╡рдЪрд╛рд▓рд┐рдд рд░реВрдкрдорд╛ рд╕рдЪреНрдпрд╛рдЙрдБрдЫреМрдВ ~/.bash_profile рд╡рд╛ рдпрд╕рдХреЛ рдмрд░рд╛рдмрд░:

$ brew install asdf
$ [ -s "/usr/local/opt/asdf/asdf.sh" ] && . /usr/local/opt/asdf/asdf.sh
$ source ~/.bash_profile

[рд▓рд┐рдирдХреНрд╕рдорд╛ рдпреЛ рдЪрд░рдг рдЖрд╡рд╢реНрдпрдХ рдЫреИрди, рдпрджреНрдпрдкрд┐ рдмреНрд░реВ рдЙрдкрд▓рдмреНрдз рдЫред - рд▓рдЧрднрдЧред рдЕрдиреБрд╡рд╛рджрдХ]

  1. рдкреНрд▓рдЧрдЗрдирд╣рд░реВ рдердкреНрджреИ minikube ╨╕ kubelet:

$ asdf plugin-add kubectl
$ asdf plugin-add minikube

[рдлреЗрд░рд┐, рд▓рд┐рдирдХреНрд╕рдорд╛ рдпреЛ рдЪрд░рдг рдЫреЛрдбреНрдиреБрд╣реЛрд╕реНред - рд▓рдЧрднрдЧред рдЕрдиреБрд╡рд╛рджрдХ]

  1. minikube рд░ kubelet рд╕реНрдерд╛рдкрдирд╛ рдЧрд░реНрдиреБрд╣реЛрд╕реН:

$ asdf install kubectl 1.9.0
$ asdf global kubectl 1.9.0
$ asdf install minikube 0.25.2
$ asdf global minikube 0.25.2

[рд╡рд┐рд╢рд┐рд╖реНрдЯ рд╕рдВрд╕реНрдХрд░рдгрд╣рд░реВ рд╕реНрдерд╛рдкрд┐рдд рдЫрдиреН, рддрд░ рдореИрд▓реЗ рд▓рд┐рдирдХреНрд╕рдХреЛ рд▓рд╛рдЧрд┐ рдирд╡реАрдирддрдо рдЙрдкрд▓рдмреНрдз рд╕рдВрд╕реНрдХрд░рдгрд╣рд░реВрдорд╛ рд╕рдмреИ рдЬрд╛рдБрдЪ рдЧрд░реЗрдВ; рдорд▓рд╛рдИ рд╢рдВрдХрд╛ рдЫ рдХрд┐ рддрдкрд╛рдЗрдБ рд╕реБрд░рдХреНрд╖рд┐рдд рд░реВрдкрдорд╛ рдирд╡реАрдирддрдо рд╕реНрдерд╛рдкрдирд╛ рдЧрд░реНрди рд╕рдХреНрдиреБрд╣реБрдиреНрдЫред - рд▓рдЧрднрдЧред рдЕрдиреБрд╡рд╛рджрдХ]

рд▓рд┐рдирдХреНрд╕рдорд╛, рдпреЛ рдЪрд░рдг рдпрд╕ рдкреНрд░рдХрд╛рд░ рдЧрд░рд┐рдПрдХреЛ рдЫ (рд╕рдмреИ рдХреБрд░рд╛ ~/bin рдорд╛ рд░рд╛рдЦрд┐рдПрдХреЛ рдЫ, рдЬреБрди рдореЗрд░реЛ PATH рдорд╛ рд╕реВрдЪреАрдмрджреНрдз рдЫ, рдЕрдиреБрд╡рд╛рджрдХрдХреЛ рдиреЛрдЯ):

$ curl -L0 minikube https://storage.googleapis.com/minikube/releases/latest/minikube-linux-amd64 && chmod +x minikube && mv minikube ~/bin/
$ curl -L0 https://storage.googleapis.com/kubernetes-release/release/$(curl -s https://storage.googleapis.com/kubernetes-release/release/stable.txt)/bin/linux/amd64/kubectl && chmod +x kubectl && mv kubectl ~/bin/

  1. рдПрдЙрдЯрд╛ minikube рднрд░реНрдЪреБрдЕрд▓ рдореЗрд╕рд┐рди рд╕рд┐рд░реНрдЬрдирд╛ рдЧрд░реНрдиреБрд╣реЛрд╕реН (VirtualBox рдкреВрд░реНрд╡-рд╕реНрдерд╛рдкрд┐рдд рд╣реБрдиреБрдкрд░реНрдЫ):

$ minikube start --cpus 2 --memory 4096 --kubernetes-version=v1.9.0 --extra-config=apiserver.Authorization.Mode=RBAC

[рдЯреЛрд▓реАрд╕рдБрдЧ рдореЗрд░реЛ рд▓рд╛рдЧрд┐ рд╕рдмреИ рдХрд╛рдо рдЧрд░реНрджрдЫ minikube start , рдкреНрдпрд╛рд░рд╛рдорд┐рдЯрд░рд╣рд░реВ рдмрд┐рдирд╛ рд░ рдкреВрд░реНрд╡рдирд┐рд░реНрдзрд╛рд░рд┐рдд рдорд╛рдирд╣рд░реВрд╕рдБрдЧред - рд▓рдЧрднрдЧред рдЕрдиреБрд╡рд╛рджрдХ]

$ minikube start
  minikube v1.5.2 on Debian 8.11
  Automatically selected the 'virtualbox' driver
  Downloading VM boot image ...
    > minikube-v1.5.1.iso.sha256: 65 B / 65 B [--------------] 100.00% ? p/s 0s
    > minikube-v1.5.1.iso: 143.76 MiB / 143.76 MiB [-] 100.00% 5.63 MiB p/s 26s
  Creating virtualbox VM (CPUs=2, Memory=4096MB, Disk=20000MB) ...
  Preparing Kubernetes v1.16.2 on Docker '18.09.9' ...
  Downloading kubelet v1.16.2
  Downloading kubeadm v1.16.2
  Pulling images ...
  Launching Kubernetes ...  Waiting for: apiserver
  Done! kubectl is now configured to use "minikube"

  1. рдбрдХрд░рдорд╛ рдиреЗрдЯрд╡рд░реНрдХрд▓рд╛рдИ рдкреНрд░реЛрдорд┐рд╕реНрдХреНрдпреБрд╕ рдореЛрдбрдорд╛ рд╕реНрд╡рд┐рдЪ рдЧрд░реНрджреИ:

$ minikube ssh -- sudo ip link set docker0 promisc on

  1. рдПрдЙрдЯрд╛ рдиреЗрдорд╕реНрдкреЗрд╕ рд╕рд┐рд░реНрдЬрдирд╛ рдЧрд░реНрдиреБрд╣реЛрд╕реН рд░ рдХрд╛рд░реНрдпрдХрд░реНрддрд╛ рдиреЛрдб рдЪрд┐рдиреНрд╣ рд▓рдЧрд╛рдЙрдиреБрд╣реЛрд╕реН:

$ kubectl create namespace openwhisk
$ kubectl label nodes --all openwhisk-role=invoker

  1. рд╣рд╛рдореАрд▓реЗ рднрдгреНрдбрд╛рд░рдХреЛ рд╕рд╛рдордЧреНрд░реАрд╣рд░реВ рдкреНрд░рд╛рдкреНрдд рдЧрд░реНрдЫреМрдВ рд░ mycluster.yaml рдлрд╛рдЗрд▓рдорд╛ рдкреНрд░рд╡реЗрд╢рдХреЛ рд▓рд╛рдЧрд┐ рдкреНрд░рдХрд╛рд░ рдУрднрд░рд░рд╛рдЗрдб рдЧрд░реНрдЫреМрдВ:

$ git clone https://github.com/apache/incubator-openwhisk-deploy-kube.git
$ cd incubator-openwhisk-deploy-kube/
$ cat << "EOF" > mycluster.yaml
whisk:
    ingress:
        type: NodePort
            api_host_name: 192.168.99.100
            api_host_port: 31001
nginx:
    httpsNodePort: 31001
EOF

  1. рд╣реЗрд▓рдо рд╕реНрдерд╛рдкрдирд╛ рдЧрд░реНрдиреБрд╣реЛрд╕реН рд░ рдпрд╕рд▓рд╛рдИ рдкреНрд░рдпреЛрдЧ рдЧрд░реЗрд░ рдкреНрд░рдпреЛрдЧ рдЧрд░реНрдиреБрд╣реЛрд╕реН:

$ brew install kubernetes-helm
$ helm init # init Helm Tiller, ╨╜╨╡ ╨╜╤Г╨╢╨╜╨╛ ╨╜╨░ Helm v3+
$ kubectl get pods -n kube-system # verify that tiller-deploy is in the running state, ╨╜╨╡ ╨╜╤Г╨╢╨╜╨╛ ╨╜╨░ helm v3+
$ kubectl create clusterrolebinding tiller-cluster-admin --clusterrole=cluster-admin --serviceaccount=kube-system:default
$ helm install ./openwhisk/helm/ --namespace=openwhisk -f mycluster.yaml

[рдирд╡реАрдирддрдо рд╕рдВрд╕реНрдХрд░рдгрд╣рд░реБ рд╕рдВрдЧ рд▓рд┐рдирдХреНрд╕ рдорд╛ (v3.0.1 рдЙрдкрд▓рдмреНрдз рдерд┐рдпреЛ) рдпреЛ рдЕрд▓рд┐ рдлрд░рдХ рд╣реБрдиреЗрдЫред - рд▓рдЧрднрдЧред рдЕрдиреБрд╡рд╛рджрдХ]

$ curl -L0 https://get.helm.sh/helm-v3.0.1-linux-amd64.tar.gz | tar -xzvf - linux-amd64/helm --strip-components=1; sudo mv helm /usr/local/bin
$ kubectl create clusterrolebinding tiller-cluster-admin --clusterrole=cluster-admin --serviceaccount=kube-system:default
$ helm install ./openwhisk/helm/ --namespace=openwhisk --generate-name -f mycluster.yaml

  1. рд╣рд╛рдореА рдЬрд╛рдБрдЪ рдЧрд░реНрдЫреМрдВ рдХрд┐ рд╕рдмреИ рдХреБрд░рд╛ рдмрдвреЗрдХреЛ рдЫ (STATUS = рдЪрд▓рд┐рд░рд╣реЗрдХреЛ рд╡рд╛ рдкреВрд░рд╛ рднрдпреЛ):

$ kubectl get pods -n openwhisk
NAME                                                              READY   STATUS      RESTARTS   AGE
openwhisk-1576070780-alarmprovider-6868dc694-plvpf                1/1     Running     1          1d5h
openwhisk-1576070780-apigateway-8d56f4979-825hf                   1/1     Running     1          1d5h
openwhisk-1576070780-cloudantprovider-544bb46596-9scph            1/1     Running     1          1d5h
openwhisk-1576070780-controller-0                                 1/1     Running     2          1d5h
openwhisk-1576070780-couchdb-7fd7f6c7cc-42tw6                     1/1     Running     1          1d5h
openwhisk-1576070780-gen-certs-z9nsb                              0/1     Completed   0          1d5h
openwhisk-1576070780-init-couchdb-r2vmt                           0/1     Completed   0          1d5h
openwhisk-1576070780-install-packages-27dtr                       0/1     Completed   0          1d4h
openwhisk-1576070780-invoker-0                                    1/1     Running     1          1d5h
openwhisk-1576070780-kafka-0                                      1/1     Running     1          1d5h
openwhisk-1576070780-kafkaprovider-f8b4cf4fc-7z4gt                1/1     Running     1          1d5h
openwhisk-1576070780-nginx-6dbdbf69bc-5x76n                       1/1     Running     1          1d5h
openwhisk-1576070780-redis-cfd8756f4-hkrt6                        1/1     Running     1          1d5h
openwhisk-1576070780-wskadmin                                     1/1     Running     1          1d5h
openwhisk-1576070780-zookeeper-0                                  1/1     Running     1          1d5h
wskopenwhisk-1576070780-invoker-00-1-prewarm-nodejs10             1/1     Running     0          61s
wskopenwhisk-1576070780-invoker-00-2-prewarm-nodejs10             1/1     Running     0          61s
wskopenwhisk-1576070780-invoker-00-3-whisksystem-invokerhealtht   1/1     Running     0          59s

  1. рдХрд╛рдо рдЧрд░реНрди wsk рдХрдиреНрдлрд┐рдЧрд░ рдЧрд░реНрджреИ:

$ wsk property set --apihost 192.168.99.100:31001
$ wsk property set --auth 23bc46b1-71f6-4ed5-8c54-816aa4f8c502:123zO3xZCLrMN6v2BKK1dXYFpXlPkccOFqm12CdAsMgRU4VrNZ9lyGVCGuMDGIwP

рдЬрд╛рдБрдЪ рдЧрд░реНрджреИ:

$ wsk -i list
Entities in namespace: default
packages
actions
triggers
rules

рд╕рдорд╕реНрдпрд╛ рд░ рддрд┐рдирдХреЛ рд╕рдорд╛рдзрд╛рди

getsockopt: рдЬрдбрд╛рди рдЕрд╕реНрд╡реАрдХрд╛рд░ рдЧрд░рд┐рдпреЛ

$ wsk -i list
error: Unable to obtain the list of entities for namespace 'default': Get http://192.168.99.100:31001/api/v1/namespaces/_/actions?limit=0&skip=0: dial tcp 192.168.99.100:31001: getsockopt: connection refused

рдХрдиреНрдЯреЗрдирд░рд╣рд░реВ рдиреЗрдорд╕реНрдкреЗрд╕рдорд╛ рдЫрдиреН рднрдиреА рдЬрд╛рдБрдЪ рдЧрд░реНрджреИ openwhisk рд╕реНрдерд┐рддрд┐ рдорд╛ Running, рдХрд┐рдирднрдиреЗ рдХрд╣рд┐рд▓реЗрдХрд╛рд╣реАрдБ рдпреЛ рддреНрд░реБрдЯрд┐ рд╕рдВрдЧ рдХреНрд░реНрдпрд╛рд╕ рд╣реБрдиреНрдЫ CreateContainerConfigError.

рдЖрд╣реНрд╡рд╛рдирдХрд░реНрддрд╛ рдЕрдЭреИ рдкреНрд░рд╛рд░рдореНрдн рдЧрд░реНрджреИ тАФ Init:1/2

рд╡рд┐рднрд┐рдиреНрди рд░рдирдЯрд╛рдЗрдо рд╡рд╛рддрд╛рд╡рд░рдгрд╣рд░реВ рдбрд╛рдЙрдирд▓реЛрдб рдЧрд░реНрдиреЗ рдкреНрд░рдХреНрд░рд┐рдпрд╛рд▓реЗ рд▓рд╛рдореЛ рд╕рдордп рд▓рд┐рди рд╕рдХреНрдЫред рдЪреАрдЬрд╣рд░реВрдХреЛ рдЧрддрд┐ рдмрдврд╛рдЙрди, рддрдкрд╛рдИрдВрд▓реЗ рдлрд╛рдЗрд▓рдорд╛ рдЫреЛрдЯреЛ рдиреНрдпреВрдирддрдо рд╕реВрдЪреА рдирд┐рд░реНрджрд┐рд╖реНрдЯ рдЧрд░реНрди рд╕рдХреНрдиреБрд╣реБрдиреНрдЫ mycluster.yaml:

whisk:
  runtimes: "runtimes-minimal-travis.json"

рдирд╛рдо рд╕рд╣рд┐рддрдХреЛ рдХрдиреНрдЯреЗрдирд░ -рд╕реНрдерд╛рдкрдирд╛-рдкреНрдпрд╛рдХреЗрдЬрд╣рд░реВ- рддреНрд░реБрдЯрд┐рдорд╛ рдХреНрд░реНрдпрд╛рд╕ рд╣реБрдиреНрдЫ

рдЬреАрд╡рдиреНрддрддрд╛ рдкрд░реАрдХреНрд╖рдгрдХреЛ рд▓рд╛рдЧрд┐ рдЯрд╛рдЗрдордЖрдЙрдЯ рдмрдврд╛рдЙрдиреБрд╣реЛрд╕реНред

Knative рдорд╛ OpenWhisk рд╕реНрдерд╛рдкрдирд╛ рдЧрд░реНрджреИ

рдкреНрд░реАрддрд┐ рджреЗрд╕рд╛рдИрд▓реЗ IBM рдХреНрд▓рд╛рдЙрдбрдорд╛ рдХреНрд▓рд╕реНрдЯрд░рдХреЛ рд╢реАрд░реНрд╖рдорд╛ рд╕реНрдерд╛рдкрдирд╛ рдЧрд░рд┐рдиреН, рд╕рд╛рдереИ рдирд┐рдпрдорд┐рдд рдорд┐рдирд┐рдХреБрдмрдорд╛, Knative Build and BuildTemplates рдХреЛ рдкреНрд░рдпреЛрдЧ рдЧрд░реЗрд░ред рдо рдХрд╕рд░реА рдорд╛ рдЖрдзрд╛рд░рд┐рдд, minukube рдХреЛ рд╢реАрд░реНрд╖ рдорд╛ рдкрдирд┐ рд╕реНрдерд╛рдкрдирд╛ рдЧрд░реНрдиреЗрдЫреБ рдпреЛ рд╡рд░реНрдгрди рдЧрд░рд┐рдПрдХреЛ рдерд┐рдпреЛ рд╣рд╛рдореНрд░реЛ рдмреНрд▓рдЧрдорд╛ рдкрд╣рд┐рд▓реЗ - рдирд╡реАрдирддрдо рд╕рдлреНрдЯрд╡реЗрдпрд░ рд╕рдВрд╕реНрдХрд░рдгрд╣рд░реВ рдкреНрд░рдпреЛрдЧ рдЧрд░реЗрд░ред Knative Build рд░ BuildTemplates рдЖрдзрд┐рдХрд╛рд░рд┐рдХ рд░реВрдкрдорд╛ рд╣рдЯрд╛рдЗрдПрдХреЛ рд╣реБрдирд╛рд▓реЗ, рдо Tekton Pipelines рдХреЛ рд░реВрдкрдорд╛ рд╕рд┐рдлрд╛рд░рд┐рд╕ рдЧрд░рд┐рдПрдХреЛ рдкреНрд░рддрд┐рд╕реНрдерд╛рдкрди рдкреНрд░рдпреЛрдЧ рдЧрд░реНрдиреЗрдЫреБред рдмрд╛рдБрдХреА рд▓реЗрдЦ рдЯреЗрдХрдЯрди рдкрд╛рдЗрдкрд▓рд╛рдЗрдирдХреЛ рдХрд╛рдЧрдЬрд╛рдд рдкрдвреЗрд░ рд▓реЗрдЦрд┐рдПрдХреЛ рд╣реЛ рддрд░ рдкреНрд░рд┐рддреАрдХреЛ рд╡рд┐рдЪрд╛рд░рдорд╛ рдЖрдзрд╛рд░рд┐рдд рдЫред рдХрд╛рдо рдЧрд░реНрди, рддрдкрд╛рдИрдВрд▓рд╛рдИ рдХреЗрд╣реА рдбрдХрд░ рд░рдЬрд┐рд╕реНрдЯреНрд░реАрдорд╛ рдкрд╣реБрдБрдЪ рдЪрд╛рд╣рд┐рдиреНрдЫ - рдо, рдореВрд▓ рд▓реЗрдЦрдХ рдЬрд╕реНрддреИ, DockerHub рдкреНрд░рдпреЛрдЧ рдЧрд░реНрдиреЗрдЫреБред

$ curl -L0 https://github.com/solo-io/gloo/releases/download/v1.2.10/glooctl-linux-amd64; chmod +x glooctl-linux-amd64; mv glooctl-linux-amd64 ~/bin
$ glooctl install knative
$ kubectl get pods -n knative-serving
NAME                              READY   STATUS    RESTARTS   AGE
activator-77fc555665-rvrst        1/1     Running   0          2m23s
autoscaler-5c98b7c9b6-x8hh4       1/1     Running   0          2m21s
autoscaler-hpa-5cfd4f6845-w87kq   1/1     Running   0          2m22s
controller-7fd74c8f67-tprm8       1/1     Running   0          2m19s
webhook-74847bb77c-txr2g          1/1     Running   0          2m17s
$ kubectl get pods -n gloo-system
NAME                                      READY   STATUS    RESTARTS   AGE
discovery-859d7fbc9c-8xhvh                1/1     Running   0          51s
gloo-545886d9c6-85mwt                     1/1     Running   0          51s
ingress-67d4996d75-lkkmw                  1/1     Running   0          50s
knative-external-proxy-767dfd656c-wwv2z   1/1     Running   0          50s
knative-internal-proxy-6fdddcc6b5-7vqd8   1/1     Running   0          51s

OpenWhisk рд╕рдВрдЧ рд╕рд░реНрднрд░рд▓реЗрд╕ рдХрдореНрдкреНрдпреБрдЯрд┐рдЩ, рднрд╛рдЧ 4
Knative рдХреЛ рд╢реАрд░реНрд╖рдорд╛ OpenWhisk рдирд┐рд░реНрдорд╛рдг рд░ рдЪрд▓рд╛рдЙрдиреБрд╣реЛрд╕реН

  1. рд╕рд╛рдордЧреНрд░реАрд╣рд░реВ рдкреНрд░рд╛рдкреНрдд рдЧрд░реНрджреИ рдпреЛ рднрдгреНрдбрд╛рд░:

$ git clone https://github.com/tektoncd/catalog/
$ cd catalog/openwhisk

  1. рд╣рд╛рдореАрд▓реЗ рд╡рд╛рддрд╛рд╡рд░рдг рдЪрд░рдХреЛ рд░реВрдкрдорд╛ рд░рдЬрд┐рд╕реНрдЯреНрд░реА рдкрд╣реБрдБрдЪ рдЧрд░реНрдирдХрд╛ рд▓рд╛рдЧрд┐ рдбреЗрдЯрд╛ рд╕реЗрдЯ рдЧрд░реНрдЫреМрдВ рд░ рддрд┐рдиреАрд╣рд░реВрд▓рд╛рдИ Kubernetes рдЧреЛрдкреНрдп рд░реВрдкрдорд╛ рдмрдЪрдд рдЧрд░реНрдЫреМрдВ:

$ export DOCKER_USERNAME=<your docker hub username>
$ export DOCKER_PASSWORD=<your docker hub password>
$ sed -e 's/${DOCKER_USERNAME}/'"$DOCKER_USERNAME"'/' -e 's/${DOCKER_PASSWORD}/'"$DOCKER_PASSWORD"'/' docker-secret.yaml.tmpl > docker-secret.yaml
$ kubectl apply -f docker-secret.yaml

рдЬрд╛рдБрдЪ рдЧрд░реНрджреИ:

$ kubectl get secret
NAME                    TYPE                                  DATA      AGE
dockerhub-user-pass     kubernetes.io/basic-auth              2         21s

  1. рд╡рд╛рддрд╛рд╡рд░рдг рдирд┐рд░реНрдорд╛рдгрдХреЛ рд▓рд╛рдЧрд┐ рдЦрд╛рддрд╛ рд╕рд┐рд░реНрдЬрдирд╛ рдЧрд░реНрдиреБрд╣реЛрд╕реН:

$ kubectl apply -f service-account.yaml

рдЬрд╛рдБрдЪ рдЧрд░реНрджреИ:

$ kubectl get serviceaccount/openwhisk-runtime-builder
NAME                        SECRETS   AGE
openwhisk-runtime-builder   2         31m

  1. OpenWhisk рдХреЛ рд▓рд╛рдЧрд┐ рдЫрд╡рд┐ рдирд┐рд░реНрдорд╛рдг рдЧрд░реНрди рдХрд╛рд░реНрдп рд╕рд┐рд░реНрдЬрдирд╛ рдЧрд░реНрдиреБрд╣реЛрд╕реН

$ kubectl apply -f openwhisk.yaml
task.tekton.dev/openwhisk created

  1. рд╣рд╛рдореА рдЫрд╡рд┐ рдирд┐рд░реНрдорд╛рдг рдЧрд░реНрди рдХрд╛рд░реНрдп рдЪрд▓рд╛рдЙрдБрдЫреМрдВ (рдЙрджрд╛рд╣рд░рдгрдХреЛ рд░реВрдкрдорд╛ NodeJS рдкреНрд░рдпреЛрдЧ рдЧрд░реЗрд░):

рд╕рд╛рдордЧреНрд░реАрд╣рд░реВрд╕рдБрдЧ taskrun.yaml рдлрд╛рдЗрд▓ рд╕рд┐рд░реНрдЬрдирд╛ рдЧрд░реНрдиреБрд╣реЛрд╕реН:

# Git Pipeline Resource for OpenWhisk NodeJS Runtime
apiVersion: tekton.dev/v1alpha1
kind: PipelineResource
metadata:
    name: openwhisk-nodejs-runtime-git
spec:
    type: git
    params:
        - name: revision
          value: master
        - name: url
          value: https://github.com/apache/openwhisk-runtime-nodejs.git
---

# Image Pipeline Resource for OpenWhisk NodeJS Sample Application
apiVersion: tekton.dev/v1alpha1
kind: PipelineResource
metadata:
    name: openwhisk-nodejs-helloworld-image
spec:
    type: image
    params:
        - name: url
          value: docker.io/${DOCKER_USERNAME}/openwhisk-nodejs-helloworld
---

# Task Run to build NodeJS image with the action source
apiVersion: tekton.dev/v1alpha1
kind: TaskRun
metadata:
    name: openwhisk-nodejs-helloworld
spec:
    serviceAccountName: openwhisk-runtime-builder
    taskRef:
        name: openwhisk
    inputs:
        resources:
            - name: runtime-git
              resourceRef:
                name: openwhisk-nodejs-runtime-git
        params:
            - name: DOCKERFILE
              value: "./runtime-git/core/nodejs10Action/knative/Dockerfile"
            - name: OW_ACTION_NAME
              value: "nodejs-helloworld"
            - name: OW_ACTION_CODE
              value: "function main() {return {payload: 'Hello World!'};}"
            - name: OW_PROJECT_URL
              value: ""
    outputs:
        resources:
            - name: runtime-image
              resourceRef:
                name: openwhisk-nodejs-helloworld-image
---

рд╣рд╛рдореА рдпрд╕ рдлрд╛рдЗрд▓рдХреЛ рд▓рд╛рдЧрд┐ рд╣рд╛рд▓рдХреЛ рдбрд╛рдЯрд╛ рд▓рд╛рдЧреВ рдЧрд░реНрдЫреМрдВ:

$ sed 's/${DOCKER_USERNAME}/'"$DOCKER_USERNAME"'/' -i taskrun.yaml

рд╣рд╛рдореА рдЖрд╡реЗрджрди:

$ kubectl apply -f taskrun.yaml
pipelineresource.tekton.dev/openwhisk-nodejs-runtime-git created
pipelineresource.tekton.dev/openwhisk-nodejs-helloworld-image created
taskrun.tekton.dev/openwhisk-nodejs-helloworld created

рдХрд╛рдо рдЬрд╛рдБрдЪ рдЧрд░реНрдиреБ рднрдиреЗрдХреЛ рдкреЛрдбрдХреЛ рдирд╛рдо рдкреНрд░рд╛рдкреНрдд рдЧрд░реНрдиреБ рд░ рдпрд╕рдХреЛ рд╕реНрдерд┐рддрд┐ рд╣реЗрд░реНрдиреБ рд╣реЛред рддрдкрд╛рдИрд▓реЗ рдкреНрд░рддреНрдпреЗрдХ рдЪрд░рдгрдХреЛ рдХрд╛рд░реНрдпрд╛рдиреНрд╡рдпрди рд▓рдЧ рдкрдирд┐ рд╣реЗрд░реНрди рд╕рдХреНрдиреБрд╣реБрдиреНрдЫ, рдЙрджрд╛рд╣рд░рдгрдХрд╛ рд▓рд╛рдЧрд┐:

$ kubectl get taskrun
NAME                          SUCCEEDED   REASON      STARTTIME   COMPLETIONTIME
openwhisk-nodejs-helloworld   True        Succeeded   5m15s       44s
$ kubectl get pod openwhisk-nodejs-helloworld-pod-4640d3
NAME                                     READY   STATUS      RESTARTS   AGE
openwhisk-nodejs-helloworld-pod-4640d3   0/6     Completed   0          5m20s
$ kubectl logs openwhisk-nodejs-helloworld-pod-4640d3 -c step-git-source-openwhisk-nodejs-runtime-git-r8vhr
{"level":"info","ts":1576532931.5880227,"logger":"fallback-logger","caller":"logging/config.go:69","msg":"Fetch GitHub commit ID from kodata failed: open /var/run/ko/refs/heads/master: no such file or directory"}
{"level":"info","ts":1576532936.538926,"logger":"fallback-logger","caller":"git/git.go:81","msg":"Successfully cloned https://github.com/apache/openwhisk-runtime-nodejs.git @ master in path /workspace/runtime-git"}
{"level":"warn","ts":1576532936.5395331,"logger":"fallback-logger","caller":"git/git.go:128","msg":"Unexpected error: creating symlink: symlink /tekton/home/.ssh /root/.ssh: file exists"}
{"level":"info","ts":1576532936.8202565,"logger":"fallback-logger","caller":"git/git.go:109","msg":"Successfully initialized and updated submodules in path /workspace/runtime-git"}

рдХрд╛рд░реНрдпрд╛рдиреНрд╡рдпрди рдкрдЫрд┐, рд╣рд╛рдореАрд╕рдБрдЧ рд░рдЬрд┐рд╕реНрдЯреНрд░реАрдорд╛ рдПрдЙрдЯрд╛ рдЫрд╡рд┐ рд╣реБрдиреЗрдЫ рдЬреБрди kn рдЙрдкрдпреЛрдЧрд┐рддрд╛ рдкреНрд░рдпреЛрдЧ рдЧрд░реЗрд░ рдкреНрд░рдпреЛрдЧ рдЧрд░реНрди рд╕рдХрд┐рдиреНрдЫ, Knative рд╕реЗрд╡рд╛рд╣рд░реВрд╕рдБрдЧ рдХрд╛рдо рдЧрд░реНрди рдбрд┐рдЬрд╛рдЗрди рдЧрд░рд┐рдПрдХреЛ, рдЙрджрд╛рд╣рд░рдгрдХрд╛ рд▓рд╛рдЧрд┐:

kn service create nodejs-helloworld --image docker.io/${DOCKER_USERNAME}/openwhisk-nodejs-helloworld
Service 'nodejs-helloworld' successfully created in namespace 'default'.
Waiting for service 'nodejs-helloworld' to become ready ... OK

Service URL:
http://nodejs-helloworld.default.example.com

рдпрджрд┐ рддрдкрд╛рдЗрдБ Gloo рдкреНрд░рдпреЛрдЧ рдЧрд░реНрдиреБрд╣реБрдиреНрдЫ рднрдиреЗ, рддрдкрд╛рдЗрдБ рдпрд╕рдХреЛ рдХрд╛рд░реНрдпрдХреНрд╖рдорддрд╛ рдпреЛ рдЬрд╕реНрддреИ рдЬрд╛рдБрдЪ рдЧрд░реНрди рд╕рдХреНрдиреБрд╣реБрдиреНрдЫ:

$ curl -H "Host: nodejs-helloworld.default.example.com" -X POST $(glooctl proxy url --name knative-external-proxy)
{"OK":true}
$ curl -H "Host: nodejs-helloworld.default.example.com" -X POST $(glooctl proxy url --name knative-external-proxy)
{"payload":"Hello World!"}

рд╢реНрд░реГрдВрдЦрд▓рд╛рдорд╛ рдЕрдиреНрдп рд▓реЗрдЦрд╣рд░реВ

OpenWhisk рд╕рдВрдЧ рд╕рд░реНрднрд░рд▓реЗрд╕ рдХрдореНрдкреНрдпреБрдЯрд┐рдЩ, рднрд╛рдЧ 1
OpenWhisk рд╕рдВрдЧ рд╕рд░реНрднрд░рд▓реЗрд╕ рдХрдореНрдкреНрдпреБрдЯрд┐рдЩ, рднрд╛рдЧ 2
OpenWhisk рд╕рдВрдЧ рд╕рд░реНрднрд░рд▓реЗрд╕ рдХрдореНрдкреНрдпреБрдЯрд┐рдЩ, рднрд╛рдЧ 3
OpenWhisk рд╕рдВрдЧ рд╕рд░реНрднрд░рд▓реЗрд╕ рдХрдореНрдкреНрдпреБрдЯрд┐рдЩ, рднрд╛рдЧ 4

рд╕реНрд░реЛрдд: www.habr.com

рдПрдХ рдЯрд┐рдкреНрдкрдгреА рдердкреНрди