Step1 kubernetesのセットアップ

microk8sのインストール

totegamma@raspi5:~$ sudo snap install microk8s --classic
[sudo] password for totegamma:
microk8s (1.29/stable) v1.29.5 from Canonical✓ installed
totegamma@raspi5:~$

グループの調整

totegamma@raspi5:~$ sudo usermod -a -G microk8s totegamma
totegamma@raspi5:~$ newgrp microk8s
totegamma@raspi5:~$

起動確認

totegamma@raspi5:~$ microk8s status
microk8s is running
high-availability: no
  datastore master nodes: 127.0.0.1:19001
  datastore standby nodes: none
addons:
  enabled:
    dns                  # (core) CoreDNS
    ha-cluster           # (core) Configure high availability on the current node
    helm                 # (core) Helm - the package manager for Kubernetes
    helm3                # (core) Helm 3 - the package manager for Kubernetes
  disabled:
    cert-manager         # (core) Cloud native certificate management
    cis-hardening        # (core) Apply CIS K8s hardening
    community            # (core) The community addons repository
    dashboard            # (core) The Kubernetes dashboard
    host-access          # (core) Allow Pods connecting to Host services smoothly
    hostpath-storage     # (core) Storage class; allocates storage from host directory
    ingress              # (core) Ingress controller for external access
    kube-ovn             # (core) An advanced network fabric for Kubernetes
    mayastor             # (core) OpenEBS MayaStor
    metallb              # (core) Loadbalancer for your Kubernetes cluster
    metrics-server       # (core) K8s Metrics Server for API access to service metrics
    minio                # (core) MinIO object storage
    observability        # (core) A lightweight observability stack for logs, traces and metrics
    prometheus           # (core) Prometheus operator for monitoring and logging
    rbac                 # (core) Role-Based Access Control for authorisation
    registry             # (core) Private image registry exposed on localhost:32000
    rook-ceph            # (core) Distributed Ceph storage using Rook
    storage              # (core) Alias to hostpath-storage add-on, deprecated
totegamma@raspi5:~$


totegamma@raspi5:~$ microk8s kubectl get nodes
NAME     STATUS   ROLES    AGE    VERSION
raspi5   Ready    <none>   4m9s   v1.29.5
totegamma@raspi5:~$ microk8s kubectl get pods --all-namespaces
NAMESPACE     NAME                                     READY   STATUS    RESTARTS   AGE
kube-system   calico-kube-controllers-77bd7c5b-bqztq   1/1     Running   0          4m6s
kube-system   calico-node-tc4tr                        1/1     Running   0          4m6s
kube-system   coredns-864597b5fd-w64fs                 1/1     Running   0          4m6s
totegamma@raspi5:~$

プラグインの有効化

totegamma@raspi5:~/concrnt-kustomize$ microk8s enable hostpath-storage
Infer repository core for addon hostpath-storage
Enabling default storage class.
WARNING: Hostpath storage is not suitable for production environments.
         A hostpath volume can grow beyond the size limit set in the volume claim manifest.

deployment.apps/hostpath-provisioner created
storageclass.storage.k8s.io/microk8s-hostpath created
serviceaccount/microk8s-hostpath created
clusterrole.rbac.authorization.k8s.io/microk8s-hostpath created
clusterrolebinding.rbac.authorization.k8s.io/microk8s-hostpath created
Storage will be available soon.
totegamma@raspi5:~/concrnt-kustomize$

ここで表示されているように、hostpath-storageはプロダクション環境では推奨されてはいません。 大人数で利用するサーバーの場合、ほかの方法を検討する必要があります。

gitのインストール

sudo apt install git
totegamma@raspi5:~$ sudo apt install git
Reading package lists... Done
Building dependency tree... Done
Reading state information... Done
The following additional packages will be installed:
  git-man liberror-perl
Suggested packages:
  git-daemon-run | git-daemon-sysvinit git-doc git-email git-gui gitk gitweb git-cvs git-mediawiki git-svn
The following NEW packages will be installed:
  git git-man liberror-perl
