Openstack over k8s: различия между версиями

Материал из noname.com.ua
Перейти к навигацииПерейти к поиску
Строка 1: Строка 1:
  +
=Комплексное задание на знание K8s/Helm/OpenStack на 8 рабочих часов (1 день)=
 
<PRE>
 
<PRE>
1) Install openstack(ceph as storage) on top of K8s(All-in-one-installation) using openstack-helm project
+
* Install openstack(ceph as storage) on top of K8s(All-in-one-installation) using openstack-helm project
2) change Keystone token expiration time afterwards to 24 hours
+
* change Keystone token expiration time afterwards to 24 hours
3) deploy 3 VMs connected to each other using heat
+
* deploy 3 VMs connected to each other using heat
 
</PRE>
 
</PRE>
   
  +
==TL; DR==
=install minikube=
 
   
  +
* Мне понадобилось примерно 13 рабочих часов что бы закончить задние
=Install helm=
 
   
  +
Хорошее:
  +
* Задание можно сделать за 8 часов (и даже быстрее)
   
  +
Плохое
brew install kubernetes-helm
 
   
  +
* Практически невозможно сделать на ноутбуке без Linux.
<PRE>
 
  +
* Примерно половину времени потрачено на попытку "взлететь" напрямую на Mac OS и использовать в качестве кластера K8s уже имевшийся minikube
helm init
 
  +
Это был явный фейл - как минимум чарты ceph не совместимы с миникубом никак (https://github.com/ceph/ceph-helm/issues/73), до остальных я не дошел. <BR>
$HELM_HOME has been configured at /Users/mmazur/.helm.
 
  +
Деплоить без скриптовой обвязки явно заняло бы больше чем 1 день (на самом деле если не срезать углы пользуясь скриптами то минимум неделя)
 
  +
* Когда я понял что задеплоить на миникуб за отведеннгое время не успеваю то решил настроить ВМку с убунтой и дальше работать с ней
Tiller (the Helm server-side component) has been installed into your Kubernetes Cluster.
 
  +
Второй явный фейл (но не мой =) ) - то тчо задание требует минимум 8 гигов свободной памяти, а на самом деле даже на ВМке с 16-ю гигами и 8 ядрами все шевелилось очень медленно. (Человек с ноутом с 8 гигами не сделает это задание из-за недостатка памяти)
 
  +
<BR> Как следствие - регулярные падения скриптов из-за таймаутов,
Please note: by default, Tiller is deployed with an insecure 'allow unauthenticated users' policy.
 
  +
<BR>Отмечу так же что с не слишеом быстрым интернетом я наступил на проблему, что Pull образов был медленным и скрипты не дожидались и падали по таймауту. Хорошей идеей было бы скачать образы заранее, но об этом я подумал уже в середине процесса и тратить время на анализ какие образы нужны, не стал,
To prevent this, run `helm init` with the --tiller-tls-verify flag.
 
For more information on securing your installation see: https://docs.helm.sh/using_helm/#securing-your-helm-installation
 
Happy Helming!
 
</PRE>
 
 
<PRE>
 
kubectl get pods -n kube-system
 
NAME READY STATUS RESTARTS AGE
 
coredns-86c58d9df4-fc47s 1/1 Running 0 2d19h
 
coredns-86c58d9df4-jpl6m 1/1 Running 0 2d19h
 
etcd-minikube 1/1 Running 0 2d19h
 
kube-addon-manager-minikube 1/1 Running 0 2d19h
 
kube-apiserver-minikube 1/1 Running 0 2d19h
 
kube-controller-manager-minikube 1/1 Running 0 2d19h
 
kube-proxy-9tg5l 1/1 Running 0 2d19h
 
kube-scheduler-minikube 1/1 Running 0 2d19h
 
storage-provisioner 1/1 Running 0 2d19h
 
tiller-deploy-69ffbf64bc-vspfs 1/1 Running 0 108s
 
</PRE>
 
<PRE>
 
helm list
 
</PRE>
 
 
<PRE>
 
helm repo update
 
Hang tight while we grab the latest from your chart repositories...
 
