Serverless Computing ma OpenWhisk, Vaega 4

Serverless Computing ma OpenWhisk, Vaega 4

O lenei tusiga e fa'amutaina le fa'asologa o fa'amatalaga fa'aliliu e uiga i OpenWhisk mai le tusitala Priti Desai. O le asō o le a tatou vaŹ»avaŹ»ai i le faŹ»agasologa o le faŹ»aogaina o OpenWhisk i luga o Kubernetes faŹ»atasi ai ma faŹ»atonuga faŹ»asaŹ»o e galulue ai ma lomiga o loŹ»o iai nei. O le a aofia ai foŹ»i le faŹ»agasologa o le faŹ»atinoina o galuega OpenWhisk e faŹ»aaoga ai Knative ma TektonCD i Kubernetes e faŹ»aaoga ai le Nodejs runtime.

Fa'aaoga OpenWhisk i Kubernetes

I le gasologa o nai aso, na ou faʻataʻitaʻia ai le faʻaogaina o OpenWhisk i Kubernetes e fatu ai se faʻataʻitaʻiga faigofie ma vave. Ma talu ai o aʻu e fou i Kubernetes, ou te talitonu o le aso ma le afa na faʻaalu i le faʻaogaina manuia. IN lenei O fale teu oloa o loʻo i ai faʻamatalaga manino mo le faʻaogaina o OpenWhisk i luga o Kubernetes. O faʻatonuga faʻapipiʻi na faia mo Mac (O le a ou faia foi mea uma i luga o Linux, auā ou te fiafia i ai Linux. - tusa. faaliliu).

  1. Fa'apipi'i le pule o afifi asdf, a uma lea e otometi lava ona tatou faasaʻoina ~/.bash_profile pe tutusa e pei o lenei:

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

[i Linux E lē manaŹ»omia lenei laasaga, e ui lava e maua le pia. - tusa. fa'aliliu]

  1. Fa'aopoopoina plugini minikube Šø kubelet:

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

[Toe fai, matou te faase'e lenei la'asaga Linux. - tusa. fa'aliliu]

  1. Fa'apipi'i le minikube ma le 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

[ua faʻapipiʻiina ni lomiga faʻapitoa, ae na ou siakiina mea uma i lomiga aupito lata mai o loʻo maua mo Linux; Ou te masalo e mafai ona e faʻapipiʻiina ma le saogalemu le mea aupito lata mai. - tusa. fa'aliliu]

i Linux O lenei laasaga e faia i se mea faapenei (ua faapipiiina mea uma i le ~/bin, o loo i totonu o la’u PATH, faamatalaga a le faaliliu):

$ 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. Fausia se masini komepiuta minikube (VirtualBox e tatau ona faʻapipiʻi muamua):

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

[E aoga mea uma ia te au ma le au minikube start , e aunoa ma ni tapula'a ma fa'atasi ai ma tau fa'aletonu. - tusa. fa'aliliu]

$ 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. Suia le fesoʻotaʻiga i Docker i le faiga faʻafefe:

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

  1. Fausia se igoa avanoa ma maka le node o le tagata faigaluega:

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

  1. Matou te maua mea o loʻo i totonu o le fale teu oloa ma faʻamalo le ituaiga mo le ulufale i le mycluster.yaml faila:

$ 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. Fa'apipi'i le Helm ma fa'aaoga i ai:

$ 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

[i Linux Faatasi ai ma lomiga aupito lata mai (o le v3.0.1 sa maua) o le a fai si ese. - tusa. fa'aliliu]

$ 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. Matou te siaki ua siitia mea uma (STATUS = Running or Completed):

$ 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. Fa'atonu wsk e galue:

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

Matou siaki:

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

Faafitauli ma Fofo

getsockopt: teena le sootaga

$ 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

Siaki o koneteina o lo'o i totonu ole igoa avanoa openwhisk i le tulaga Running, ona o nisi taimi e paʻu i mea sese CreateContainerConfigError.

O lo'o amataina pea le Invoker — Init:1/2

O le fa'agasologa o le la'uina o si'osi'omaga ta'avale eseese e mafai ona umi se taimi. Ina ia faʻavave mea, e mafai ona e faʻamaoti se lisi faʻapuupuu maualalo i le faila mycluster.yaml:

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

Pusa ma le igoa -fa'apipi'i-pa'iga- pa'u ile Mea Sese

Na'o le fa'aopoopoina o taimi fa'agata mo su'ega ola.

Faʻapipiʻi OpenWhisk i luga ole Knative

Na faia e Priti Desai le faʻapipiʻiina i luga o se fuifui i le IBM ao, faʻapea foʻi i luga o se minikube masani, faʻaaoga Knative Build and BuildTemplates. O le a ou faʻapipiʻi foi i luga o le minukube, faʻavae i luga o le auala sa faamatalaina i la matou blog muamua - faʻaaogaina polokalama fou faʻapipiʻi. Talu ai o Knative Build and BuildTemplates ua faʻagataina aloaia, o le a ou faʻaogaina le sui fautuaina i le tulaga o Tekton Pipelines. O le vaega o totoe o le tusiga na tusia ina ua uma ona faitau faʻamaumauga mo Tekton Pipelines, ae faʻavae i luga o manatu o Priti. Ina ia galue, e te manaʻomia le avanoa i nisi Docker Registry - O aʻu, pei o le tusitala muamua, o le a faʻaaogaina 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

Serverless Computing ma OpenWhisk, Vaega 4
Fausiaina ma faʻagaoioia OpenWhisk i luga ole Knative

  1. Mauaina o anotusi lenei faleoloa:

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

  1. Matou te setiina faʻamaumauga mo le mauaina o le Resitala e avea ma fesuiaiga o le siosiomaga ma faʻasaoina o se mealilo a 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

Matou siaki:

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

  1. Fausia se tala mo siosiomaga faufale:

$ kubectl apply -f service-account.yaml

Matou siaki:

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

  1. Fausia se galuega e fausia ai se ata mo OpenWhisk

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

  1. Matou te faʻatinoina le galuega e fausia ai le ata (faʻaaoga NodeJS e fai ma faʻataʻitaʻiga):

Fausia se faila taskrun.yaml ma mea e aofia ai:

# 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
---

Matou te faʻaogaina faʻamatalaga o loʻo i ai nei mo lenei faila:

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

Matou te talosaga:

$ 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

O le siakiina o le galuega e aofia ai le mauaina o le igoa o le pod ma le matamata i lona tulaga. E mafai fo'i ona e va'ai i le fa'atinoga o la'asaga ta'itasi, mo se fa'ata'ita'iga:

$ 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"}

A maeʻa le faʻatinoga, o le a matou maua se ata i le Resitala e mafai ona faʻaaogaina e faʻaaoga ai le kn faʻaaogaina, fuafuaina e galulue ma Knative auaunaga, mo se faʻataʻitaʻiga:

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

Afai e te faʻaaogaina Gloo, e mafai ona e siaki lona faʻatinoga e pei o lenei:

$ 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!"}

O isi tala i le faasologa

Serverless Computing ma OpenWhisk, Vaega 1
Serverless Computing ma OpenWhisk, Vaega 2
Serverless Computing ma OpenWhisk, Vaega 3
Serverless Computing ma OpenWhisk, Vaega 4

puna: www.habr.com

FaŹ»atau talimalo faŹ»atuatuaina mo nofoaga ma DDoS puipuiga, VPS VDS servers šŸ”„ Fa'atau le 'upega tafa'ilagi talimalo fa'atuatuaina ma le puipuiga DDoS, 'au'aunaga VPS VDS | ProHoster