情况如下:我有一个 Firestore 数据库。我每天都会将其下载到 Google Cloud Storage Bucket 作为备份。如果我想在本地下载它,我使用这个命令gsutil -m cp -r gs://BUCKET_PATH "DESTINATION_PATH"
而且效果很好。
我的问题:我下载的Bucket的格式是LevelDB(我认为)。在我的机器上,它看起来像这样:
例如,这是我的/users
当我通过 Google Storage 下载它时,它会存储在 Firestore 中。在该文件夹中,我有多个二进制文件(“output-...”)和一个元数据文件(此处:“all_namespaces_kind_users”)。
MY GOAL:我希望能够读取 json 文件中的数据库。
MY TRIES:
- 我尝试使用这个转换器:https://github.com/Venryx/firestore-leveldb-tools https://github.com/Venryx/firestore-leveldb-tools但它使用Python2和一些旧的谷歌库。使用此转换器,我必须在本地下载 SDK(见下文)。
#repoRoot = os.getcwd()
repoRoot = os.path.dirname(os.path.realpath(__file__))
# import google sdks
sys.path.append(os.path.join(repoRoot, 'SDKs/google_appengine'))
sys.path.append(os.path.join(repoRoot, 'SDKs/google-cloud-sdk/lib/third_party'))
from google.appengine.api.files import records
from google.appengine.datastore import entity_pb
from google.appengine.api import datastore
- 使用先前的转换器,我尝试使用以下建议将其更新到 Python3:https://github.com/Venryx/firestore-leveldb-tools/issues/1#issuecomment-674563473 https://github.com/Venryx/firestore-leveldb-tools/issues/1#issuecomment-674563473。我成功替换了第一个导入
from google.appengine.api.files import records
但其他两个则不然。
- 对于另外两个:
from google.appengine.datastore import entity_pb
and from google.appengine.api import datastore
, 我看到了这个 :https://pypi.org/project/protobuf-cloud-datastore-translator/ https://pypi.org/project/protobuf-cloud-datastore-translator/但我不完全理解。
我的问题:如何将我的 Firestore 数据库(存储在 Google Bucket 中)转换为 json 文件?
也许有人有完全不同的建议方法?还是我应该坚持我的路?在这种情况下,我如何使用更新的 google librairies 将转换器转换为 Python3 ?
额外问题:谷歌怎么没有一个干净的解决方案呢? (还是我傻?)
我在 Python 3 中创建了一个转换器,可以将 firestore 导出文件转换为 JSON 文件firestore-导出-json https://github.com/labbots/firestore-export-json。该软件包提供了一个简单的 CLI 命令来转换文件。
fs_to_json [path_to_source_dir] -d [path_to_destination]
本文内容由网友自发贡献,版权归原作者所有,本站不承担相应法律责任。如您发现有涉嫌抄袭侵权的内容,请联系:hwhale#tublm.com(使用前将#替换为@)