...Skip local chart repository
 
...Successfully got an update from the "stable" chart repository
 
Update Complete. ⎈ Happy Helming!⎈
 
</PRE>
 
 
=Ceph=
 
* http://docs.ceph.com/docs/mimic/start/kube-helm/
 
 
<PRE>
 
helm serve &
 
[1] 35959
 
14:16:09-mmazur@Mac18:~/WORK_OTHER/Mirantis_test_task/ceph-helm$ Regenerating index. This may take a moment.
 
Now serving you on 127.0.0.1:8879
 
 
</PRE>
 
 
<PRE>
 
helm repo add local http://localhost:8879/charts
 
"local" has been added to your repositories
 
</PRE>
 
 
<PRE>
 
git clone https://github.com/ceph/ceph-helm
 
cd ceph-helm/ceph
 
</PRE>
 
<PRE>
 
make
 
 
===== Processing [helm-toolkit] chart =====
 
if [ -f helm-toolkit/Makefile ]; then make --directory=helm-toolkit; fi
 
find: secrets: No such file or directory
 
echo Generating /Users/mmazur/WORK_OTHER/Mirantis_test_task/ceph-helm/ceph/helm-toolkit/templates/_secrets.tpl
 
Generating /Users/mmazur/WORK_OTHER/Mirantis_test_task/ceph-helm/ceph/helm-toolkit/templates/_secrets.tpl
 
rm -f templates/_secrets.tpl
 
for i in ; do printf '{{ define "'$i'" }}' >> templates/_secrets.tpl; cat $i >> templates/_secrets.tpl; printf "{{ end }}\n" >> templates/_secrets.tpl; done
 
if [ -f helm-toolkit/requirements.yaml ]; then helm dependency update helm-toolkit; fi
 
Hang tight while we grab the latest from your chart repositories...
 
...Successfully got an update from the "local" chart repository
 
...Successfully got an update from the "stable" chart repository
 
Update Complete. ⎈Happy Helming!⎈
 
Saving 0 charts
 
Deleting outdated charts
 
if [ -d helm-toolkit ]; then helm lint helm-toolkit; fi
 
==> Linting helm-toolkit
 
[INFO] Chart.yaml: icon is recommended
 
 
1 chart(s) linted, no failures
 
if [ -d helm-toolkit ]; then helm package helm-toolkit; fi
 
Successfully packaged chart and saved it to: /Users/mmazur/WORK_OTHER/Mirantis_test_task/ceph-helm/ceph/helm-toolkit-0.1.0.tgz
 
 
===== Processing [ceph] chart =====
 
if [ -f ceph/Makefile ]; then make --directory=ceph; fi
 
if [ -f ceph/requirements.yaml ]; then helm dependency update ceph; fi
 
Hang tight while we grab the latest from your chart repositories...
 
...Successfully got an update from the "local" chart repository
 
...Successfully got an update from the "stable" chart repository
 
Update Complete. ⎈Happy Helming!⎈
 
Saving 1 charts
 
Downloading helm-toolkit from repo http://localhost:8879/charts
 
Deleting outdated charts
 
if [ -d ceph ]; then helm lint ceph; fi
 
==> Linting ceph
 
[INFO] Chart.yaml: icon is recommended
 
 
1 chart(s) linted, no failures
 
if [ -d ceph ]; then helm package ceph; fi
 
Successfully packaged chart and saved it to: /Users/mmazur/WORK_OTHER/Mirantis_test_task/ceph-helm/ceph/ceph-0.1.0.tgz
 
</PRE>
 
 
 
* https://github.com/ceph/ceph-helm
 
 
 
<PRE>
 
kubectl describe node minikube
 
Name: minikube
 
Roles: master
 
Labels: beta.kubernetes.io/arch=amd64
 
beta.kubernetes.io/os=linux
 
kubernetes.io/hostname=minikube
 
node-role.kubernetes.io/master=
 
</PRE>
 
<PRE>
 
kubectl label node minikube ceph-mon=enabled ceph-mgr=enabled ceph-osd=enabled ceph-osd-device-dev-sdb=enabled ceph-osd-device-dev-sdc=enabled
 
