
แแก แกแขแแขแแ แแแแแแ แแแก แแแขแแ แแก OpenWhisk-แแก แจแแกแแฎแแ แแแ แแแแแแ แจแแแแจแแแแแแก แกแแ แแแก . แแฆแแก แฉแแแ แแแแแแฎแแแแแ Kubernetes-แแ OpenWhisk-แแก แแแแแแแแแแก แแ แแชแแกแก แจแแกแฌแแ แแแฃแแ แแ แซแแแแแแแแ แแแแแแแชแแแแแก แแแแแแแแ แ แแแ แกแแแแแแ แแฃแจแแแแแกแแแแก. แแก แแกแแแ แแแแชแแแก OpenWhisk แคแฃแแฅแชแแแแแก แแแจแแแแแก แแ แแชแแกแก Knative-แแกแ แแ TektonCD-แแก แแแแแงแแแแแแ Kubernetes-แแ Nodejs แแแจแแแแแก แแ แแแก แแแแแงแแแแแแ.
OpenWhisk-แแก แแแงแแแแแ Kubernetes-แแ
แ แแแแแแแแ แแฆแแก แแแแแแแแแแแจแ แแ แแชแแแแแแแ OpenWhisk-แแก แแแแแแแกแแแแก Kubernetes-แแ, แ แแแ แจแแแแฅแแแ แแแ แขแแแ แแ แกแฌแ แแคแ แกแแขแแกแขแ แแแแแแ. แแ แ แแแแแ แแ แแฎแแแ แแแ Kubernetes-แจแ, แแฏแแ แ, แ แแ แแฆแแแแฎแแแแ แ แแแแฎแแ แฏแ แฌแแ แแแขแแแฃแ แแแแแแแแแแแ. IN แกแแชแแแแแก แแฅแแ แซแแแแแ แแแแคแแ แแแกแขแ แฃแฅแชแแแแ Kubernetes-แแ OpenWhisk-แแก แแแแแแแกแแแแกแแแแก. แแฅ แแ แแก แแแแแแแแแแก แแแกแขแ แฃแฅแชแแแแ แแแแแแแแแฃแแแ Mac-แแกแแแแก (แแแช แงแแแแแคแแ แก แแแแแแแแแ Linux, แ แแแแแ แแ แแแ แฉแแแแแ Linux. - แแแแฎแ. แแแแ แแแแแแ).
- แแแแแขแแก แแแแแฏแแ แแก แแแกแขแแแแชแแ
asdf, แ แแก แจแแแแแแแช แฉแแแ แแแขแแแแขแฃแ แแ แแแกแฌแแ แแแ~/.bash_profileแแ แแแกแ แแฅแแแแแแแแขแ, แ แแแแ แแชแแ:
$ brew install asdf
$ [ -s "/usr/local/opt/asdf/asdf.sh" ] && . /usr/local/opt/asdf/asdf.sh
$ source ~/.bash_profile[แฌแแแก Linux แแก แแแแแฏแ แแฃแชแแแแแแแ แแ แแ แแก, แแฃแแชแ แแแฎแแ แจแ แฎแแแแแกแแฌแแแแแแ. - แแแแฎแ. แแแแ แแแแแแ]
- แแแแแแแขแแแแก แแแแแขแแแ
minikubeะธkubelet:
$ asdf plugin-add kubectl
$ asdf plugin-add minikube[แแแแแ แแ แแฎแแ, แฉแแแ แแแแแแขแแแแแ แแ แแแแแฏแก Linux. - แแแแฎแ. แแแแ แแแแแแ]
- แแแแแแกแขแแแแ แแ 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[แแแแแ แแขแฃแแ แแแ แกแแแแแ แแแแแกแขแแแแ แแแฃแแ, แแแแ แแ แแ แงแแแแแคแแ แ แจแแแแแแฌแแ แฃแแฎแแแก แฎแแแแแกแแฌแแแแ แแแ แกแแแแแ Linux; แแคแแฅแ แแ, แ แแ แฃแแฎแแแกแ แแแ แกแแแก แฃแกแแคแ แแฎแแ แแแกแขแแแแชแแ แจแแแแซแแแแ. - แแแแฎแ. แแแแ แแแแแแ]
แฌแแแก Linux แแก แแแแแฏแ แแแแฎแแแแแแ แแกแ แกแ แฃแแแแแ (แงแแแแแคแแ แ แแแแแกแขแแแแ แแแฃแแแ ~/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/- แจแแฅแแแแแ 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"- แฅแกแแแแก แแแแแ แแแ Docker-แจแ แแ แแแแกแแฃแฃแ แ แแแแแจแ:
$ minikube ssh -- sudo ip link set docker0 promisc on- แจแแฅแแแแแ แกแแฎแแแแ แกแแแ แชแ แแ แแแแแจแแแ แแฃแจแ แแแแแซแ:
$ kubectl create namespace openwhisk
$ kubectl label nodes --all openwhisk-role=invoker- แฉแแแ แแแฆแแแ แกแแชแแแแก แจแแแแแแกแก แแ แแฃแจแแแแ แขแแแก 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- แแแแแแกแขแแแแ แแ Helm แแ แแแแแแแแกแแ แแแ แแแกแ แแแแแงแแแแแแ:
$ 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- แฉแแแ แแแแแฌแแแแ, แ แแ แงแแแแแคแแ แ แแแแแแ แแ (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- 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"แแแแขแแแแแ แ แกแแฎแแแฌแแแแแแ - แแแกแขแแแแชแแ - แแแแแขแแแ - แแแแ แแ แแ แจแแชแแแแ
แฃแแ แแแแ แแแแแ แแแ แกแแชแแชแฎแแแกแฃแแแ แแแแแแแก แขแแกแขแแแแก แแแแแแ.
OpenWhisk-แแก แแแกแขแแแแชแแ Knative-แแ
Priti Desai-แ แแแแแฎแแ แชแแแแ แแแกแขแแแแชแแ IBM แฆแ แฃแแแแจแ แแแแกแขแแ แแก แแแแแ, แแกแแแ แ แแแแ แช แฉแแแฃแแแแ แแ แแแแแแฃแแแ, Knative Build-แแกแ แแ BuildTemplates-แแก แแแแแงแแแแแแ. แแกแแแ แแแแแแแกแขแแแแ แ minukube-แก แแแแแ, แแแแก แแแฎแแแแแ, แแฃ แ แแแแ แฉแแแแก แแแแแจแ แแแ แ - แแ แแแ แแแฃแแ แฃแแ แฃแแแแแงแแคแแก แฃแแฎแแแกแ แแแ แกแแแแแก แแแแแงแแแแแแ. แแแแแแแแ Knative Build แแ BuildTemplates แแคแแชแแแแฃแ แแ แแแซแแแแแแฃแแแ, แแ แแแแแแแงแแแแ แ แแแแแแแแแแฃแ แฉแแแแชแแแแแแก Tekton Pipelines-แแก แกแแฎแแ. แกแขแแขแแแก แแแแแ แฉแแแ แแแฌแแแ แแแแฌแแ แ Tekton Pipelines-แแก แแแแฃแแแแขแแชแแแก แฌแแแแแฎแแแก แจแแแแแ, แแแแ แแ แแคแฃแซแแแแ แแ แแขแแก แแแแแแก. แกแแแฃแจแแแ แแแแญแแ แแแแแ Docker Registry-แแ แฌแแแแแ - แแ, แแ แแแแแแแฃแ แ แแแขแแ แแก แแกแแแแกแแ, แแแแแแแงแแแแ 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-แแก แแแแแ แแ แแแจแแแแ Knative-แแก แแแแแ
- แจแแแแแ แกแแก แแแฆแแแ :
$ git clone https://github.com/tektoncd/catalog/
$ cd catalog/openwhisk- แฉแแแ แแแงแแแแแ แ แแแกแขแ แจแ แฌแแแแแแก แแแแแชแแแแแก แแแ แแแแก แชแแแแแแแแ แแ แแแแแฎแแแ แแแ แแฃแแแ แแแขแแก แกแแแแฃแแแแแแแ:
$ 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- แจแแฅแแแแแ แแแแแ แแจแ แกแแแจแแแแแแ แแแ แแแแกแแแแก:
$ kubectl apply -f service-account.yamlแฉแแแ แจแแแแแฌแแแ:
$ kubectl get serviceaccount/openwhisk-runtime-builder
NAME SECRETS AGE
openwhisk-runtime-builder 2 31m- แจแแฅแแแแแ แแแแแแแแ OpenWhisk-แแกแแแแก แแแแแกแแฎแฃแแแแแก แจแแกแแฅแแแแแแ
$ kubectl apply -f openwhisk.yaml
task.tekton.dev/openwhisk created- แฉแแแ แแแกแ แฃแแแแ แแแแแแแแแก แกแฃแ แแแแก แจแแกแแฅแแแแแแ (แแแแแแแแแ 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!"}แกแแ แแแก แกแฎแแ แกแขแแขแแแแ
แฌแงแแ แ: www.habr.com
