【问题标题】:Static images in webpage from Google App Engine来自 Google App Engine 的网页中的静态图片
【发布时间】:2014-05-02 08:41:54
【问题描述】:

我正在将一个旧的 Java 项目移植到 GAE。它有一些 servlet,它们生成带有静态图像的 html 页面。在原始项目中,这些图像存储在 servlet 旁边的文件系统中。

我首先尝试使用 GCS,我已经上传了我的文件并授予了公开阅读的权限。在这种情况下,我可以通过它们的公共链接访问文件,我可以将这些链接嵌入到 HTML 输出中。但我有一种感觉,这不是正确的解决方案。加载时间似乎很慢,就像图像不会“在内部传输”一样,我必须为每张图像提供权限。

所以我的问题是,如何在 GAE 应用程序中获取位于 GCS 上的文件的“内部”URL?

我找到了一些Java examples,但在我的情况下,我认为我不需要源中的图像对象,我只需要一个 URL 将其传递给 HTML 源。

据我所知,我可以将源图像作为资源简单地部署,但数量很多。

如果有其他灵魂,比如 Datastore,我也愿意,但我认为 GCS 会是最简单的。

【问题讨论】:

  • 您提到您正在为每张图片设置权限 - 您是否考虑过使用 default object ACLs 功能?这意味着如果在创建时没有指定 ACL,任何上传到存储桶的对象都将自动使用该 ACL 创建。
  • 是的,我把那个弄红了。我已经在开发者控制台中为我的存储桶设置了权限,但是上传的对象由于某种原因没有继承它们。
  • AFAIK,无法通过控制台编辑存储桶的默认对象 ACL。您可能更改的是存储桶本身的 ACL。我们的文档中有一个table 解释了这种关系。设置默认对象 ACL 的最简单方法可能是通过 gsutil's "defacl" command

标签: java google-app-engine servlets google-cloud-storage


【解决方案1】:

Google Cloud Storage 是加载图像的选项,与其他任何选项一样快。浏览器读取链接并要求服务器(在本例中为 GCS)提供图像。没有“内部” URL 可以更快地运行 - 速度反映了 GCS 和请求图像的浏览器之间的带宽/距离。

您可以使用 CDN 加快速度,您的图像存储在世界各地的本地服务器上。仅当您向大量用户提供内容时才有意义,并且它是页面加载速度的关键部分。

另一种加快页面加载时间的方法是使用图像精灵而不是图像。通过这种方式,您可以减少从浏览器到服务器(即 GCS)的请求数量。如果您的图像不经常更改,并且大多数页面需要相同的图像“集合”(即不动态显示),这是一个非常好的解决方案。

【讨论】:

    猜你喜欢
    • 1970-01-01
    • 1970-01-01
    • 1970-01-01
    • 2010-10-16
    • 2016-09-02
    • 1970-01-01
    • 2016-06-12
    • 1970-01-01
    • 2013-12-25
    相关资源
    最近更新 更多