</PRE>
 
<PRE>
 
kubectl describe node minikube
 
Name: minikube
 
Roles: master
 
Labels: beta.kubernetes.io/arch=amd64
 
beta.kubernetes.io/os=linux
 
ceph-mgr=enabled
 
ceph-mon=enabled
 
ceph-osd=enabled
 
ceph-osd-device-dev-sdb=enabled
 
ceph-osd-device-dev-sdc=enabled
 
kubernetes.io/hostname=minikube
 
node-role.kubernetes.io/master=
 
</PRE>
 
==2==
 
<PRE>
 
helm install --name=ceph local/ceph
 
NAME: ceph
 
LAST DEPLOYED: Sat Feb 2 14:31:32 2019
 
NAMESPACE: default
 
STATUS: DEPLOYED
 
 
RESOURCES:
 
==> v1/Service
 
NAME TYPE CLUSTER-IP EXTERNAL-IP PORT(S) AGE
 
ceph-mon ClusterIP None <none> 6789/TCP 1s
 
ceph-rgw ClusterIP 10.96.102.37 <none> 8088/TCP 0s
 
 
==> v1beta1/DaemonSet
 
NAME DESIRED CURRENT READY UP-TO-DATE AVAILABLE NODE SELECTOR AGE
 
ceph-mon 1 1 0 1 0 ceph-mon=enabled 0s
 
 
==> v1beta1/Deployment
 
NAME DESIRED CURRENT UP-TO-DATE AVAILABLE AGE
 
ceph-mds 1 1 1 0 0s
 
ceph-mgr 1 1 1 0 0s
 
ceph-mon-check 1 1 1 0 0s
 
ceph-rbd-provisioner 2 2 2 0 0s
 
ceph-rgw 1 1 1 0 0s
 
 
==> v1/Job
 
NAME COMPLETIONS DURATION AGE
 
ceph-mon-keyring-generator 0/1 0s 0s
 
ceph-rgw-keyring-generator 0/1 0s 0s
 
ceph-mgr-keyring-generator 0/1 0s 0s
 
ceph-osd-keyring-generator 0/1 0s 0s
 
ceph-mds-keyring-generator 0/1 0s 0s
 
ceph-namespace-client-key-generator 0/1 0s 0s
 
ceph-storage-keys-generator 0/1 0s 0s
 
 
==> v1/Pod(related)
 
NAME READY STATUS RESTARTS AGE
 
ceph-mon-7bjnx 0/3 Pending 0 0s
 
ceph-mds-85b4fbb478-9sr5d 0/1 Pending 0 0s
 
ceph-mgr-588577d89f-gwgjx 0/1 Pending 0 0s
 
ceph-mon-check-549b886885-gqhsg 0/1 Pending 0 0s
 
ceph-rbd-provisioner-5cf47cf8d5-d55wt 0/1 ContainerCreating 0 0s
 
ceph-rbd-provisioner-5cf47cf8d5-j6zhk 0/1 Pending 0 0s
 
ceph-rgw-7b9677854f-rfz5w 0/1 Pending 0 0s
 
ceph-mon-keyring-generator-x8dxx 0/1 Pending 0 0s
 
ceph-rgw-keyring-generator-x4vrz 0/1 Pending 0 0s
 
ceph-mgr-keyring-generator-4tncv 0/1 Pending 0 0s
 
ceph-osd-keyring-generator-qfws4 0/1 Pending 0 0s
 
ceph-mds-keyring-generator-lfhnc 0/1 Pending 0 0s
 
ceph-namespace-client-key-generator-ktr6d 0/1 Pending 0 0s
 
ceph-storage-keys-generator-ctxvt 0/1 Pending 0 0s
 
 
==> v1/Secret
 
NAME TYPE DATA AGE
 
ceph-keystone-user-rgw Opaque 7 1s
 
 
==> v1/ConfigMap
 
NAME DATA AGE
 
ceph-bin-clients 2 1s
 
ceph-bin 26 1s
 
ceph-etc 1 1s
 
ceph-templates 5 1s
 
 
==> v1/StorageClass
 
