OpenWhisk рд╕рд╣ рд╕рд░реНрд╡реНрд╣рд░рд▓реЗрд╕ рд╕рдВрдЧрдгрди, рднрд╛рдЧ 4

OpenWhisk рд╕рд╣ рд╕рд░реНрд╡реНрд╣рд░рд▓реЗрд╕ рд╕рдВрдЧрдгрди, рднрд╛рдЧ 4

рд╣рд╛ рд▓реЗрдЦ рд▓реЗрдЦрдХрд╛рдЪреНрдпрд╛ OpenWhisk рдмрджреНрджрд▓ рдЕрдиреБрд╡рд╛рджрд┐рдд рдиреЛрдЯреНрд╕рдЪреА рдорд╛рд▓рд┐рдХрд╛ рд╕рдорд╛рдкреНрдд рдХрд░рддреЛ рдкреНрд░рд┐рддреА рджреЗрд╕рд╛рдИ. рдЖрдЬ рдЖрдореНрд╣реА рдНрдкреНрд▓рд┐рдХреЗрд╢рдиреНрд╕рдЪреНрдпрд╛ рд╕рдзреНрдпрд╛рдЪреНрдпрд╛ рдЖрд╡реГрддреНрддреНрдпрд╛рдВрд╕рд╣ рдХрд╛рд░реНрдп рдХрд░рдгреНрдпрд╛рд╕рд╛рдареА рджреБрд░реБрд╕реНрдд рдЖрджреЗрд╢рд╛рдВрд╕рд╣ рдУрдкрдирд╡рд┐рд╕реНрдХрд▓рд╛ рдХреБрдмрд░реНрдиреЗрдЯреНрд╕рд╡рд░ рддреИрдирд╛рдд рдХрд░рдгреНрдпрд╛рдЪреА рдкреНрд░рдХреНрд░рд┐рдпрд╛ рдкрд╛рд╣реВ. рд╣реЗ рдиреЛрдбрдЬ рд░рдирдЯрд╛рдЗрдо рд╡рд╛рдкрд░реВрди Kubernetes рд╡рд░ Knative рдЖрдгрд┐ TektonCD рд╡рд╛рдкрд░реВрди OpenWhisk рдлрдВрдХреНрд╢рдиреНрд╕ рдЪрд╛рд▓рд╡рдгреНрдпрд╛рдЪреА рдкреНрд░рдХреНрд░рд┐рдпрд╛ рджреЗрдЦреАрд▓ рдХрд╡реНрд╣рд░ рдХрд░реЗрд▓.

Kubernetes рд╡рд░ OpenWhisk рддреИрдирд╛рдд рдХрд░рдд рдЖрд╣реЗ

рдХрд╛рд╣реА рджрд┐рд╡рд╕рд╛рдВрджрд░рдореНрдпрд╛рди, рдореА рдПрдХ рд╕рд╛рдзреЗ рдЖрдгрд┐ рдЬрд▓рдж рдЪрд╛рдЪрдгреА рдЧреНрд░рд╛рдЙрдВрдб рддрдпрд╛рд░ рдХрд░рдгреНрдпрд╛рд╕рд╛рдареА OpenWhisk рддреЗ Kubernetes рддреИрдирд╛рдд рдХрд░рдгреНрдпрд╛рдЪрд╛ рдкреНрд░рдпреЛрдЧ рдХреЗрд▓рд╛. рдЖрдгрд┐ рдореА Kubernetes рд╕рд╛рдареА рдирд╡реАрди рдЕрд╕рд▓реНрдпрд╛рдиреЗ, рдорд╛рдЭрд╛ рд╡рд┐рд╢реНрд╡рд╛рд╕ рдЖрд╣реЗ рдХреА рдпрд╢рд╕реНрд╡реА рддреИрдирд╛рддреАрд╕рд╛рдареА рджреАрдб рджрд┐рд╡рд╕ рдЦрд░реНрдЪ рдЭрд╛рд▓рд╛. IN рд╣реЗ рд░реЗрдкреЙрдЬрд┐рдЯрд░реАрдЬрдордзреНрдпреЗ рдХреБрдмрд░реНрдиреЗрдЯреНрд╕рд╡рд░ 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. рдорд┐рдиреАрдХреНрдпреВрдм рдЖрдгрд┐ рдХреБрдмреЗрд▓реЗрдЯ рд╕реНрдерд╛рдкрд┐рдд рдХрд░рд╛:

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

