2

我正在使用基于 Ubuntu 12.04(ruby 1.9.2p290 和 rails 3.1.0)的 VM,我的应用程序在本地运行良好。我正在使用 git,当我尝试git push heroku master它不起作用时:

git push heroku master

我得到:“计数对象:435,完成。压缩对象:100%(215/215),完成。写入对象:100%(435/435),73.35 KiB,完成。总计435(增量171),重用435(三角洲 171) "

而且它永远不会完成,所以它不会向heroku推送任何东西。终端永远待命。我是heroku的新手,如果问题很明显,我很抱歉:)

操作系统信息:

工作 [1]+ 运行 git push heroku master &

ps -x

PID TTY 状态时间命令

1078?Ssl 0:00 gnome 会话 --session=ubuntu

1135 ? Sl 0:00 /usr/bin/VBoxClient --clipboard

1147?Sl 0:00 /usr/bin/VBoxClient --display

1154 ? Sl 0:00 /usr/bin/VBoxClient --seamless

1162 ? Sl 0:19 /usr/bin/VBoxClient --draganddrop

1167?Ss 0:00 /usr/bin/ssh-agent /usr/bin/dbus-launch --exit-with-s

1171?S 0:00 /usr/bin/dbus-launch --exit-with-session gnome-sessio

1172 ? Ss 0:01 //bin/dbus-daemon --fork --print-pid 5 --print-addres

1246?Sl 0:00 /usr/bin/gnome-keyring-daemon --start --components=se

1250 ? Sl 0:02 /usr/lib/gnome-settings-daemon/gnome-settings-daemon

1329 ? S 0:00 /usr/lib/gvfs/gvfsd

1334 ? sl 0:00 /usr/lib/gvfs//gvfs-fuse-daemon -f /home/ubuntu/.gvfs

1401 ? Sl 0:03 元城

1417 ? S 0:00 /usr/lib/i386-linux-gnu/gconf/gconfd-2

1421 ? 小号

1426 ? Sl 0:01 unity-2d-panel

1427 ? Sl 0:07 unity-2d-shell

1430 ? S 0:00 /usr/lib/pulseaudio/pulse/gconf-helper

1447 ? Sl 0:01 /usr/lib/bamf/bamfdaemon

1450 ? Sl 0:00 /usr/lib/gnome-settings-daemon/gnome-fallback-mount-h

1453 ? Sl 0:02 鹦鹉螺-n

1455 ? Sl 0:00 /usr/lib/policykit-1-gnome/polkit-gnome-authenticatio

1457 ? Sl 0:00 蓝牙小程序

1468 ? Sl 0:00 nm-小程序

1482 ? S 0:00 /usr/lib/gvfs/gvfs-gdu-volume-monitor

1500?Sl 0:00 /usr/lib/gvfs/gvfs-afc-volume-monitor

1504 ? S 0:00 /usr/lib/gvfs/gvfs-gphoto2-volume-monitor

1518 ? S 0:00 /usr/lib/gvfs/gvfsd-trash --spawner :1.9 /org/gtk/gvf

1521?Sl 0:01 /usr/lib/unity/unity-panel-service

1523 ? Sl 0:00 /usr/lib/dconf/dconf-service

1539?Sl 0:00 /usr/lib/indicator-datetime/indicator-datetime-service

1541?Sl 0:00 /usr/lib/indicator-printers/indicator-printers-service

1543 ? Sl 0:00 /usr/lib/indicator-messages/indicator-messages-service

1545 ? Sl 0:00 /usr/lib/indicator-session/indicator-session-service

1547?Sl 0:00 /usr/lib/indicator-application/indicator-application-

1549?Sl 0:00 /usr/lib/indicator-sound/indicator-sound-service

1574 ? S 0:00 /usr/lib/geoclue/geoclue-master

1591?S 0:00 /usr/lib/ubuntu-geoip/ubuntu-geoip-provider

1597?Sl 0:00 /usr/lib/gnome-disk-utility/gdu-notification-daemon

