InstantCommons不缓存 - 每个页面加载请求公共文件

时间:2012-12-20 16:59:03

标签: php mediawiki

我是Practical Plants背后的主要开发者。我们使用InstantCommons从公共区域获取图像,但似乎它们无法在本地缓存,使页面加载速度变慢并给Commons带来不必要的负担。

我设置了$wgUseInstantCommons=true,它可以很好地下载图像,但不会缓存它们。我在我的debug.log中得到了这个:

ForeignAPIRepo: HTTP GET: http://commons.wikimedia.org/w/api.php?titles=File%3ABrassica_oleracea0.jpg&iiprop=timestamp%7Cuser%7Ccomment%7Curl%7Csize%7Csha1%7Cmetadata%7Cmime&prop=imageinfo&iimetadataversion=2&format=json&action=query&redirects=true
Class PEAR_Error not found; skipped loading
ForeignAPIRepo: HTTP GET: http://commons.wikimedia.org/w/api.php?titles=File%3ABrassica_oleracea0.jpg&iiprop=url%7Ctimestamp&iiurlwidth=248&iiurlheight=-1&iiurlparam=248px&prop=imageinfo&format=json&action=query&redirects=true
ForeignAPIRepo::getThumbUrl got remote thumb http://upload.wikimedia.org/wikipedia/commons/thumb/1/11/Brassica_oleracea0.jpg/248px-Brassica_oleracea0.jpg
ForeignAPIRepo: HTTP GET: http://commons.wikimedia.org/w/api.php?titles=mwstore%3A%2F%2Fwikimediacommons-backend%2Fwikimediacommons-thumb%2F1%2F11%2FBrassica_oleracea0.jpg%2F248px-Brassica_oleracea0.jpg&prop=imageinfo&format=json&action=query&redirects=true
ForeignAPIRepo::getThumbUrlFromCache Thumbnail was already downloaded before
ForeignAPIRepo: HTTP GET: http://upload.wikimedia.org/wikipedia/commons/thumb/1/11/Brassica_oleracea0.jpg/248px-Brassica_oleracea0.jpg
ForeignAPIRepo::getThumbUrlFromCache could not write to thumb path: mwstore://wikimediacommons-backend/wikimediacommons-thumb/1/11/Brassica_oleracea0.jpg/248px-Brassica_oleracea0.jpg

请注意,我添加了错误ForeignAPIRepo:getThumbUrlFromCache中的路径输出以尝试理解问题,因此我的ForeignAPIRepo.php文件中的第300-305行看起来像这样

$op = array( 'op' => 'create', 'dst' => $localFilename, 'content' => $thumb );
if( !$backend->doOperation( $op )->isOK() ) {
    wfRestoreWarnings();
    wfDebug( __METHOD__ . " could not write to thumb path: ".$localFilename."\n" );
    return $foreignUrl;
}

任何人都知道这里会发生什么?我的./images目录和所有子目录都是775(apache用户拥有组权限)所以它们肯定是可写的。此外,本地上传的图像工作正常。

如果我可以提供更多信息,请告诉我们!

2 个答案:

答案 0 :(得分:1)

升级到1.20.2修复了这个问题,所以我假设它只是我正在使用的MediaWiki版本的一个错误(1.19.X)。

答案 1 :(得分:0)

请注意,从MediaWiki 1.27开始,InstantCommons will hotlink thumbnails而不是在本地生成它们。这将大大减轻头痛。该配置也可用于旧版本。