Ecosyste.ms: Awesome
An open API service indexing awesome lists of open source software.
https://github.com/wdrdres3qew5ts21/vm-kubevirt-integration
Virtual Machine Migration to Kubernetes with KubeVirt Solution
https://github.com/wdrdres3qew5ts21/vm-kubevirt-integration
argocd kubevirt multus network
Last synced: 15 days ago
JSON representation
Virtual Machine Migration to Kubernetes with KubeVirt Solution
- Host: GitHub
- URL: https://github.com/wdrdres3qew5ts21/vm-kubevirt-integration
- Owner: wdrdres3qew5ts21
- Created: 2021-08-21T20:17:27.000Z (over 3 years ago)
- Default Branch: main
- Last Pushed: 2022-07-03T09:03:25.000Z (over 2 years ago)
- Last Synced: 2024-11-09T04:33:21.042Z (2 months ago)
- Topics: argocd, kubevirt, multus, network
- Language: TypeScript
- Homepage:
- Size: 346 KB
- Stars: 0
- Watchers: 3
- Forks: 0
- Open Issues: 0
-
Metadata Files:
- Readme: readme.md
Awesome Lists containing this project
README
### Current KubeVirt Version (0.50.x+++)
| ปัญหาที่พบ | คำอธิบาย | วิธีแก้ป้ญหา |
| --- | ----------- |-----------|
| KubeVirt ไม่รองรับ Macvlan ทำให้ไม่สามารถวาง VM แล้วเชื่อมต่อข้าม Node ได้ [แก้ได้แล้ว] | เพราะ CNI ต้องการให้ IP กับ MacAddress นั้นตรงกันแต่ MacVlan ทำให้ มี MacAddress ของ VM ถูกย้ายไปที่ระดับ Pod แทนทำให้ Traffic เจ้าไปไม่ถึง|https://github.com/kubevirt/user-guide/pull/528 ทาง KubeVirt แนะนำว่าใช้ NMState แล้วเปลี่ยนไปใช้ Bridge CNI จากนั้นให้ NMState เชื่อมทุกๆ Bridge ของทุกๆ Kube Node เข้าด้วยกัน https://github.com/kubevirt/kubevirt/issues/5483 https://github.com/nmstate/kubernetes-nmstate |
|ถ้าใช้ Multus กับ VM KubeVirt เหมือนจะไม่สามารถ FIX IP ได้เหมือนตอนทำกับ Pod สำหรับ VM ที่ถูก Migrate ขึ้นมา [แก้ได้แล้ว]| https://github.com/kubevirt/kubevirt/issues/4564 ถ้าเป็น Pod ปกติหรือ Interface แรกสามารถใช้ Cloud Init Fix IP ได้แต่ปัญหาคือมันจะไมไ่ด้ Interface Multus เข้าไปและทำให้เชื่อมต่อกับ Pod อื่นหรือออกไปยัง Internet ข้างนอกไมไ่ด้ | ทดลองใช้ FIX NetworkAttchMent ไปก่อน แล้วเชื่อม Bridge เองทีหลัง เพราะว่า IP อยู่ใน วงเดียวกันทำ manual routing เองอาจจะทำได้ |
|ip ไม่ยอมคืนหลงัใช้งาน pod[แก้ได้แล้ว] |https://www.cni.dev/plugins/current/ipam/host-local/ จากทฤษฎีนี้ พบว่าจริงๆแล้วไม่ต้องคืน IP เพราะเรา FIX IP เสมอ https://devopstales.github.io/home/multus/| https://www.cni.dev/plugins/current/ipam/host-local/Repo: https://github.com/wdrdres3qew5ts21/vm-kubevirt-integration (Structure/Assets)
https://github.com/wdrdres3qew5ts21/coredns-integration-operator (Golang Coding)```json
Client Version: version.Info{GitVersion:"v0.44.1", GitCommit:"01805c72083902832ecbd08559f4d3aa88110ea1", GitTreeState:"clean", BuildDate:"2021-08-12T12:35:53Z", GoVersion:"go1.16.6", Compiler:"gc", Platform:"darwin/amd64"}Server Version: version.Info{GitVersion:"v0.50.0", GitCommit:"7e034450c10ad2a879db960b9912be2dff7ed9ce", GitTreeState:"clean", BuildDate:"2022-02-10T13:39:37Z", GoVersion:"go1.17.5", Compiler:"gc", Platform:"linux/amd64"}
```
### Setup Kube-Virt
```
oc new-project kubevirtexport VERSION=$(curl -s https://api.github.com/repos/kubevirt/kubevirt/releases | grep tag_name | grep -v -- '-rc' | sort -r | head -1 | awk -F': ' '{print $2}' | sed 's/,//' | xargs)
echo $VERSION
kubectl create -f https://github.com/kubevirt/kubevirt/releases/download/${VERSION}/kubevirt-operator.yaml# Not working anymore need to enable from KubeVirt CR only
# kubectl create configmap kubevirt-config -n kubevirt --from-literal debug.useEmulation=true# Create Resource Deployment to kubevirt namespace
kubectl create -f https://github.com/kubevirt/kubevirt/releases/download/${VERSION}/kubevirt-cr.yaml
export VERSION=$(curl -s https://github.com/kubevirt/containerized-data-importer/releases/latest | grep -o "v[0-9]\.[0-9]*\.[0-9]*")
kubectl create -f https://github.com/kubevirt/containerized-data-importer/releases/download/$VERSION/cdi-operator.yaml
kubectl create -f https://github.com/kubevirt/containerized-data-importer/releases/download/$VERSION/cdi-cr.yaml
# Update KubeVirt CR to use Software Emulation
oc apply -f final-solution/kubevirt-cr/```
# Kubevirt Software Emulation
Not working anymore need to enable from KubeVirt CR only
https://github.com/kubevirt/kubevirt/blob/main/docs/software-emulation.md# Create Demo Cirros VM
https://kubevirt.io/user-guide/virtual_machines/templates/#templates```
oc project kubevirt
kubectl apply -f https://kubevirt.io/labs/manifests/vm.yaml
```
CDI KubeVirt
```
export VERSION=$(curl -s https://github.com/kubevirt/containerized-data-importer/releases/latest | grep -o "v[0-9]\.[0-9]*\.[0-9]*")
kubectl create -f https://github.com/kubevirt/containerized-data-importer/releases/download/$VERSION/cdi-operator.yaml
kubectl create -f https://github.com/kubevirt/containerized-data-importer/releases/download/$VERSION/cdi-cr.yaml
```# Start Mock VM
```
oc get vms
virtctl start testvm
```
Check Prometheus Metrics
```
oc port-forward svc/kubevirt-prometheus-metrics -n kubevirt 8888:443https://localhost:8888/metrics
```
https://kubevirt.io/user-guide/operations/component_monitoring/#integrating-with-the-prometheus-operatorhttps://www.redhat.com/sysadmin/openshift-terminating-state
```
kubevirt_vmi_memory_resident_bytes{name="vm-test-01",namespace="default",node="node01"} 2.5595904e+07
kubevirt_vmi_network_traffic_bytes_total{domain="default_vm-test-01",interface="vnet0",name="vm-test-01",namespace="default",node="node01",type="rx"} 8431
kubevirt_vmi_network_traffic_bytes_total{domain="default_vm-test-01",interface="vnet0",name="vm-test-01",namespace="default",node="node01",type="tx"} 1835
kubevirt_vmi_vcpu_seconds{domain="default_vm-test-01",id="0",name="vm-test-01",namespace="default",node="node01",state="1"} 19
```Expose port
```
oc new-project vm-imagesoc project vm-images
virtctl image-upload dv ubuntu20-iso-dv --image-path="$PWD/ubuntu-20-server.iso" --size=5Gi --insecure
virtctl expose vmi fedora --name=fedora-ssh-port --port=20222 --target-port=22
virtctl image-upload --pvc-name=win10-home --image-path="$PWD/win10.iso" --size=5.5Gi --insecure
virtctl image-upload dv fedora35-iso-dv -n vm-images --image-path="$PWD/fedora-35-server.iso" --size=5.5Gi --insecure
```
### Image ใช้จริงอยู่ตรงนี้
### Need using IMG or QCOW2 format for automatic boot system```
oc project vm-imagesvirtctl image-upload dv database-server-vm-dv -n vm-images --image-path="$PWD/data-server-sql.img" --size=25Gi --insecure
virtctl image-upload dv frontend-server-vm-dv -n vm-images --image-path="$PWD/frontend-server.img" --size=25Gi --insecure
virtctl image-upload dv backend-server-vm-dv -n vm-images --image-path="$PWD/backend-server-docker.img" --size=25Gi --insecure
virtctl image-upload dv ubuntu20-cloud-dv -n vm-images --image-path="$PWD/ubuntu-20-server.img" --size=5.5Gi --insecure
virtctl image-upload dv fedora35-cloud-dv -n vm-images --image-path="$PWD/fedora-35-cloud.qcow2" --size=2Gi --insecure
virtctl image-upload pvc fedora35-cloud-dv -n vm-images --image-path="$PWD/fedora-35-cloud.qcow2" --size=2Gi --insecureoc new-project legacy-company
# Maybe not require anymore ?
oc adm policy add-scc-to-user ibm-anyuid-hostaccess-scc -z defaultoc proeject legacy-company
oc adm policy add-scc-to-user privileged -z default
```# Using `./tool` for Debug about Network to Virtual Machine Pod
Network Debug Pod Required Privileged to Access Linux Capabilities Feature
Inside nettool pod just paste SSH Private Key so you can login to VM
```
oc apply -f tool/
```
Login to VM with this Solution
```
oc exec -it nettool-fc8556c58-ktrs6 bash
## inside Nettool (Network Debug Pod)ssh root@
```
VM can be hardcode IP by setting Ethernet Interface at Virtual Machine CRในปัจจุบันถ้าเราใช้ Custom IP ที่สร้างขึ้นมาเองจาก Multus Pod ที่ใช้ Custom IP ตัวนั้นจากสามารถ Ping เจอกันแค่อยู่ใน Host เดียวกันเท่านั้นเพราะว่ามันใช้ Bridge เดียวกัน สามารถลองดูตัวอย่างได้จาก Pod Frontend ของเรา ถ้าหากเราไม่ใช้ Custom IP จะไม่มี Bridge พิเศษสร้างขึ้นมา
โดยในปัจจุบัน Pod ที่มีการใช้ Custom IP คือ Fedora-Warehouse, Ubuntu-Database, Frontend todo หมายควาว่าถ้า Pod เหล่านี้ไปลงที่ Node ไหน Node เหล่านั้นจะต้องมี Bridge Custom ขึ้นมา
ใช้ MACVLAN แก้ปัญหาข้าม Node ได้```yaml
apiVersion: kubevirt.io/v1
kind: VirtualMachine
metadata:
generation: 1
labels:
kubevirt.io/os: linux
name: fedora-warehouse-domain
namespace: legacy-company
... Reduce Detail about this Example for more detail see ./final-solution/virtual-machine/fedora-warehouse-domain.yaml
networkData: |
version: 2
ethernets:
eth0:
addresses:
- 192.168.255.1/24
```
https://developers.redhat.com/blog/2019/11/12/using-the-red-hat-openshift-tuned-operator-for-elasticsearchMount Capability net เข้ามาให้ forward ได้ผ่าน sysctl init contaienr
https://cloud.ibm.com/docs/openshift?topic=openshift-kernel#workerการทำให้ Network สามารถ Routing ข้าม Subnet กันได้ทำได้จากวิธีการเพิ่ม Default GW Routing ข้ามไปยังอีก Kubernetes Node หนึ่งซึ่งทำเฉพาะตัวที่เป็น Router ก็พอแล้ว
sudo apt-get install openjdk-11-jdk
sysctl -w net.ipv4.ip_forward=1
kubelet --allowed-unsafe-sysctls 'net.ipv4.ip_forward'
ls -alZ /proc/sys/net/ipv4/ip_forward
เวลา forward package มันจะวิ่งตรงไปเลยไม่มีการแปลง IP ที่ตรงกลางตัวอย่างเช่นจาก Public ไปหา Private Subnet ที่เครื่อง Router ก็จะเห็น IP ถูก Forward ตรงๆไปเลย
```
18:33:53.749498 IP 192.168.15.26 > 192.168.16.17: ICMP echo request, id 55, seq 122, length 64
18:33:53.749523 IP 192.168.16.17 > 192.168.15.26: ICMP echo reply, id 55, seq 122, length 64
18:33:54.749449 IP 192.168.15.26 > 192.168.16.17: ICMP echo request, id 55, seq 123, length 64
18:33:54.749479 IP 192.168.16.17 > 192.168.15.26: ICMP echo reply, id 55, seq 123, length 64
``````
ip route add 192.168.16.0/24 via 192.168.15.20 dev net1
```
ใช้ `TCP Dump` ตรงกลางที่ Router ซึ่งมี Interface สองขาคือ Subnet Public กับ Subnet Private
```
tcpdump -i
```
ตัวอย่างเช่น public interface วิ่งด้วย net1 เชื่อมไปหา router ด้วย net1 ก็ต้อง dump ด้วย net1
ซึ่งระหว่างที่มี packet วิ่งมาที่ router ตรงกลาง traffic นั้น forward จาก Interface net1 ไปหา net2 เราจึงต้องทำการเปิด sysctl routing `net.ipv4.ip_forward` ด้วย และก็ใช้ NAT ในการแปลงระหว่าง Network ที่อยู่คนล่ะวงซึ่งจะต้องการสิทธิของ Linux Routing `RTNETLINK answers: Operation not permitted` จึงจะสามารถเพิ่ม routing ได้ จึงต้องเพิ่มสิทธิ
`NET_ADMIN` เข้าไปด้วย
https://blog.pentesteracademy.com/linux-security-understanding-linux-capabilities-series-part-i-4034cf8a7f09https://www.youtube.com/watch?v=5qHjNRKQh3M&ab_channel=LinuxEssentials
# Using `./final-solution` directory for create Infrastructure
ถ้าใช้ VM-Images ข้าม Namespace แล้วจะเกิด Error ดั่งนี้ ต้องให้สิทธิในการ Clone DataVolume เลยต้องทำการให้สิทธิด้วยนั่นเอง
```
oc apply -f final-solution/virtual-machine/
Error from server (Invalid): error when creating "final-solution/virtual-machine/fedora-crm-domain.yaml": admission webhook "virtualmachine-validator.kubevirt.io" denied the request: Authorization failed, message is: User system:serviceaccount:legacy-company:default has insufficient permissions in clone source namespace vm-images
``````
oc new-project legacy-company
oc project legacy-company
oc apply -f final-solution/rbac
oc apply -f final-solution/virtual-machine/
```# Using `./dns` directory for demonstrate problem
จะสร้างตัวอย่างของ DNS Middleware Layer ที่ทำให้ Pod ใน Kubernetes สามารถ Resolve Private Domain ใหม่ได้ทันทีโดยไม่ต้องแก้ Config อะไรในตัว Pod เลยเพราะว่าตัว Pod นั้นมา Query CoreDNS ของ Cluster หลักแล้ว Traffic ก็ถูกไปถาม DNS Server ตัวใหม่ที่เราสร้างจากตรงนี้ได้ด้วยเช่นกันนั่นเอง
```
oc apply -f dns
```# Debug Kubernetes Node (Real Host that host pod)
```
oc debug node/
```Argo Kubevirt
```
virtualmachines.kubevirt.io "ubuntu" is forbidden: User "system:serviceaccount:thesis-virt:argocd-argocd-application-controller" cannot patch resource "virtualmachines" in API group "kubevirt.io" in the namespace "thesis-virt"
```ปัญหา
1. IP เปลี่ยนเอง
2. การจัดการ Disk หลายๆตัว
3. Migrate VM ไปอีก Node Hardwareไฟล์ system มันไปเก็บใน pvc ของ Base ISO Image เลยซึ่งมันผิด# vm-kubevirt-integration
Trigger Argo Hook
webook
https://argoproj.github.io/argo-cd/operator-manual/webhook/Debug network
xdig @dns.openshift-dns.svc.cluster.local -p 8053 infra.napzz-thesis-chula.com
http://www-inf.int-evry.fr/~hennequi/CoursDNS/NOTES-COURS_eng/syntax.html
https://cloud.redhat.com/blog/using-the-multus-cni-in-openshift
https://github.com/openshift/multus-cni/blob/master/docs/quickstart.md
### วิธ๊เข้าเครื่อง
เข้าไปใน pod debug network
```
ssh -i id_rsa [email protected]
```## Operator Requirement
Golang 1.16.x Version (only)swtich GO version
https://stackoverflow.com/questions/58210941/unable-to-brew-switch-go-versions### Local Virtual Machine Snapshot
192.168.18.5
data-server (ubuntu 20.04)
username: supakorn
password: lnwza007192.168.18.4
backend-server (ubuntu 20.04)
username: supakorn
password: lnwza007192.168.18.6
frontend-server (ubuntu 20.04)
username: supakorn
password: lnwza007ต้อง dump vmdk format ออกมาด้วยคำสั่งนี้
```
VBoxManage clonehd --format VMDK data-server.vmdk data-server.imgVBoxManage clonehd --format RAW data-server.vmdk backend-server-final.img
```https://blogs.oracle.com/cloud-infrastructure/post/running-kvm-and-vmware-vms-in-container-engine-for-kubernetes
KubeVirt มีปัญหากับ Macvlan ต้องใช้ Bridge แทน
https://github.com/kubevirt/kubevirt/issues/5483#issuecomment-1077625725Interface Network ที่ใช้งานประเภทความต่างระหว่าง Hardware Emulation กับ para Virtual ซึ่งเราต้องเปลี่ยน Interfacte ลองให้ใช้เป้น Virt-o ไปเลย และก็ configure ตัว VM ด้วย NetworkManager แทนที่จะใช้ NetworkD โดยตรงถ้าเป็น Ubuntu ให้ไปเปลี่ยนใน Netplan ใช่เป้น backend Network Manger
https://www.nakivo.com/blog/virtualbox-network-setting-guide/
https://askubuntu.com/questions/1290471/ubuntu-ethernet-became-unmanaged-after-update
our /etc/netplan/*.yaml file should look like:
```
network:
version: 2
renderer: NetworkManager
```
ตามด้วยคำสั่ง
```
sudo netplan generatesudo netplan apply
reboot
```
### Virtual Machine Detailติดตั้ง mysql ลงใน ubuntu data-server
https://www.digitalocean.com/community/tutorials/how-to-install-mysql-on-ubuntu-20-04sudo apt install mysql-server
sudo systemctl start mysql.service
### Local Virtual Machine Snapshot192.168.18.4
backend-server (ubuntu 20.04)
username: supakorn
password: lnwza007192.168.18.5
data-server (ubuntu 20.04)
username: supakorn
password: lnwza007192.168.18.7
crm-server (ubuntu 20.04)
username: supakorn
password: lnwza007### SQL Script on Data-Server
https://www.digitalocean.com/community/tutorials/how-to-create-a-new-user-and-grant-permissions-in-mysql
วิธี login เข้าระบบ mysql ผ่าน socket authneticatio root user```
sudo mysql
```
แก้ไฟล์ Config ใน /etc/mysql/mysql.conf.d
```
select user,host from mysql.user;CREATE USER 'supakorn'@'192.168.18.4' IDENTIFIED BY 'lnwza007';
GRANT all privileges ON *.* TO 'supakorn'@'192.168.18.4';
flush privilegescreate database napzz;
use napzz
create table customer(id int primary key,firstname varchar(100),lastname varchar(100),age int,)
inser ข้อมูลลงไป
```ต่อ mysql แบบ remote ด้วยคำสั่ง
```
mysql -h 192.168.18.5 -P 3306 -u supakorn -p
```ในเครื่อง Fedora ทดลองเปลี่ยน IP Address
```
nmcli show connectionnmcli con mod enps03 ipv4.addresses 192.168.18.5/24
```ตอนนี้ตัว Bridge Router Pingไปหา Ip VM KubeVirt แต่ว่ามันไปไม่ได้เพราะมันใช้ MacVlan
https://github.com/kubevirt/kubevirt/issues/5483### Debug Bridge Network
แสดง Link ที่เชื่อมอยู่ใน Bridge นั้นๆและ debug Network Namespace
```
brctl show# ใช้คำสั่งนี้แทน brctl ได้ในการดู bridge
ip link show type bridgeip link show master brse
ip netns list
545: vetha3ba3899@if8: mtu 1500 qdisc noqueue master brse state UP mode DEFAULT group default
link/ether fa:39:1a:4b:ab:30 brd ff:ff:ff:ff:ff:ff link-netnsid 43
553: veth1ccc0e6e@if6: mtu 1500 qdisc noqueue master brse state UP mode DEFAULT group default
link/ether e2:2d:1e:2f:44:cb brd ff:ff:ff:ff:ff:ff link-netnsid 44
839: veth7d1146c3@if6: mtu 1500 qdisc noqueue master brse state UP mode DEFAULT group default
link/ether 8a:71:24:5b:c4:0e brd ff:ff:ff:ff:ff:ff link-netnsid 45
```### Static IP For KubeVirt
ถ้าเกิดเราใช้ IPAM แบบปกติมันจะ Fix IP ของ Multus ไมไ่ด้เราต้องใช้ Static NetworkAttachment มาเสียบลงไปแล้วใช้ Bridge เดียวกันกับก่อนหน้าที่เราใช้ ให้ดูที่สองไฟล์นี้เป็นตัวอย่างจะใช้ CNI ประเภท Bridge แทน macvlan เพื่อแก้ปัญหา Network จาก Kubevirt https://github.com/kubevirt/kubevirt/issues/5483
และใช้ Bridge ชื่อเดียวกันทำให้ plugin สำเร็จและ Routing ได้```
oc apply -f final-solution/bridge-virtual-machine/ubuntu-second-domain.yamloc apply -f final-solution/bridge-virtual-machine/bridge-static.yaml
```เครื่องจริงที่ใช้คือเครื่องที่โดน Import VM โดยตรงก็ทำงาไนด้เช่นเดียวกันโดยการใช้เทคนิค FIX IP
```
oc apply -f final-solution/bridge-virtual-machine/database-server.yamloc apply -f final-solution/bridge-virtual-machine/bridge-server.yaml
```### การใช้ NMState เชื่อม Bridge ข้าม Node
https://kubevirt.io/2020/Multiple-Network-Attachments-with-bridge-CNI.htmlลง Network Add-on Manager CRD
```
kubectl apply -f https://github.com/kubevirt/cluster-network-addons-operator/releases/download/v0.74.0/namespace.yaml
kubectl apply -f https://github.com/kubevirt/cluster-network-addons-operator/releases/download/v0.74.0/network-addons-config.crd.yaml
kubectl apply -f https://github.com/kubevirt/cluster-network-addons-operator/releases/download/v0.74.0/operator.yaml
```จะไปสร้าง DaemonSet namespace `cluster-network-addons` สร้าง Resource Network AddOns
```
oc apply -f final-solution/02-nmstate/manifest
oc apply -f final-solution/02-nmstate/mmstate.yaml```
ลง Kubernetes NMState CRD ซึ่งจะใชเในการจัดการ Network Manager บนเครื่อง Host ให้ Clone git ลงมาก่อนแล้วติดตั้งลงไป
https://github.com/nmstate/kubernetes-nmstate```
oc apply -f final-solution/02-nmstate/bundle/
```### บั้คเกี่ยวกับ JVM รายละเอียดปลีกย่อย
BackendServer
ssh supakorn@localhost -p 2200docker run -p 8080:8080 quay.io/linxianer12/todoapp-frontend:1.0.0
docker run -p 8080:9090 quay.io/linxianer12/subject-reservation-service:b0dff8a-dirty
### Forward ไปหา Private Network
ต้องใช้ domian internal เหมือนเดิมเพราะว่า Certificate นั้นผูกไว้กับ Domain ที่เรียก เราเลยต้องแก้ที่ `/etc/hosts` แทนเพื่อให้รักษา Certificate ที่ Signining Domain เอาไว้semanage fcontext -a -t container_file_t "$(pwd)/nginx(/.*)?"
restorecon -Rv nginx/podman run -p 3030:3030 -d -v /home/lab-user/nginx/:/etc/nginx/conf.d docker.io/nginx:1.21.6-perl
podman run -p 3030:3030 -d quay.io/linxianer12/proxy-openshift-kubevirt-lab:0.0.1
-v /home/lab-user/nginx/:/etc/nginx/conf.d
sudo su
firewall-cmd --add-port=3030/tcp --permanent
firewall-cmd --reload
export KUBECONFIG=/home/lab-user/scripts/ocp/auth/kubeconfig
export KUBECONFIG=/Users/supakorn.t/ProjectCode/kubevirt-thesis/kubeconfig
docker build -t quay.io/linxianer12/proxy-openshift-kubevirt-lab:0.0.1
บั้ค NMState ทำ Network หลุด
https://bugzilla.redhat.com/show_bug.cgi?id=2037411ทดสอบบน Openshift 4.7 ด้วย RHEL 8.3 สามารถโหลดได้
ลง
```
pip3 gdowngdown https://drive.google.com/uc?id=1L7yh-lSS-fMLoF_VaVcMh7oW1ZF0MFnV
gdown https://drive.google.com/uc?id=11hL6vi57S7poek7PTtR53ZTMBEANQPmz
gdown https://drive.google.com/uc?id=10UGymHtlGYzoMAq1R57ztpR0Rc80vs1k
# Backend Server
gdown https://drive.google.com/uc?id=1PrpUa8lYf1tbqWLFMe_GXfFa2Yjg3JxE# chula
gdown https://drive.google.com/uc?id=1gUlzGOCbQAxDjBxmjV3qlKxfMlu4SLoA
``````
NAME STATUS ROLES AGE VERSION
master-0.ocp.example.com Ready master 416d v1.20.0+5fbfd19
master-1.ocp.example.com Ready master 416d v1.20.0+5fbfd19
master-2.ocp.example.com Ready master 416d v1.20.0+5fbfd19
worker-0.ocp.example.com Ready worker 416d v1.20.0+5fbfd19
worker-1.ocp.example.com Ready worker 416d v1.20.0+5fbfd19
worker-2.ocp.example.com Ready worker 416d v1.20.0+5fbfd19
[lab-user@provision Downloads]$ oc get nncp
NAME STATUS
brse-ens5 SuccessfullyConfigured
[lab-user@provision Downloads]$ oc get nnce
NAME STATUS
master-0.ocp.example.com.brse-ens5 NodeSelectorNotMatching
master-1.ocp.example.com.brse-ens5 NodeSelectorNotMatching
master-2.ocp.example.com.brse-ens5 NodeSelectorNotMatching
worker-0.ocp.example.com.brse-ens5 SuccessfullyConfigured
worker-1.ocp.example.com.brse-ens5 SuccessfullyConfigured
worker-2.ocp.example.com.brse-ens5 SuccessfullyConfigured
[lab-user@provision Downloads]$ uname -a
Linux provision 4.18.0-240.15.1.el8_3.x86_64 #1 SMP Wed Feb 3 03:12:15 EST 2021 x86_64 x86_64 x86_64 GNU/Linux
[lab-user@provision Downloads]$ cat /etc/os-release
NAME="Red Hat Enterprise Linux"
VERSION="8.3 (Ootpa)"
ID="rhel"
ID_LIKE="fedora"
VERSION_ID="8.3"
PLATFORM_ID="platform:el8"
PRETTY_NAME="Red Hat Enterprise Linux 8.3 (Ootpa)"
ANSI_COLOR="0;31"
CPE_NAME="cpe:/o:redhat:enterprise_linux:8.3:GA"
HOME_URL="https://www.redhat.com/"
BUG_REPORT_URL="https://bugzilla.redhat.com/"REDHAT_BUGZILLA_PRODUCT="Red Hat Enterprise Linux 8"
REDHAT_BUGZILLA_PRODUCT_VERSION=8.3
REDHAT_SUPPORT_PRODUCT="Red Hat Enterp
```### Expose Service ให้ใช้ได้กับ VM
virtctl expose vmi backend-server --port=9090 --target-port=9090 --name backend-server