编译运行kubernetes-dashboard源码
前提CentOS7,前端、后端、kubernetes集群同一台linux上的基础环境1.k8s集群部署参考2.go1.8wget -chttps://storage.googleapis.com/golang/go1.8.3.linux-amd64.tar.gztar -C /usr/local -xzf go1.8.3.linux-amd64.tar.
前提
CentOS7,前端、后端、kubernetes集群同一台linux上的
基础环境
1.k8s集群
2.go1.8
wget -c https://storage.googleapis.com/golang/go1.8.3.linux-amd64.tar.gz
tar -C /usr/local -xzf go1.8.3.linux-amd64.tar.gz
export PATH=$PATH:/usr/local/go/bin
echo "PATH=$PATH:/usr/local/go/bin">>/etc/profile
source /etc/profile
3.nodejs
curl --silent --location \
https://rpm.nodesource.com/setup_6.x | bash -
yum -y install nodejs
4.cnpm
npm install -g cnpm --registry=https://registry.npm.taobao.org
5.java1.8
yum install java
6.gulp
cnpm install --global gulp-cli
cnmp install --global gulp
修改文件
在dashboard所在源码包目录下
修改dashboard/build/hyperkube.sh
将其中的镜像地址改为本地仓库的镜像
依次执行如下命令
cnpm install
kubectl proxy --port=8080
gulp serve
编译成功后可在
http://IP:9090访问该dashboard应用
项目架构
dashbodard采用前后端分离设计,前端是使用angular的单页应用,用ES6编写,后端使用go语言的go-restful框架当作http服务器。
整个工作流程如下
frontend(9090) —> Dashboard backend (9091) —> Kubernetes API server (8080)
客户端通过浏览器发送请求给Backend,Backend使用k8s的restful api操作kubernetes资源和获取集群信息。
汉化
对dashboard/src/app/frontend里面的名称进行中文翻译替换
尚未解决问题
1.执行gulp serve:prod
会在配置metric的地方卡住
2.监控图表未能显示(没找到合适的国内镜像)
3.国际化未能通过编译实现
4.通过gulp docker-image:head
命令构建的镜像,启动失败
提示
KUBERNETES_SERVICE_HOST and KUBERNETES_SERVICE_PORT未指定
最终效果
参考文献
更多推荐
所有评论(0)