大数跨境

RISC-V公测平台发布 · 如何在SG2042上玩转k3s

RISC-V公测平台发布 · 如何在SG2042上玩转k3s RVBoards
2023-07-29
0
导读:K3s 不仅能够缩短启动集群的时间,还能够减少集群需要消耗的资源。是RISC-V软件生态中不可或缺的一部分。

前言

Kubernetes是一个开源的容器管理平台,通过Kubernetes的跨集群管理功能,用户可以方便地进行应用程序的复制、迁移和跨云平台的部署。

而k3s作为Kubernetes的轻量级发行版,相比传统的Kubernetes具有更小的二进制文件大小和更低的资源消耗。

使用 K3s 不仅能够缩短启动集群的时间,还能够减少集群需要消耗的资源。是RISC-V软件生态中不可或缺的一部分。

接下来就将教大家如何在SG2042上玩转k3s。

一、本次实验材料

1. 一台SG2042服务

2. 已经预先编译好的k3s

已预先编译的k3s二进制文件下载

https://github.com/CARV-ICS-FORTH/k3s/releases

二、实验过程

1. 下载、运行k3s

首先我们下载预先编译好的k3s包:

由于预编译好的k3s包已被分为三个文件,因此需要将三个文件合并为一个文件

解压,并给k3s-riscv64文件添加运行权限:

测试该文件是否能运行,如果出现说明,那就说明成功运行。

将k3s-riscv64文件复制到/usr/local/bin/下,并更名为k3s

注意:不要忘记加上sudo,否则会提示没有权限。

再次测试,看看k3s是否能运行:

2. 下载、运行k3s安装脚本

当然只有k3s二进制文件是不够的,因此我们还需要使用安装脚本以获得完整的k3s体验。

下载k3s安装脚本:

curl -sfL

https://get.k3s.io > k3s-install.sh

运行该脚本:

chmod +x k3s-install.sh
注意,如果直接./k3s-install.sh,会提示不支持的架构,因此需要把前面的参数带上。
INSTALL_K3S_EXEC="server --disable metrics-server" INSTALL_K3S_SKIP_DOWNLOAD="true" bash -x ./k3s-install.sh

查看状态,如提示active那就说明k3s正在运行:

systemctl status k3s

3.运行k3s容器

新建hello-sg2042.yaml打开并往里面复制以下内容:

改自:

https://raw.githubusercontent.com/CARV-ICS-FORTH/kubernetes-riscv64/main/examples/hello-kubernetes.yaml

apiVersion: v1kind: Servicemetadata:  name: hellospec:  type: ClusterIP  ports:  - port: 8080  selector:    app: hello---apiVersion: apps/v1kind: Deploymentmetadata:  name: hellospec:  replicas: 1  selector:    matchLabels:      app: hello  template:    metadata:      labels:        app: hello    spec:      containers:      - name: hello-kubernetes        image: carvicsforth/hello-kubernetes:1.10.1        env:        - name: MESSAGE          value: "Greeting from SG2042!"

保存退出后使用该模板启动一个新的容器:

sudo kubectl apply -f hello-sg2042.yaml

注意:不要忘记sudo,不然就会提示没有权限!

查看pods情况:

sudo kubectl get pods -o wide

(如果看到pod还没显示ip地址,你可以耐心等一会,直到显示pod的ip地址)

使用curl拉取网页,如果拉取到网页,那就说明k3s容器运行成功:

4.开放外部计算机访问

虽然本机可以通过curl访问,但是外部计算机访问不了,那如何让外部计算机访问该网页呢?

这就需要修改hello-sg2042.yaml中的内容了,用编辑器打开hello-sg2042.yaml,然后按照以下内容修改:

apiVersion: v1kind: Servicemetadata:  name: hellospec:  type: NodePort  ports:  - port: 8080    targetPort: 8080    nodePort: 30080    protocol: TCP  selector:    app: hello---apiVersion: apps/v1kind: Deploymentmetadata:  name: hellospec:  replicas: 1  selector:    matchLabels:      app: hello  template:    metadata:      labels:        app: hello    spec:      containers:      - name: hello-kubernetes        image: carvicsforth/hello-kubernetes:1.10.1        env:        - name: MESSAGE          value: "Greeting from SG2042!"

注意:nodePort可以自行修改你想要的,但是只能在30000-32767里选一个。

在浏览器中访问http://175.8.161.253:30080(如果用的是你自己的端口号,请将30080改成你当时设置的nodePort)即可。

三、实验总结:

得益于社区的帮助,k3s已经可以运行在sg2042平台上,但是由于该Fork并未并入k3s官方代码,因此k3s目前未正式支持riscv64。

参考资料:

kubernetes-riscv64下的运行指南

https://github.com/CARV-ICS-FORTH/kubernetes-riscv64#running


正文完


RISC-V公测平台发布》系列文章会持续跟大家分享澎峰RISC-V生态圈的开发者朋友们在RISC-V平台的移植测试成果,目前已发布:
1. RISC-V公测平台发布 · Stream带宽完整测试

2. RISC-V公测平台发布 · 我的世界MohistMC

3. RISC-V公测平台发布 · 第一个WEB Server“Hello RISC-V world!”

4. RISC-V公测平台发布 · 如何在SG2042上玩转k3s(本篇)

未来计划发布:

1. RISC-V公测平台发布 · 第一个BLOG Server"RISC-V成长日记”

欢迎持续关注和参与进来~加入讨论群后,向管理员申请可免费试用64核RISC-V服务器SUDO权限账号
  1. 加入微信讨论群:加iYuta-R2为好友后可拉入群。
  2. 加入QQ讨论群:906962594(RVBoards·Only RISC-V)
    扫描二维码加群👇

对服务器平台有任何的疑问都可以查阅《快速使用指南》(实时更新),也可以加群一起讨论。
64核RISC-V高性能处理器公共测试云平台 · 快速使用指南
https://www.kdocs.cn/l/cmnYcyFIlVRx

【声明】内容源于网络
0
0
RVBoards
内容 0
粉丝 0
RVBoards
总阅读0
粉丝0
内容0