您获得OperationalError:数据库被锁定的原因是2个dev_appserver.py实例将碰撞尝试访问相同的数据库本地存储目录,默认情况下是根据应用程序的名称确定的 – 相同的2个服务的相同的应用.
避免此类冲突的一种方法是使用dev_appserver.py的–storage_path可选参数(可以通过dev_appserver.py –help查看)指定本地存储目录:
--storage_path PATH path to the data (datastore, blobstore, etc.)
associated with the application. (default: None)
但是,使用2个不同的存储路径可能会产生意外结果 – 如果您的服务引用该存储中应该是相同信息的内容,则可能会看到不同的值.
将dev_appserver.py与同一应用程序的多个服务一起使用的正确方法是通过单个dev_appserver.py实例运行所有服务,该实例将为每个服务分配不同的端口.
例如,我有一个包含3个服务并使用调度文件的应用程序.这是我如何调用开发服务器,从应用程序目录这是3个服务迪尔斯的父目录(调度文件必须是一日一中.yaml文件args来名单,我总是用默认模块的一个遵循它,在我的情况下main / main.yaml):
/usr/bin/python2.7 /usr/local/google_appengine/dev_appserver.py --host 0.0.0.0 --log_level=debug dispatch.yaml main/main.yaml buildin/buildin.yaml apartci/apartci.yaml
这就是devserver如何自动分配每个服务侦听的端口,在服务器启动时显示:
INFO 2016-11-18 14:20:53,329 api_server.py:205] Starting API server at: http://localhost:40310
INFO 2016-11-18 14:20:53,330 dispatcher.py:185] Starting dispatcher running at: http://0.0.0.0:8080
INFO 2016-11-18 14:20:53,345 dispatcher.py:197] Starting module "default" running at: http://0.0.0.0:8081
INFO 2016-11-18 14:20:53,353 dispatcher.py:197] Starting module "buildin" running at: http://0.0.0.0:8082
INFO 2016-11-18 14:20:53,361 dispatcher.py:197] Starting module "apartci" running at: http://0.0.0.0:8083
INFO 2016-11-18 14:20:53,362 admin_server.py:116] Starting admin server at: http://localhost:8000