
本文详细介绍了在heroku平台部署go revel应用程序时遇到的常见构建包错误及其解决方案。通过使用一个经过修复的自定义构建包,并遵循一系列清晰的部署步骤,开发者可以成功地将revel应用部署到heroku,确保go环境与revel框架的兼容性,从而避免常见的部署失败问题。
在Heroku上部署Go语言开发的Revel应用程序,通常需要依赖特定的构建包(buildpack)来处理Go环境的设置、依赖管理以及Revel框架的编译。然而,开发者在使用某些社区构建包时,可能会遇到由于构建包内部逻辑缺陷导致的部署失败。本文将深入探讨这类问题,并提供一个经过验证的解决方案,指导您如何成功地将Go Revel应用部署到Heroku。
常见的部署问题识别
当尝试使用早期或存在缺陷的Go Revel构建包(例如 robfig/heroku-buildpack-go-revel)部署应用时,通常会遇到以下错误:
-----> Running: go get -tags heroku ./... mv: cannot stat `/tmp/build_86bd3433-7925-4ae9-b4bf-f5466525aef1/.go/bin/*': No such file or directory ! Push rejected, failed to compile Revel app
这个错误表明构建包在编译Go应用后,尝试移动一个不存在的目录或文件(/tmp/build_.../.go/bin/*),导致部署过程中断并被Heroku拒绝。这通常是由于构建包的脚本逻辑在某些情况下未能正确处理Go编译产物的路径或存在性检查。
解决方案:使用修复后的构建包
为了解决上述问题,可以使用一个经过社区修复的Go Revel构建包。该修复主要针对构建包内部的 mv 命令,使其在移动文件时进行条件判断,避免因目标不存在而报错。
修复后的构建包示例:https://github.com/dougnukem/heroku-buildpack-go-revel.git
部署Go Revel应用的详细步骤
以下是使用修复后的构建包将Revel应用部署到Heroku的完整流程。
1. 环境准备
- Go 语言环境: 确保Go已正确安装并配置 GOPATH。
- Git: 版本控制工具。
- Heroku CLI: Heroku命令行接口,用于与Heroku平台交互。
2. 设置本地Go工作区
首先,定义您的Go工作区。通常,这会在您的用户目录下创建一个 go 文件夹。
export GOPATH=$HOME/go mkdir -p $GOPATH
3. 获取Revel示例应用
接下来,我们将获取一个Revel的HelloWorld示例应用。这里我们使用一个与修复构建包兼容的示例项目。
go get github.com/dougnukem/revel-helloworld cd $GOPATH/src/github.com/dougnukem/revel-helloworld
注意事项:
- go get 命令会将项目克隆到 $GOPATH/src/github.com/dougnukem/revel-helloworld 路径下。
- 请确保进入正确的项目目录,以便后续的Git操作。
4. 创建Heroku应用
在项目根目录中,使用Heroku CLI创建一个新的Heroku应用。
heroku create
执行此命令后,Heroku会为您创建一个新的应用,并自动将其Git远程仓库添加到您的本地仓库中(通常命名为 heroku)。
5. 配置Heroku构建包
这是解决部署问题的关键一步。您需要将Heroku应用的构建包URL设置为修复后的构建包。
heroku config:set BUILDPACK_URL=https://github.com/dougnukem/heroku-buildpack-go-revel.git
重要提示:
- 请确保 BUILDPACK_URL 指向的是一个功能正常且与Revel兼容的构建包。
- 如果未来有官方或更稳定的构建包发布,建议更新此URL。
6. 推送代码到Heroku
现在,您可以将本地的Revel应用代码推送到Heroku。
git push heroku master
Heroku将检测到推送操作,并根据您配置的构建包开始部署过程。如果一切顺利,您将看到Go环境安装、依赖获取以及Revel应用编译成功的日志。
7. 验证部署
部署成功后,您可以通过以下命令在浏览器中打开您的Heroku应用:
heroku open
您应该能看到Revel HelloWorld应用的欢迎页面。
总结
在Heroku上部署Go Revel应用程序时,选择一个稳定且功能完善的构建包至关重要。本文通过识别常见的 mv: cannot stat 错误,并提供了一个经过修复的构建包及其详细的部署步骤,帮助开发者顺利完成Revel应用的部署。遵循这些步骤,您可以有效地避免因构建包缺陷导致的部署失败,确保您的Go Revel应用在Heroku上稳定运行。在遇到部署问题时,检查Heroku日志 (heroku logs --tail) 也是定位问题的有效方法。










