
想使用阿里云 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('biaoac', 'img/1.jpg', $content, $options); } catch (OssException $e) { print $e->getMessage(); } ?> 1 opengps 2019 年 11 月 9 日 这俩语言我都没用熟练,我用 .net 版本上传还是很快的。你可以试试在不同位置打印时间戳日志,分析下具体满在哪一步。重点是那句执行上传的代码的前后要加上时间戳打印,对比这句代码消耗时间的差异 |
2 akira 2019 年 11 月 9 日 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 日 via iPhone 为什么不走内网的 endpoint |