NAME PROVISIONER AGE
 
general ceph.com/rbd 1s
 
</PRE>
 
==3==
 
<PRE>
 
kubectl get pods
 
NAME READY STATUS RESTARTS AGE
 
ceph-mds-85b4fbb478-9sr5d 0/1 Pending 0 2m
 
ceph-mds-keyring-generator-lfhnc 0/1 ContainerCreating 0 2m
 
ceph-mgr-588577d89f-gwgjx 0/1 Init:0/2 0 2m
 
ceph-mgr-keyring-generator-4tncv 0/1 ContainerCreating 0 2m
 
ceph-mon-7bjnx 0/3 Init:0/2 0 2m
 
ceph-mon-check-549b886885-gqhsg 0/1 Init:0/2 0 2m
 
ceph-mon-keyring-generator-x8dxx 0/1 ContainerCreating 0 2m
 
ceph-namespace-client-key-generator-ktr6d 0/1 ContainerCreating 0 2m
 
ceph-osd-keyring-generator-qfws4 0/1 ContainerCreating 0 2m
 
ceph-rbd-provisioner-5cf47cf8d5-d55wt 0/1 ContainerCreating 0 2m
 
ceph-rbd-provisioner-5cf47cf8d5-j6zhk 0/1 ContainerCreating 0 2m
 
ceph-rgw-7b9677854f-rfz5w 0/1 Pending 0 2m
 
ceph-rgw-keyring-generator-x4vrz 0/1 ContainerCreating 0 2m
 
ceph-storage-keys-generator-ctxvt 0/1 ContainerCreating 0 2m
 
</PRE>
 
<PRE>
 
Node-Selectors: ceph-mds=enabled
 
Tolerations: node.kubernetes.io/not-ready:NoExecute for 300s
 
node.kubernetes.io/unreachable:NoExecute for 300s
 
Events:
 
Type Reason Age From Message
 
---- ------ ---- ---- -------
 
Warning FailedScheduling 95s (x2 over 95s) default-scheduler 0/1 nodes are available: 1 node(s) didn't match node selector.
 
</PRE>
 
<PRE>
 
kubectl label node minikube ceph-mon=enabled ceph-mgr=enabled ceph-osd=enabled ceph-osd-device-dev-sdb=enabled ceph-osd-device-dev-sdc=enabled ceph-mds=enabled
 
</PRE>
 
 
==4==
 
<PRE>
 
kubectl get pods
 
NAME READY STATUS RESTARTS AGE
 
ceph-mds-85b4fbb478-9sr5d 0/1 Pending 0 4m24s
 
ceph-mds-keyring-generator-lfhnc 0/1 ContainerCreating 0 4m24s
 
ceph-mgr-588577d89f-gwgjx 0/1 Init:0/2 0 4m24s
 
ceph-mgr-keyring-generator-4tncv 0/1 ContainerCreating 0 4m24s
 
ceph-mon-7bjnx 0/3 Init:0/2 0 4m24s
 
ceph-mon-check-549b886885-gqhsg 0/1 Init:0/2 0 4m24s
 
ceph-mon-keyring-generator-x8dxx 0/1 CrashLoopBackOff 4 4m24s
 
ceph-namespace-client-key-generator-ktr6d 0/1 ContainerCreating 0 4m24s
 
ceph-osd-keyring-generator-qfws4 0/1 CrashLoopBackOff 4 4m24s
 
ceph-rbd-provisioner-5cf47cf8d5-d55wt 0/1 ContainerCreating 0 4m24s
 
ceph-rbd-provisioner-5cf47cf8d5-j6zhk 0/1 ContainerCreating 0 4m24s
 
ceph-rgw-7b9677854f-rfz5w 0/1 Pending 0 4m24s
 
ceph-rgw-keyring-generator-x4vrz 0/1 CrashLoopBackOff 4 4m24s
 
ceph-storage-keys-generator-ctxvt 0/1 ContainerCreating 0 4m24s
 
</PRE>
 
<PRE>
 
kubectl logs ceph-rgw-keyring-generator-x4vrz
 
... skipped ...
 
