我们有一个连接到GCSQL的Google应用引擎应用,我们在尝试连接数据库时遇到了很多DeadlineExceededError问题。 错误似乎是由大量用户在短时间内打开应用程序产生的。 当我们在此期间查看仪表板上的开口连接时,同时打开的连接不超过45个 它在很大比例的查询(阅读,写作和连接)上失败了,花了太多时间去做。 由于花费的时间,服务关闭,我们收到错误。
错误示例:
Traceback (most recent call last):
File "/python27_runtime/python27_lib/versions/1/google/appengine/runtime/wsgi.py", line 223, in Handle
result = handler(dict(self._environ), self._StartResponse)
File "/python27_runtime/python27_lib/versions/third_party/webapp2-2.3/webapp2.py", line 1505, in __call__
rv = self.router.dispatch(request, response)
File "/python27_runtime/python27_lib/versions/third_party/webapp2-2.3/webapp2.py", line 1253, in default_dispatcher
return route.handler_adapter(request, response)
File "/python27_runtime/python27_lib/versions/third_party/webapp2-2.3/webapp2.py", line 1077, in __call__
return handler.dispatch()
File "/python27_runtime/python27_lib/versions/third_party/webapp2-2.3/webapp2.py", line 545, in dispatch
return method(*args, **kwargs)
File "/base/data/home/apps/s~ono-hat-prod/1.365115032772094991/onohatpreprod.py", line 5541, in post
cursor.execute("SELECT %s FROM actuaciones WHERE numero = '%s' " % (rc,idHat))
File "/python27_runtime/python27_lib/versions/1/google/storage/speckle/python/api/rdbms.py", line 499, in execute
self._DoExec(request)
File "/python27_runtime/python27_lib/versions/1/google/storage/speckle/python/api/rdbms.py", line 375, in _DoExec
response = self._conn.MakeRequest('Exec', request)
File "/python27_runtime/python27_lib/versions/1/google/storage/speckle/python/api/rdbms.py", line 873, in MakeRequest
response = self._MakeRetriableRequest(stub_method, request)
File "/python27_runtime/python27_lib/versions/1/google/storage/speckle/python/api/rdbms.py", line 897, in _MakeRetriableRequest
response = self.MakeRequestImpl(stub_method, request)
File "/python27_runtime/python27_lib/versions/1/google/storage/speckle/python/api/rdbms_apiproxy.py", line 67, in MakeRequestImpl
except apiproxy_errors.ApplicationError, e:
DeadlineExceededError
发生错误之前的一段代码:
class detalleActuacion(webapp2.RequestHandler):
def post(self):
idHat = self.request.get('id')
logging.info(idHat)
num_conexiones = 0
num_cierres = 0
conn = rdbms.connect(instance=_INSTANCE_NAME, database='Actuaciones')
num_conexiones = num_conexiones + 1
cursor = conn.cursor()
dict_act = {}
request_cad = 'solucionado,duracion,numero,fecha_inicio_ventana,fecha_fin_ventana,'
request_cad = request_cad+'tipo,titulo,tipo_cliente,ubicacion,zona_regional,'
request_cad = request_cad+'zona_local,ciudad_ticket,zona_regional_subticket,zona_local_subticket,'
request_cad = request_cad+'zona_local_ticket,skill,num_recursos,num_actuaciones,ubi_emplaz,'
request_cad = request_cad+'ubi_provincia,ubi_lat,ubi_long,ubi_via,ubi_calle,ubi_numero,ubi_adic,'
request_cad = request_cad+'ubi_CP,miga_terminal,miga_tlf,miga_dir,severidad,prioridad,serv_CATV,'
request_cad = request_cad+'serv_datos,serv_DTV,serv_empresa,serv_telefonia,instr,num_rep,'
rc = request_cad+'fecha_creac,fecha_creac_tp,fecha_sol,fecha_sol_tp,fecha_cierre,fecha_cierre_tp,'
rc = rc+'fecha_inicio,fecha_fin,descr_adic,descr_log,grupo_pos,accion,cola,estado,estado_ticket,'
rc=rc+'doc_adj,detalle_equipos,tarea,subtarea,subzona,TIR,elem_red,descripcion,num_afectados,'
rc=rc+'repeticion,fecha_repeticion,dias_repeticion,dias_semana,fin_repeticion,cl_afectados,'
rc=rc+'plan_tp,marca_seguimiento,tipificacion,miga,zona,bandeja,alerta,descr_log1,descr_log2,descr_log3,descr_log4,descr_log5,descr_log6,descr_log7,descr_log8,descr_log9,'
rc=rc+'elem_red_2,estado_CRM,tecnico,tecnico2,tecnico3,tecnico4,tecnico5,num_asignaciones,ultima_modificacion,tiempo_proceso,fecha_inicio_real,fecha_fin_real'
rc=rc+',observaciones1,observaciones2,observaciones3,observaciones4,observaciones5,observaciones6,observaciones7,observaciones8,observaciones9,observaciones10'
cursor = conn.cursor()
cursor.execute("SELECT %s FROM actuaciones WHERE numero = '%s' " % (rc,idHat))
提前感谢您的协助。
答案 0 :(得分:0)
如果有45个并发请求,则可能会有更多打开的连接。 见What are the connection limits for Google Cloud SQL from App Engine, and how to best reuse DB connections?
您还可以尝试增加实例大小:更多RAM可能会减少每个请求的延迟,从而减少连接数。