我正在使用web.py和GAE(Windows 7,Python27)运行一些基本的测试代码。该表单允许将消息发布到数据存储区。当我停止应用并再次运行时,之前发布的任何数据都已消失。使用admin(http:// localhost:8080 / _ah / admin / datastore)手动添加实体也存在同样的问题。
我尝试使用额外标志在应用程序设置中设置路径:
--datastore_path=D:/path/to/app/
(不确定那里的语法)。它没有效果。我搜索了我的计算机上的* .datastore,并且找不到任何文件,这看起来很可疑,尽管数据显然存储在应用程序运行期间的某个地方。
from google.appengine.ext import db
import web
urls = (
'/', 'index',
'/note', 'note',
'/crash', 'crash'
)
render = web.template.render('templates/')
class Note(db.Model):
content = db.StringProperty(multiline=True)
date = db.DateTimeProperty(auto_now_add=True)
class index:
def GET(self):
notes = db.GqlQuery("SELECT * FROM Note ORDER BY date DESC LIMIT 10")
return render.index(notes)
class note:
def POST(self):
i = web.input('content')
note = Note()
note.content = i.content
note.put()
return web.seeother('/')
class crash:
def GET(self):
import logging
logging.error('test')
crash
app = web.application(urls, globals())
def main():
app.cgirun()
if __name__ == '__main__':
main()
更新: 当我通过命令行运行它时,我得到以下内容:
WARNING 2012-04-06 19:07:31,266 rdbms_mysqldb.py:74] The rdbms API is not available because the MySQLdb library could not be loaded.
INFO 2012-04-06 19:07:31,778 appengine_rpc.py:160] Server: appengine.google.com
WARNING 2012-04-06 19:07:31,783 datastore_file_stub.py:513] Could not read datastore data from c:\users\amy\appdata\local\temp\dev_appserver.datastore
WARNING 2012-04-06 19:07:31,851 dev_appserver.py:3394] Could not initialize images API; you are likely missing the Python "PIL" module. ImportError: No module named _imaging
INFO 2012-04-06 19:07:32,052 dev_appserver_multiprocess.py:647] Running application dev~palimpsest01 on port 8080: http://localhost:8080
INFO 2012-04-06 19:07:32,052 dev_appserver_multiprocess.py:649] Admin console is available at: http://localhost:8080/_ah/admin
建议数据存储...没有正确安装?
答案 0 :(得分:7)
从1.6.4开始,我们在每次写入后都停止保存数据存储区。在模拟高复制数据存储区中找到的事务模型时,此方法不起作用(您将丢失最后几次写入)。它也非常低效。我们对其进行了更改,以便数据存储区dev存储库刷新所有写入并在关闭时保存其状态。听起来dev_appserver没有正确关闭。你应该看到:
关闭服务器时日志中的应用所有待处理事务并保存数据存储
(请参阅source code和source code)。如果不这样做,则意味着dev_appserver没有被干净地关闭(使用TERM信号或KeyInterrupt)。