Error from server (Forbidden): error when creating "STDIN": secrets is forbidden: User "system:serviceaccount:default:default" cannot create resource "secrets" in API group "" in the namespace "default"
 
</PRE>
 
<PRE>
 
apiVersion: rbac.authorization.k8s.io/v1
 
kind: ClusterRoleBinding
 
metadata:
 
name: grant-all-to-default-service-account-role-binding
 
namespace: default
 
roleRef:
 
apiGroup: rbac.authorization.k8s.io
 
kind: ClusterRole
 
name: admin
 
subjects:
 
- kind: ServiceAccount
 
name: default
 
namespace: default
 
</PRE>
 
<PRE>
 
kubectl create -f p.yaml
 
</PRE>
 
<PRE>
 
kubectl get pods
 
NAME READY STATUS RESTARTS AGE
 
ceph-mds-85b4fbb478-9sr5d 0/1 Pending 0 14m
 
ceph-mgr-588577d89f-gwgjx 0/1 Init:0/2 0 14m
 
ceph-mon-7bjnx 0/3 Init:0/2 0 14m
 
ceph-mon-check-549b886885-gqhsg 0/1 Init:0/2 0 14m
 
ceph-namespace-client-key-generator-ktr6d 0/1 Completed 6 14m
 
ceph-rbd-provisioner-5cf47cf8d5-d55wt 1/1 Running 0 14m
 
ceph-rbd-provisioner-5cf47cf8d5-j6zhk 1/1 Running 0 14m
 
ceph-rgw-7b9677854f-rfz5w 0/1 Pending 0 14m
 
</PRE>
 
==555==
 
helm delete --purge ceph
 
helm install --name=ceph local/ceph
 
 
 
 
 
 
===6666===
 
 
15:24:35-mmazur@Mac18:~/WORK_OTHER/Mirantis_test_task/ceph-helm/ceph/ceph$ kubectl label node minikube ceph-mon=enabled ceph-mgr=enabled ceph-osd=enabled ceph-osd-device-dev-sdb=enabled ceph-osd-device-dev-sdc=enabled ceph-mds=enabled ceph-mds=enabled
 
 
 
 
* https://github.com/ceph/ceph-helm/issues/73
 

Версия 16:05, 3 февраля 2019

Комплексное задание на знание K8s/Helm/OpenStack на 8 рабочих часов (1 день)

* Install openstack(ceph as storage) on top of K8s(All-in-one-installation) using openstack-helm project 
* change Keystone token expiration time afterwards to 24 hours 
* deploy 3 VMs connected to each other using heat

TL; DR

  • Мне понадобилось примерно 13 рабочих часов что бы закончить задние

Хорошее:

  • Задание можно сделать за 8 часов (и даже быстрее)

Плохое

  • Практически невозможно сделать на ноутбуке без Linux.
  • Примерно половину времени потрачено на попытку "взлететь" напрямую на Mac OS и использовать в качестве кластера K8s уже имевшийся minikube

Это был явный фейл - как минимум чарты ceph не совместимы с миникубом никак (https://github.com/ceph/ceph-helm/issues/73), до остальных я не дошел.
Деплоить без скриптовой обвязки явно заняло бы больше чем 1 день (на самом деле если не срезать углы пользуясь скриптами то минимум неделя)

  • Когда я понял что задеплоить на миникуб за отведеннгое время не успеваю то решил настроить ВМку с убунтой и дальше работать с ней

Второй явный фейл (но не мой =) ) - то тчо задание требует минимум 8 гигов свободной памяти, а на самом деле даже на ВМке с 16-ю гигами и 8 ядрами все шевелилось очень медленно. (Человек с ноутом с 8 гигами не сделает это задание из-за недостатка памяти)
Как следствие - регулярные падения скриптов из-за таймаутов,
Отмечу так же что с не слишеом быстрым интернетом я наступил на проблему, что Pull образов был медленным и скрипты не дожидались и падали по таймауту. Хорошей идеей было бы скачать образы заранее, но об этом я подумал уже в середине процесса и тратить время на анализ какие образы нужны, не стал,