0 upgraded, 3 newly installed, 0 to remove and 0 not upgraded.
Need to get 4903 kB of archives.
After this operation, 24.7 MB of additional disk space will be used.
Do you want to continue? [Y/n]
Get:1 http://ports.ubuntu.com/ubuntu-ports noble/main arm64 liberror-perl all 0.17029-2 [25.6 kB]
Get:2 http://ports.ubuntu.com/ubuntu-ports noble-updates/main arm64 git-man all 1:2.43.0-1ubuntu7.1 [1100 kB]
Get:3 http://ports.ubuntu.com/ubuntu-ports noble-updates/main arm64 git arm64 1:2.43.0-1ubuntu7.1 [3777 kB]
Fetched 4903 kB in 3s (1447 kB/s)
Selecting previously unselected package liberror-perl.
(Reading database ... 130091 files and directories currently installed.)
Preparing to unpack .../liberror-perl_0.17029-2_all.deb ...
Unpacking liberror-perl (0.17029-2) ...
Selecting previously unselected package git-man.
Preparing to unpack .../git-man_1%3a2.43.0-1ubuntu7.1_all.deb ...
Unpacking git-man (1:2.43.0-1ubuntu7.1) ...
Selecting previously unselected package git.
Preparing to unpack .../git_1%3a2.43.0-1ubuntu7.1_arm64.deb ...
Unpacking git (1:2.43.0-1ubuntu7.1) ...
Setting up liberror-perl (0.17029-2) ...
Setting up git-man (1:2.43.0-1ubuntu7.1) ...
Setting up git (1:2.43.0-1ubuntu7.1) ...
Processing triggers for man-db (2.12.0-4build2) ...
totegamma@raspi5:~$

コンカレントのプロジェクトファイルのダウンロード

totegamma@raspi5:~$ git clone https://github.com/concrnt/concrnt-kustomize.git
Cloning into 'concrnt-kustomize'...
remote: Enumerating objects: 10, done.
remote: Counting objects: 100% (10/10), done.
remote: Compressing objects: 100% (9/9), done.
remote: Total 10 (delta 0), reused 10 (delta 0), pack-reused 0
Receiving objects: 100% (10/10), 9.68 KiB | 9.68 MiB/s, done.
totegamma@raspi5:~$


totegamma@raspi5:~$ ls
Desktop  Documents  Downloads  Music  Pictures  Public  Templates  Videos  concrnt-kustomize  snap
totegamma@raspi5:~$ cd concrnt-kustomize/
totegamma@raspi5:~/concrnt-kustomize$

各種パラメーターの設定

totegamma@raspi5:~/concrnt-kustomize$ ls
cm-files  configmap-generator.yaml  kustomization.yaml  values.yaml
totegamma@raspi5:~/concrnt-kustomize$

ここで、サーバーの設定を行います。

  • values.yaml: サーバーの名前やアイコン、アドレス等を設定します。
  • cm-files/tos.txt: 利用規約を記載します。
  • cm-files/code-of-conduct.txt: 行動規範を記載します。
  • cm-files/register-template.json: (必要であれば編集)ユーザーが登録する際に記入してもらう情報のテンプレートです。

namespaceの作成

totegamma@raspi5:~/concrnt-kustomize$ microk8s kubectl create namespace concrnt
namespace/concrnt created
totegamma@raspi5:~/concrnt-kustomize$

デプロイ

次のコマンドでデプロイします。 設定ファイルを変更した場合も、このコマンドを実行することで変更が反映されます。

totegamma@raspi5:~/concrnt-kustomize$ microk8s kubectl kustomize . --enable-helm | microk8s kubectl apply -f -
configmap/activitypub-config created
configmap/concrnt-config created
configmap/concrnt-static created
service/ccapi created
service/ccgateway created
service/ccwebui created
service/db created
service/memcached created
service/redis created
persistentvolumeclaim/concrnt-repository created
persistentvolumeclaim/postgres-varlib created
persistentvolumeclaim/redis-data created
deployment.apps/ccapi created
deployment.apps/ccgateway created
deployment.apps/ccwebui created
deployment.apps/concurrent-db created
deployment.apps/concurrent-memcached created
deployment.apps/concurrent-redis created
cronjob.batch/db-backup created
totegamma@raspi5:~/concrnt-kustomize$

一部の自動で反映されない設定を変更したときなど、手動で再起動を行いたい場合は次のコマンドを実行してください。

totegamma@raspi5:~/concrnt-kustomize$ microk8s kubectl rollout restart deployment/ccapi deployment/ccgateway -n concrnt

デプロイの確認

totegamma@raspi5:~/concrnt-kustomize$ microk8s kubectl get pods -n concrnt
NAME                                   READY   STATUS    RESTARTS      AGE
ccapi-6c7bd74ff4-kscvb                 1/1     Running   1 (25s ago)   65s
ccgateway-7ffc8bc8f7-6mt87             1/1     Running   2 (41s ago)   65s
ccwebui-645fbfd67-vjrb4                1/1     Running   0             65s
concurrent-db-66c9c4f5dd-lzkhd         1/1     Running   0             64s
concurrent-memcached-d7bbc79dc-7mthk   1/1     Running   0             64s
concurrent-redis-bf6c8ddb-hfw5v        1/1     Running   0             64s
totegamma@raspi5:~/concrnt-kustomize$

全てのPodがRunning状態になっていることを確認してください。(applyしてすぐは、restarting状態になっていることがあります)