制作包含自定义rancher/ui的docker镜像

举报
拿我格子衫来 发表于 2022/03/18 00:10:16 2022/03/18
【摘要】 我们知道启动一个rancher服务只需要运行 下面这行代码就行了。 sudo docker run -d --restart=unless-stopped -p 80:80 -p 443:443 rancher/rancher 但如果我们想要对rancher的ui做一些自定义的定制,除了使用官方推荐的修改ui接口外,能否将自定义的U...

我们知道启动一个rancher服务只需要运行 下面这行代码就行了。

sudo docker run -d --restart=unless-stopped -p 80:80 -p 443:443 rancher/rancher

但如果我们想要对rancher的ui做一些自定义的定制,除了使用官方推荐的修改ui接口外,能否将自定义的UI打也打包成一个镜像。

官方推荐的自定义UI部署方式,build时必须确定访问域名,部署到五个机器就要build五次,非常不方便。 所以要想办法,能否将自定义的UI通过官方的build镜像的方式,直接打包到镜像中。

 

既然要通过官方的打包镜像,就要深入分析一下官方镜像的整个打包过程。最直接的方法是去看rancher的源码

去看脚本,dockerfile,以及makefile, dapper 流水线。 整个build流程是非常复杂的

 

基本的构建步骤是

  1. 买一个国外的4核8G的机器
  2. 安装git,docker,下载rancher项目
  3. 执行make指令
  4. 构建完成

     

构建的版本是以项目的最新tag为依据的,最新tag是v2.4.5, 那编译的镜像就是v2.4.5

另外编译的镜像也要为rancher/rancher:xx 否则有可能不能用,因为内部有一些镜像名称校验

此外如果你要build一个包含自定义UI的镜像

只需要两步

  1. build rancher/ui项目构建出一个tar.gz的文件
  2. 修改Dockerfile

     

build rancher/ui 使用的命令是

./scripts/build-static -s -c '123'

123可以随便写,因为这里的变量不会被打包到压缩包里,其实这个命令执行了两次编译,有兴趣的可以多去看看 这个build-static 脚本

 

主要是这部分

if [[ $LATEST -ne 1 ]]; then
  echo "Building Static Tarball..."
  UI_MODE="${MODE}" RANCHER="" CATALOG="" runCmd ./node_modules/.bin/ember build --environment=${ENVIRONMENT} --output-path=${BUILD_DIR}

  # Create a file containing the version
  echo "${PKG_VERSION}" > ${BUILD_DIR}/VERSION.txt

  # Remove .DS_Store files
  runCmd find ${BUILD_DIR} -name '.DS_Store' -exec rm {} \;

  # Create a tarball of the version
  runCmd tar -czf ${BUILD_TGZ} -C ${BUILD_PAR} ${VERSION}
fi;

 

你可以在dist/static目录下找到一个tar.gz的压缩包。 构建包含自定义UI的镜像就要使用这个压缩包,将此文件上传至服务器,

拿到公网访问的链接如 http://1.2.3.4/v2.4.5.tar.gz

是否方法是

在ranhcer的项目下,修改package/Dockerfile

 

找到

curl -sL https://releases.rancher.com/ui/${CATTLE_UI_VERSION}.tar.gz | tar xvzf - --strip-components=1 && \

大概在123行,目前的master版本是如此 

 

 https://releases.rancher.com/ui/${CATTLE_UI_VERSION}.tar.gz 修改为 http://1.2.3.4/v2.4.5.tar.gz

 

齐活,make一下就完事了。

如果要打固定版本的镜像,可以将代码切换到该tag的版本,然后重新打个tag,不能与官方的tag冲突。

 

镜像有8,9百M,所以整个构建过程还是比较慢的,也下载了很多资源。 

 

 

文章来源: fizzz.blog.csdn.net,作者:拿我格子衫来,版权归原作者所有,如需转载,请联系作者。

原文链接:fizzz.blog.csdn.net/article/details/108417872

【版权声明】本文为华为云社区用户转载文章,如果您发现本社区中有涉嫌抄袭的内容,欢迎发送邮件进行举报,并提供相关证据,一经查实,本社区将立刻删除涉嫌侵权内容,举报邮箱: cloudbbs@huaweicloud.com
  • 点赞
  • 收藏
  • 关注作者

评论(0

0/1000
抱歉,系统识别当前为高风险访问,暂不支持该操作

全部回复

上滑加载中

设置昵称

在此一键设置昵称,即可参与社区互动!

*长度不超过10个汉字或20个英文字符,设置后3个月内不可修改。

*长度不超过10个汉字或20个英文字符,设置后3个月内不可修改。