javascript - 在谷歌云存储中获取/设置元数据 - node.js
问题描述
我正在尝试从 Google Cloud Storage 文件中设置和检索元数据,但我正在尝试的似乎不起作用。我的代码在 Kubernetes 节点中运行/我有这个:
// let's make sure that the source file is still there.
let sourceFile = storage.bucket(sourceFileObject.bucket).file( sourceFileObject.name );
const metadata = {
MD_DL_ERROR: 1
};
console.log( `Setting metadata for ${sourceFileObject.name} to: `, metadata );
sourceFile.setMetadata(metadata, function(err, apiResponse) {
console.log( `NOW GETTING METADATA for: ${sourceFileObject.name}` );
sourceFile.getMetadata( function(err, metadata, apiResponse) {
console.log( "got metadata: ", metadata );
} );
});
但是当它运行时,日志中的内容并没有显示任何元数据已设置的迹象:
Setting metadata for CA-SACMLS/20022759_000.jpg to: { MD_DL_ERROR: 1 }
NOW GETTING METADATA for: CA-SACMLS/20022759_000.jpg
got metadata: { kind: 'storage#object',
id: 'idx-photos-raw-gs.ihouseprd.com/CA-SACMLS/20022759_000.jpg/1588629892121256',
selfLink: 'https://blah blah blah',
mediaLink: 'https://blah blah blah',
name: 'CA-SACMLS/20022759_000.jpg',
bucket: 'idx-photos-raw-gs.ihouseprd.com',
generation: '1588629892121256',
metageneration: '2',
contentType: 'image/jpg',
storageClass: 'MULTI_REGIONAL',
size: '124923',
md5Hash: 'HASHVAL',
crc32c: 'koOVMQ==',
etag: 'CKiFmcObm+kCEAI=',
timeCreated: '2020-05-04T22:04:52.120Z',
updated: '2020-05-04T22:04:52.509Z',
timeStorageClassUpdated: '2020-05-04T22:04:52.120Z' }
我错过了什么?
解决方案
我认为这是由于文件元数据的修改延迟造成的(2 请求被触发得非常近且太快),我在您的代码中添加了一个睡眠功能,看起来像预期的那样工作。
const {Storage} = require('@google-cloud/storage');
const storage = new Storage();
const myBucket = storage.bucket('fakebucket');
//sleep definition
const sleep = (waitTimeInMs) => new Promise(resolve => setTimeout(resolve, waitTimeInMs));
const sourceFileObject = myBucket.file('demo.zip');
const metadata = {
metadata: {
rrasd: 'custom',
adsdasdasd: 'go here'
}
};
sourceFileObject.setMetadata(metadata, function(err, apiResponse) {
//wait for the propagation
sleep(250).then(() => {
sourceFileObject.getMetadata(function(err, metadata, apiResponse) {
console.log("got metadata: ", metadata);
})
})
});
};
更新
我更改了代码以避免const metadata
重新定义并且看起来像预期的那样工作,睡眠承诺不共享元数据变量,因为我之前的代码工作,感谢@AndyWallace 提供这个提示
const nmetadata = {
metadata: {
rr123809123asd: 'custom'
}
};
sourceFileObject.setMetadata(nmetadata, function(err, apiResponse) {
sourceFileObject.getMetadata( function(err, metadata, apiResponse) {
console.log( "got metadata: ", metadata );
})
});
};
推荐阅读
- c# - 使用 iTextSharp 以编程方式更改字段的 PDF(动态 XFA)在打开时会引发 SOM 错误
- python-3.x - Python: Upload a package to Azure using SAS URI
- ruby-on-rails - 查看时如何授权单个属性
- webpack - Webpack 生产模式 - NODE_ENV 未定义
- oauth-2.0 - Spring OauthServer如何一次验证2个客户端
- html - Liferay HTML 是如何为控制面板生成的?
- ruby-on-rails - 带有 Turbolinks 的 StimulusJS,必须等待“turbolinks:load”事件才能执行 StimulusJS 控制器
- reactjs - “存储”类型中缺少属性“[Symbol.observable]”
' 但在 'Store 类型中是必需的 '。TS2741 - google-cloud-storage - ML-Engine unable to access job_dir directory in bucket
- json - 在 Ptython3 中解析 Twitter JSON 内容