GAE - 我无法清除数据存储区,数据存储区已损坏我相信

时间:2013-05-22 08:58:49

标签: google-app-engine

不知何故,我的本地数据存储已损坏,我想清除它,但我没有这样做。

我似乎无法运行任何现在使用数据存储区的代码,因为它处于错误状态。

我使用以下commnand:

dev_appserver.py --clear_datastore GoogleAppEngine GoogleAppEngine是我的app文件夹

以下是控制台上的日志:

由于我使用的是GO而不是JAVA,我找不到和删除文件一样 ./WEB-INF/appengine-generated/local_db.bin任何地方。

M:\nick\svn\projects>dev_appserver.py --clear_datastore GoogleAppEngine
Traceback (most recent call last):
  File "M:\Softwares\Dev Tools\SDK\google_appengine\dev_appserver.py", line 182, in <module>
    _run_file(__file__, globals())
  File "M:\Softwares\Dev Tools\SDK\google_appengine\dev_appserver.py", line 178, in _run_file
    execfile(script_path, globals_)
  File "M:\Softwares\Dev Tools\SDK\google_appengine\google\appengine\tools\devappserver2\devappserver2.py", line 689, in <module>
    main()
  File "M:\Softwares\Dev Tools\SDK\google_appengine\google\appengine\tools\devappserver2\devappserver2.py", line 679, in main
    options = PARSER.parse_args()
  File "C:\Python27\lib\argparse.py", line 1688, in parse_args
    args, argv = self.parse_known_args(args, namespace)
  File "C:\Python27\lib\argparse.py", line 1720, in parse_known_args
    namespace, args = self._parse_known_args(args, namespace)
  File "C:\Python27\lib\argparse.py", line 1926, in _parse_known_args
    start_index = consume_optional(start_index)
  File "C:\Python27\lib\argparse.py", line 1866, in consume_optional
    take_action(action, args, option_string)
  File "C:\Python27\lib\argparse.py", line 1794, in take_action
    action(self, namespace, argument_values, option_string)
  File "M:\Softwares\Dev Tools\SDK\google_appengine\google\appengine\tools\boolean_action.py", line 67, in __call__
    raise ValueError('must be "yes" or "no", not %r' % values)
ValueError: must be "yes" or "no", not 'GoogleAppEngine'

M:\nick\svn\projects>dev_appserver.py --clear_datastore GoogleAppEngine

以下是我尝试访问DataStore Viewer页面时的屏幕内容。

Traceback (most recent call last):
  File "M:\Softwares\Dev Tools\SDK\google_appengine\lib\webapp2-2.5.1\webapp2.py", line 1536, in __call__
    rv = self.handle_exception(request, response, e)
  File "M:\Softwares\Dev Tools\SDK\google_appengine\lib\webapp2-2.5.1\webapp2.py", line 1530, in __call__
    rv = self.router.dispatch(request, response)
  File "M:\Softwares\Dev Tools\SDK\google_appengine\lib\webapp2-2.5.1\webapp2.py", line 1278, in default_dispatcher
    return route.handler_adapter(request, response)
  File "M:\Softwares\Dev Tools\SDK\google_appengine\lib\webapp2-2.5.1\webapp2.py", line 1102, in __call__
    return handler.dispatch()
  File "M:\Softwares\Dev Tools\SDK\google_appengine\google\appengine\tools\devappserver2\admin\admin_request_handler.py", line 95, in dispatch
    super(AdminRequestHandler, self).dispatch()
  File "M:\Softwares\Dev Tools\SDK\google_appengine\lib\webapp2-2.5.1\webapp2.py", line 572, in dispatch
    return self.handle_exception(e, self.app.debug)
  File "M:\Softwares\Dev Tools\SDK\google_appengine\lib\webapp2-2.5.1\webapp2.py", line 570, in dispatch
    return method(*args, **kwargs)
  File "M:\Softwares\Dev Tools\SDK\google_appengine\google\appengine\tools\devappserver2\admin\datastore_viewer.py", line 721, in get
    start))
  File "M:\Softwares\Dev Tools\SDK\google_appengine\google\appengine\tools\devappserver2\admin\datastore_viewer.py", line 658, in _get_entity_template_data
    cls.NUM_ENTITIES_PER_PAGE)
  File "M:\Softwares\Dev Tools\SDK\google_appengine\google\appengine\tools\devappserver2\admin\datastore_viewer.py", line 131, in _get_entities
    entities = query.Get(count, start)
  File "M:\Softwares\Dev Tools\SDK\google_appengine\google\appengine\api\datastore.py", line 1674, in Get
    return list(self.Run(limit=limit, offset=offset, **kwargs))
  File "M:\Softwares\Dev Tools\SDK\google_appengine\google\appengine\datastore\datastore_query.py", line 2892, in next
    next_batch = self.__batcher.next()
  File "M:\Softwares\Dev Tools\SDK\google_appengine\google\appengine\datastore\datastore_query.py", line 2754, in next
    return self.next_batch(self.AT_LEAST_ONE)
  File "M:\Softwares\Dev Tools\SDK\google_appengine\google\appengine\datastore\datastore_query.py", line 2791, in next_batch
    batch = self.__next_batch.get_result()
  File "M:\Softwares\Dev Tools\SDK\google_appengine\google\appengine\api\apiproxy_stub_map.py", line 604, in get_result
    return self.__get_result_hook(self)
  File "M:\Softwares\Dev Tools\SDK\google_appengine\google\appengine\datastore\datastore_query.py", line 2558, in __query_result_hook
    self.__results = self._process_results(query_result.result_list())
  File "M:\Softwares\Dev Tools\SDK\google_appengine\google\appengine\datastore\datastore_query.py", line 2591, in _process_results
    for result in results]
  File "M:\Softwares\Dev Tools\SDK\google_appengine\google\appengine\datastore\datastore_rpc.py", line 156, in pb_to_query_result
    return self.pb_to_entity(pb)
  File "M:\Softwares\Dev Tools\SDK\google_appengine\google\appengine\api\datastore.py", line 347, in pb_to_entity
    return Entity._FromPb(pb)
  File "M:\Softwares\Dev Tools\SDK\google_appengine\google\appengine\api\datastore.py", line 1126, in _FromPb
    (prop.name(), traceback.format_exc()))
Error: Property IdString is corrupt in the datastore:
Traceback (most recent call last):
  File "M:\Softwares\Dev Tools\SDK\google_appengine\google\appengine\api\datastore.py", line 1122, in _FromPb
    value = datastore_types.FromPropertyPb(prop)
  File "M:\Softwares\Dev Tools\SDK\google_appengine\google\appengine\api\datastore_types.py", line 1847, in FromPropertyPb
    value = unicode(value, 'utf-8')
UnicodeDecodeError: 'utf8' codec can't decode byte 0xcc in position 14: invalid continuation byte

我不明白为什么以及如何打破数据存储区。 我正在和Go一起学习GAE,这次活动真的吓到了我......

2 个答案:

答案 0 :(得分:2)

第一个追溯会告诉你你到底做错了什么。您已通过--clear_datastore GoogleAppEngine,但期待--clear_datastore=yes GoogleAppEngine(或“否”)。

正确的语法是documented

答案 1 :(得分:0)

对于Java用户解决方案是: 删除local_db.bin文件