想使用阿里云 OSS 存储图片,本地同样的环境下上传 4M 的图片到 OSS,按照帮助文档里的代码实现上传:
PHP 2 秒上传完成感觉速度是正常的,说明不是本地网络慢导致的,不知道 Java 版做了什么设置导致这么慢,经过多次反复测试时间都没什么变化,大家有遇到过这个情况吗,帮忙看看什么是原因导致的?
Java 代码:
import com.aliyun.oss.OSS;
import com.aliyun.oss.OSSClientBuilder;
import com.aliyun.oss.model.PutObjectRequest;
import java.io.File;
import java.io.FileNotFoundException;
/**
* 上传文档: https://help.aliyun.com/document_detail/32013.html?spm=a2c4g.11186623.3.4.3ac339a5K0c1T7
* 简单上传: https://help.aliyun.com/document_detail/84781.html?spm=a2c4g.11186623.2.7.218d59aa5mAief#concept-84781-zh
*/
public class AliOss {
public static void main(String[] args) throws FileNotFoundException {
long start = System.currentTimeMillis();
System.out.println("Start: " + start);
// [1] Endpoint 以杭州为例,其它 Region 请按实际情况填写
// [2] 阿里云主账号 AccessKey 拥有所有 API 的访问权限,风险很高
String endpoint = "oss-cn-beijing.aliyuncs.com";
String accessKeyId = "xxx";
String accessKeySecret = "xxx";
// [3] 创建 OSSClient 实例
OSS ossClient = new OSSClientBuilder().build(endpoint, accessKeyId, accessKeySecret);
// [4] 创建 PutObjectRequest 对象
String filename = System.currentTimeMillis() + ".jpg";
PutObjectRequest putObjectRequest = new PutObjectRequest("biaomac", filename, new File("/Users/Biao/Pictures/storm.jpg"));
// [6] 上传文件
ossClient.putObject(putObjectRequest);
// [7] 关闭 OSSClient
ossClient.shutdown();
// [8] 输出访问文件的 URL
// URL 为 Bucket 域名 biaomac.oss-cn-beijing.aliyuncs.com 加上文件名字,
// 如 https://biaomac.oss-cn-beijing.aliyuncs.com/avatar.jpg
System.out.println("https://biaomac.oss-cn-beijing.aliyuncs.com/" + filename);
System.out.println("End: " + (System.currentTimeMillis() - start));
}
}
PHP 代码:
<?php
require_once __DIR__ . '/autoload.php';
use OSS\OssClient;
use OSS\Core\OssException;
$endpoint = "oss-cn-beijing.aliyuncs.com";
$accessKeyId = "xxx";
$accessKeySecret = "xxx";
try {
$ossClient = new OssClient($accessKeyId, $accessKeySecret, $endpoint);
$content = file_get_contents('/Users/Biao/Pictures/storm.jpg');
$options = array();
$ossClient->putObject('biaomac', 'img/1.jpg', $content, $options);
} catch (OssException $e) {
print $e->getMessage();
}
?>
1
opengps 2019-11-09 23:10:41 +08:00
这俩语言我都没用熟练,我用 .net 版本上传还是很快的。你可以试试在不同位置打印时间戳日志,分析下具体满在哪一步。重点是那句执行上传的代码的前后要加上时间戳打印,对比这句代码消耗时间的差异
|
2
akira 2019-11-09 23:17:30 +08:00
1234567 都输出下日志 看看时间消耗是在哪一步
|
3
jorneyr OP 上传文件 ossClient.putObject(putObjectRequest) 这一句花了 6 秒多,其他的地方都正常
|
4
jorneyr OP 谢谢大家,最后一步一步的 Debug,发现是 ServiceSignature.sign 中获取摘要算法 Mac.getInstance("HmacSHA1") 这一句慢,是系统原因,在 hosts 中增加了 127.0.0.1 localhost Biao.local 后就快了,最后 4M 的文件 1.6 秒就传完了。
|
5
uglyer 2019-11-10 08:41:37 +08:00 via iPhone
为什么不走内网的 endpoint
|