iis服务器助手广告广告
返回顶部
首页 > 资讯 > 后端开发 > GO >通过触发器在 GCP 上部署 Go Cloud Function 时出现“ZIP 不支持 1980 年之前的时间戳”
  • 147
分享到

通过触发器在 GCP 上部署 Go Cloud Function 时出现“ZIP 不支持 1980 年之前的时间戳”

2024-04-05 00:04:30 147人浏览 独家记忆
摘要

本篇文章向大家介绍《通过触发器在 GCP 上部署 Go Cloud Function 时出现“ZIP 不支持 1980 年之前的时间戳”》,主要包括,具有一定的参考价值,需要的朋友可以参考一下。问题

本篇文章向大家介绍《通过触发器在 GCP 上部署 Go Cloud Function 时出现“ZIP 不支持 1980 年之前的时间戳”》,主要包括,具有一定的参考价值,需要的朋友可以参考一下。

问题内容

问题: 我正在尝试在二级编译中通过此步骤部署一个函数 (second-level-compilation.yaml)

- name: 'gcr.io/cloud-builders/gcloud'
  args: ['beta', 'functions',
       'deploy', '${_function_name}',
       '--source', 'path/to/function',
       '--runtime', 'go111',
       '--region', '${_gcp_cloud_function_region}',
       '--entry-point', '${_entrypoint}',
       '--env-vars-file', '${_function_path}/.env.${_deploy_env}.yaml',
       '--trigger-topic', '${_trigger_topic_name}',
       '--timeout', '${_function_timeout}',
       '--service-account', '${_service_account}']

我使用控制台从 cloud build 中收到此错误。

步骤#1:步骤#11:错误:(gcloud.beta.functions.deploy) 使用目录路径/到/函数的源代码创建 zip 存档时出错:zip 不支持 1980 年之前的时间戳

这是全球流程:

  1. 以下步骤是一级编译 (first-level-compilation.yaml)。这是由使用 GitHub 存储库的云构建触发的(通过应用程序 github cloud build):

    - name: 'gcr.io/cloud-builders/gcloud'
      entrypoint: 'bash'
      args: ['-c', 'launch-second-level-compilation.sh ${_MY_VAR}']
  2. 脚本“launch-second-level-compilation.sh”根据 ${_my_var} 执行特定操作,然后启动二级编译,并使用“gcloud builds commit --config”传递大量替换变量=second-level-compilation.yaml --substitutions=_function_name=val,_gcp_cloud_function_region=val,....."

  3. 然后,使用生成并通过 launch-second-level-compilation.sh 脚本传递的替换值来执行本问题开头描述的“second-level-compilation.yaml”。

这里的主要思想是让一个通用的first-level-compilation.yaml负责调用具有特定动态生成的替换的二级编译。

尝试/调查

  1. 正如本期 cloud container builder 中所述,zip 不支持 1980 年之前的时间戳,我尝试“ls”/workspace 目录中的文件。但 /workspace 根目录下的文件都没有奇怪的日期。

  2. 我将 path/to/function 从相对路径更改为 /workspace/path/to/function,但没有成功,毫不奇怪,因为目录结尾是相同的。


解决方案


请确保您没有没有文件的文件夹。例如:

|--dir
   |--subdir1
   |  |--file1
   |--subdir2
      |--file2

在此示例中,dir 不直接包含任何文件,仅包含子目录。在本地部署期间,gcp sdk 将 dir 放入 tarball 中,而不复制 last modded 字段。 因此它被设置为 1st jan 1970 ,这会导致 zip 出现问题。

一种可能的解决方法是确保每个目录至少包含一个文件。

以上就是本文的全部内容了,是否有顺利帮助你解决问题?若是能给你带来学习上的帮助,请大家多多支持编程网!更多关于golang的相关知识,也可关注编程网公众号。

您可能感兴趣的文档:

--结束END--

本文标题: 通过触发器在 GCP 上部署 Go Cloud Function 时出现“ZIP 不支持 1980 年之前的时间戳”

本文链接: https://www.lsjlt.com/news/596115.html(转载时请注明来源链接)

有问题或投稿请发送至: 邮箱/279061341@qq.com    QQ/279061341

本篇文章演示代码以及资料文档资料下载

下载Word文档到电脑,方便收藏和打印~

下载Word文档
猜你喜欢
软考高级职称资格查询
编程网,编程工程师的家园,是目前国内优秀的开源技术社区之一,形成了由开源软件库、代码分享、资讯、协作翻译、讨论区和博客等几大频道内容,为IT开发者提供了一个发现、使用、并交流开源技术的平台。
  • 官方手机版

  • 微信公众号

  • 商务合作