为Heroku静态编译pdftk。 需要将PDF拆分为单页文件
所以我们使用heroku来托管我们的rails应用程序。 我们搬到了雪松堆里。 此堆栈没有安装pdftk库。 我联系了支持,并被告知静态编译它为amd64 ubuntu并将其包含在我的应用程序中。
事实certificate这比我想象的要困难得多。 最初我下载了ubuntu的包( http://packages.ubuntu.com/natty/pdftk ),将其解压缩,并包含二进制文件和共享库。 我遇到了类似的奇怪错误:
Unhandled Java Exception: java.lang.NullPointerException at com.lowagie.text.pdf.PdfCopy.copyIndirect(pdftk) at com.lowagie.text.pdf.PdfCopy.copyObject(pdftk) at com.lowagie.text.pdf.PdfCopy.copyDictionary(pdftk)
我假设这是因为没有安装某些依赖项?
所以这是我的问题:
- 是否有更简单的静态编译库的方法? 或者我是否需要移动其二进制文件及其所有库和依赖项?
- 我只是想将多页PDF分成ruby中的单页文件。 有没有办法在没有PDFTK的情况下做到这一点? 还是我坚持尝试静态编译PDFTK?
感谢您的帮助,我知道这不是一个简单的问题,但非常感谢您对这个问题的帮助。 我浪费了近6个小时试图让这个该死的东西上class。
不幸的是,Heroku不断剥离魔法以增加灵活性。 结果,它越来越像我以前管理和维护自己的服务器的日子。 没有简单的解决方案。 我的“猴子补丁”是将文件发送到我可以安装PDFTK的服务器,处理该文件并将其发回。 不是很好,但它确实有效。 不得不处理这个问题会破坏使用heroku的目的。
简单的解决方案是添加一个在heroku上找不到的pdftk依赖项。
$ldd pdftk linux-vdso.so.1 => (0x00007ffff43ca000) libgcj.so.10 => not found libstdc++.so.6 => /usr/lib/libstdc++.so.6 (0x00007f1d26d48000) libm.so.6 => /lib/libm.so.6 (0x00007f1d26ac4000) libgcc_s.so.1 => /lib/libgcc_s.so.1 (0x00007f1d268ad000) libc.so.6 => /lib/libc.so.6 (0x00007f1d2652a000) libpthread.so.0 => /lib/libpthread.so.0 (0x00007f1d2630c000) /lib64/ld-linux-x86-64.so.2 (0x00007f1d27064000)
我把pdftk和libgcj.so.10放到我的应用程序的/ bin目录中。 然后你只需要告诉heroku在加载libs时查看/ bin目录。
你可以输入
$heroku config LD_LIBRARY_PATH: /app/.heroku/vendor/lib LIBRARY_PATH: /app/.heroku/vendor/lib
要查看当前LD_LIBRARY_PATH的设置,然后添加/ app / bin(或者您选择存储libgcj.so.10的任何目录)。
$heroku config:set LD_LIBRARY_PATH=/app/.heroku/vendor/lib:/app/bin
不利的一面是我的slug大小从15.9MB变为27.5MB
我们遇到了同样的问题,我们提出的解决方案是使用Stapler而不是https://github.com/hellerbarde/stapler ,它是一个python实用程序,只需要在Heroku上安装额外的模块(pyPdf)。
我一直关注这个博客文章: http : //theprogrammingbutler.com/blog/archives/2011/07/28/running-pdftotext-on-heroku/
以下是我安装pyPdf的步骤:
访问heroku bash控制台
heroku run bash
安装最新版本的pyPdf
cd tmp curl http://pybrary.net/pyPdf/pyPdf-1.13.tar.gz -o pyPdf-1.13.tar.gz tar zxvf pyPdf-1.13.tar.gz python setup.py install --user
这会将所有必需的文件放在应用程序根目录下的.local文件下。 我刚下载它并将其添加到我们的git repo以及stapler实用程序中。 最后我更新了我的代码以使用订书机而不是pdftk,etvoilà! 再次从Heroku拆分PDF。
另一种可能更清洁的方法是将其封装在gem中( http://news.ycombinator.com/item?id=2816783 )
我在SO上读了一个类似的问题 ,并且发现Ryan Daigle的这种方法对我也很有用:不是构建难以与Heroku服务器匹配的本地二进制文件,而是使用远程环境来编译和构建所需的依赖项。 这是使用Heroku提供的Vulcan gem完成的。
Ryan的文章“为Heroku应用程序构建依赖二进制文件”
Jon Magic的另一种方法(我未经测试)是直接通过Heroku的bash
下载和编译依赖项,例如直接在服务器上: “在Heroku上编译可执行文件” 。
另外,如果Heroku的底层环境发生了足够的变化,这两种方法都会导致二进制文件破裂。
试试虾 。