[рд╡рд┐рд╢рд┐рд╖реНрдЯ рдЖрд╡реГрддреНрддреНрдпрд╛ рд╕реНрдерд╛рдкрд┐рдд рдХреЗрд▓реНрдпрд╛ рдЖрд╣реЗрдд, рдкрд░рдВрддреБ рдореА Linux рд╕рд╛рдареА рдирд╡реАрдирддрдо рдЙрдкрд▓рдмреНрдз рдЖрд╡реГрддреНрддреНрдпрд╛рдВрд╡рд░ рд╕рд░реНрд╡рдХрд╛рд╣реА рддрдкрд╛рд╕рд▓реЗ рдЖрд╣реЗ; рдорд▓рд╛ рд╢рдВрдХрд╛ рдЖрд╣реЗ рдХреА рддреБрдореНрд╣реА рд╕реБрд░рдХреНрд╖рд┐рддрдкрдгреЗ рдирд╡реАрдирддрдо рд╕реНрдерд╛рдкрд┐рдд рдХрд░реВ рд╢рдХрддрд╛. - рдЕрдВрджрд╛рдЬреЗ рдЕрдиреБрд╡рд╛рджрдХ]

рд▓рд┐рдирдХреНрд╕рд╡рд░, рд╣реА рдкрд╛рдпрд░реА рдпрд╛рд╕рд╛рд░рдЦреА рдХреЗрд▓реА рдЬрд╛рддреЗ (рд╕рд░реНрд╡ рдХрд╛рд╣реА ~/рдмрд┐рдирдордзреНрдпреЗ рдареЗрд╡рд▓реЗ рдЬрд╛рддреЗ, рдЬреЗ рдорд╛рдЭреНрдпрд╛ 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 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

[рдирд╡реАрдирддрдо рдЖрд╡реГрддреНрддреНрдпрд╛рдВрд╕рд╣ Linux рд╡рд░ (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 рд╕реНрдерд╛рдкрд┐рдд рдХрд░рдд рдЖрд╣реЗ

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

$ 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. рдЖрдореНрд╣реА рдкрд░реНрдпрд╛рд╡рд░рдг рд╡реНрд╣реЗрд░рд┐рдПрдмрд▓реНрд╕ рдореНрд╣рдгреВрди рд░рдЬрд┐рд╕реНрдЯреНрд░реАрдордзреНрдпреЗ рдкреНрд░рд╡реЗрд╢ рдХрд░рдгреНрдпрд╛рд╕рд╛рдареА рдбреЗрдЯрд╛ рд╕реЗрдЯ рдХрд░рддреЛ рдЖрдгрд┐ рдХреБрдмрд░реНрдиреЗрдЯреНрд╕ рд╕рд┐рдХреНрд░реЗрдЯ рдореНрд╣рдгреВрди рдЬрддрди рдХрд░рддреЛ:

$ 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. рдЖрдореНрд╣реА рдкреНрд░рддрд┐рдорд╛ рддрдпрд╛рд░ рдХрд░рдгреНрдпрд╛рд╕рд╛рдареА рдХрд╛рд░реНрдп рдЪрд╛рд▓рд╡рддреЛ (рдЙрджрд╛рд╣рд░рдгрд╛рд░реНрде рдиреЛрдбрдЬреЗрдПрд╕ рд╡рд╛рдкрд░реБрди):

рд╕рд╛рдордЧреНрд░реАрд╕рд╣ 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

рддреБрдореНрд╣реА рдЧреНрд▓реВ рд╡рд╛рдкрд░рдд рдЕрд╕рд▓реНрдпрд╛рд╕, рддреБрдореНрд╣реА рддреНрдпрд╛рдЪреА рдХрд╛рд░реНрдпрдХреНрд╖рдорддрд╛ рдпрд╛рдкреНрд░рдорд╛рдгреЗ рддрдкрд╛рд╕реВ рд╢рдХрддрд╛:

$ 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

рдПрдХ рдЯрд┐рдкреНрдкрдгреА рдЬреЛрдбрд╛