概要
docker 发布应用时, 将 git revision 注入到应用中, 在问题出现时, 可以迅速定位代码版本.
实施步骤
- 获取 git revision
- 将 git revision 传入具体的应用中
- 前端的 revision 通过 yarn build 传入
- 后端的 revision 通过 环境变量传入
获取 git revision
GIT_TAG=`git describe --tags`IFS='-' read -r -a tags <<< $GIT_TAGif [ "${#tags[@]}" = "1" ]; then GIT_COMMIT=$tagselse GIT_COMMIT=`git rev-parse HEAD | cut -c 1-8`fi
上面的代码是获取最新的 git revision 的前 8 位, 如果最新的 git revision 有 tag, 则使用 tag 获取的 git revision 放在 GIT_COMMIT 中.
前端 git revision 注入
首先是 docker build 命令中传入 git revision
docker build -t xxx.latest --build-arg VERSION=${GIT_COMMIT} .
然后在 docker file 中获取 VERSION, 并将其传给 yarn build 命令
ARG VERSION=no-version # 默认值 no-versionRUN yarnRUN yarn build --VERSION=${VERSION}
最后是前端工程中获取此变量, 并在页面的 footer 处显示 git revision
process.argv .filter(str => /^--/.test(str)) .map(str => str.replace('--', '')) .forEach(str => { let sub = str.match(/([\s\S]*)\=([\s\S]*)/) sub ? (TYPE[sub[1]] = sub[2]) : (TYPE[str] = true) })const mergeWebpackConfig = () => (config, env) => { // ...省略... config.plugins = (config.plugins || []).concat([ new webpack.DefinePlugin({ 'process.env.VERSION': JSON.stringify(TYPE['VERSION']) }) ]) // ...省略...}
后端 git revision 注入
本文的例子是基于 golang 的 API 后端, 获取 git revision 的方法和上面类似.
获取 git revision 之后, 在 docker file 中获取 VERSION, 并设置环境变量 VERSION
ARG VERSION=no-versionENV VERSION=${VERSION}
API 服务添加 -v 参数, 用来显示服务的版本
ver := flag.Bool("v", false, "verify version")flag.Parse()if *ver { fmt.Println(os.Getenv("VERSION")) return}