1603 ? S 0:00 /usr/lib/gvfs/gvfsd-元数据

1609?Sl 0:00 /usr/lib/indicator-appmenu/hud-service

1620 ? Sl 0:00 /usr/lib/unity-lens-applications/unity-applications-d

1622?Sl 0:00 /usr/lib/unity-lens-files/unity-files-daemon

1624 ? Sl 0:00 /usr/lib/unity-lens-music/unity-music-daemon

1626?Sl 0:00 /usr/bin/python /usr/lib/unity-lens-video/unity-lens-

1653?Sl 0:00 /usr/bin/zeitgeist-daemon

1661?Sl 0:00 心灵感应指示器

1668?Sl 0:00 /usr/lib/zeitgeist/zeitgeist-fts

1672?Sl 0:00 时代精神-datahub

1676?S 0:00 /bin/cat

1682 ? Sl 0:00 /usr/lib/telepathy/mission-control-5

1701 ? Sl 0:00 gnome 屏幕保护程序

1703 ? Sl 0:00 /usr/bin/python /usr/lib/unity-scope-video-remote/uni

1728 ? Sl 0:05 侏儒终端

1734 ? S 0:00 gnome-pty-helper

1738 分/2 Ss 0:00 bash

1796 年?Sl 0:00 更新通知

1954 pts/2 S 0:00 git push heroku master

1955 pts/2 S 0:00 ssh git@heroku.com git-receive-pack 'polar-island-471

1959 分/2 R+ 0:00 ps -x

4

2 回答 2

7

您对 Heroku 的推送可能会超时的原因有很多。以我的经验,最常见的原因是由于站点大小,而站点大小是指 3 件事:您的 git 存储库的大小,您的站点被推送到 Heroku 的大小(git 存储库 - 忽略的文件),以及您使用的宝石的大小。Heroku 在容纳大型站点(或长时间运行的进程,就此而言)并不是特别强大,如果您变得太大,您可能会导致您的推送挂起/超时并且间歇性地,这可能会令人困惑。

.git 文件夹 我的网站变得无法解释地大,并且随着时间的推移,我在项目根目录中的 .git 文件夹已经增长到 600mb。谢天谢地,我注意到 heroku deploy 聊天中的一个警告,警告我我的 git repo 太大了。无论如何,由于该文件夹是由 git 在幕后管理的,我最终开始了一个新的 git repo 并将我的代码移到它上面,这使我的网站缩小了 90%。

.slugignore 另一个导致我的站点变得足够大而导致超时的陷阱是允许将日志、我的临时目录和我的 solr 索引目录等内容包含在项目中。在我的 .slugignore 文件中排除所有这些文件夹后,推送变得非常快。是的,您可以使用 .gitignore 获得相同的基本效果,但有些事情我喜欢通过 git 管理,但在推送到 heroku 时忽略。这时候 .slugignore 就派上用场了。

gems 通过完成上述步骤,我将网站缩小到合理的大小,但仍然偶尔会出现超时。然后我意识到宝石也会影响您的网站大小。所以我从我的 gemfile 中删除了一些未使用的 gem,我能够将我的 slug 编译时间从 900+ 秒减少到 250 秒,我的整体部署时间从 15+ 分钟(经常超时)减少到 10 分钟以下。不必为每次部署等待这么长时间并冒一半时间超时的风险,真是一种解脱。

根据您的特定设置,任何或所有这些因素都会真正伤害您。就我而言,我做错了一切。但是,即使您没有超时,您可能仍希望尽可能地修剪您的站点以缩短部署时间。

如何让 heroku 不烂 http://www.stormconsultancy.co.uk/blog/development/6-ways-to-get-more-bang-for-your-heroku-buck-while-making-your-rails-网站超级活泼/

于 2013-08-19T10:20:43.260 回答
1

原因是,我的连接速度很慢。这是我智能手机的接入点。

于 2016-04-06T15:36:59.077 回答