2.2 Module Operations
This quick start guide mainly introduces Module operations based on Module Controller V2. It includes:
- Environment Preparation
- Module Controller V2 >= v2.1.3, Koupleless runtime >= 1.4.1-SNAPSHOT, SOFAArk >= 2.2.16
- Test Base Preparation
- Module Deployment and Status Checking
Environment Preparation
K8S Environment Deployment
Module Controller V2 builds Module operation capabilities based on K8S, so a basic K8S environment is needed first.
Note: Module Controller currently only supports arm64 / amd64 environments.
If you already have a K8S cluster, skip this section.
For local testing, it is recommended to use Minikube to quickly set up K8S locally. Minikube is an open-source tool for local Kubernetes deployment, helping quickly deploy K8S components.
To install Minikube, first, install the Docker environment: Docker Official Website
After installing Docker and starting the Docker daemon, Minikube installation preparation is complete.
Refer to the official documentation for Minikube installation.
Module Controller V2 Deployment
Module Controller V2 can be deployed in two ways:
- Local execution (requires go environment, not recommended)
- Image deployment (recommended)
Next, we will use image deployment as an example.
First, prepare necessary RBAC configuration for Module Controller V2.
- Download Service Account YAML
- Download Cluster Role YAML
- Download Cluster Role Binding YAML
Then apply the above three YAML files to set permissions and bindings for the service account.
Next, prepare the Pod Yaml for Module Controller deployment:
apiVersion: apps/v1
kind: Deployment
metadata:
name: module-controller
spec:
replicas: 1
selector:
matchLabels:
app: module-controller
template:
metadata:
labels:
app: module-controller
spec:
serviceAccountName: virtual-kubelet # Service Account configured in the previous step
containers:
- name: module-controller
image: serverless-registry.cn-shanghai.cr.aliyuncs.com/opensource/release/module-controller-v2:v2.1.3 # already upload to image registry
imagePullPolicy: Always
resources:
limits:
cpu: "1000m"
memory: "400Mi"
ports:
- name: httptunnel
containerPort: 7777
env:
- name: ENABLE_HTTP_TUNNEL
value: "true"
Apply the above YAML to the K8S cluster, and wait for the Module Controller Pod to reach the Running state.
The Module operations capability is now set up. Next, prepare the test base and test Module.
Test Base Deployment
To facilitate onboarding, a Docker image of a test base is provided. First, download the Base Yaml:
apiVersion: apps/v1
kind: Deployment
metadata:
name: base
spec:
replicas: 1
selector:
matchLabels:
app: base
template:
metadata:
labels:
app: base
spec:
containers:
- name: base
image: serverless-registry.cn-shanghai.cr.aliyuncs.com/opensource/test/base-web:1.4.0 # Pre-packaged image, from https://github.com/koupleless/samples/blob/main/springboot-samples/web/tomcat/Dockerfile
imagePullPolicy: Always
ports:
- name: base
containerPort: 8080
- name: arklet
containerPort: 1238
env:
- name: MODULE_CONTROLLER_ADDRESS # which is `koupleless.arklet.http.heartbeat.endpoint` in koupleless runtime in the base-web
value: {YOUR_MODULE_CONTROLLER_IP_AND_PORT} # 127.0.0.1:7777
Replace {YOUR_MODULE_CONTROLLER_IP_AND_PORT}
with the actual Module Controller Pod IP and Port in the YAML.
Apply the modified YAML to the K8S cluster and wait for the Base Pod to reach the Running state.
Once the base has started, verify its successful mapping to a VNode with:
kubectl get nodes
If a node named vnode.test-base.dev appears and is Ready, the base is successfully started and mapped.
The UUID above is generated at base startup and changes each restart.
Next, use port-forward
to expose the base container’s service for verification, using the command:
kubectl port-forward base 8080:8080
Visit link to verify if it maps successfully.
Module Deployment and Status Checking
Module Deployment
First, verify the state before Module installation by visiting the base service: Module Test.
It should return an error page indicating the Module is not installed.
Next, deploy the Module using a Deployment. Apply the Module YAML to K8S for Module deployment. Here is an example for a single Module, notice that the container name must be the same with the biz name defined in the jar:
apiVersion: apps/v1
kind: Deployment
metadata:
name: biz1-web-single-host
labels:
virtual-kubelet.koupleless.io/component: module-deployment
spec:
replicas: 1
selector:
matchLabels:
module: biz1-web-single-host
template:
metadata:
labels:
module: biz1-web-single-host
virtual-kubelet.koupleless.io/component: module
spec:
containers:
- name: biz1-web-single-host # this name must same with the biz name defined in the jar
image: https://koupleless-dosc.oss-cn-hongkong.aliyuncs.com/biz1-web-single-host-0.0.1-SNAPSHOT-ark-biz.jar
env:
- name: BIZ_VERSION
value: 0.0.1-SNAPSHOT
affinity:
nodeAffinity:
requiredDuringSchedulingIgnoredDuringExecution:
nodeSelectorTerms:
- matchExpressions:
# these labels in vnode generated in base `https://github.com/koupleless/runtime/blob/main/arklet-core/src/main/java/com/alipay/sofa/koupleless/arklet/core/hook/base/BaseMetadataHookImpl.java`
# you can define your own labels by implementing your own BaseMetadataHookImpl
- key: base.koupleless.io/name
operator: In
values:
- TO_BE_IMPLEMENTED
- key: base.koupleless.io/cluster-name
operator: In
values:
- default
tolerations:
- key: "schedule.koupleless.io/virtual-node"
operator: "Equal"
value: "True"
effect: "NoExecute"
- key: "schedule.koupleless.io/node-env"
operator: "Equal"
value: "dev"
effect: "NoExecute"
Once deployment is complete, use kubectl get pods
to check the status of all Module pods.
When the pods created by the deployment reach the Running state, the Module installation is complete. Verify by visiting the base service again: Module Test.
You should see the content: hello to /biz1 deploy
, indicating the Module installation is complete.
Module Deletion
Modules can be removed by deleting their Deployment with:
kubectl delete deployment biz1
Check the pod deletion success with kubectl get pods
.
After deletion, visit the base service Module Test to verify Module uninstallation.
The page should revert to the state indicating the Module is uninstalled.
Feedback
Was this page helpful?
Welcome propose feedback to community!
Welcome propose feedback to community, or improve this document directly.。