- html - 出于某种原因,IE8 对我的 Sass 文件中继承的 html5 CSS 不友好?
- JMeter 在响应断言中使用 span 标签的问题
- html - 在 :hover and :active? 上具有不同效果的 CSS 动画
- html - 相对于居中的 html 内容固定的 CSS 重复背景?
我有一个 AWS API 网关,它代理多个 AWS Lambda 函数。这些函数从 PostgreSQL 数据库 (AWS Aurora PostgreSQL) 读取和写入。我已经使用 Entity Framework Core Database First 连接了数据访问。我有一个问题,在几分钟后我第一次调用我的 API 并执行 Lambda 函数时,通过 EF Core 对数据库的第一次查询最多需要 29 秒(!)。下一个只在 1 秒后执行,只需要 200 毫秒。
我知道你在想什么,这是 Lambda 冷启动。好吧,我已经排除了这一点,因为如果我取出任何 EF Core 代码,并让我的函数返回一个虚拟响应,时间会下降到大约 4 秒响应,然后如果我再次调用 200 毫秒之后。
如果我检查我的函数的日志,我还可以看到延迟发生在执行第一个 EF Core 查询时,在此之前的其他事件发生得非常快。请参阅下面的摘录。
“找到测试客户”是从查询中第一次从数据库返回数据。请参阅下面的摘录:
using (var loyalty = new loyaltyContext())
{
var testArray = new string[]
{Customer.CustomerStateReasonCodes.Deceased,
Customer.CustomerStateReasonCodes.Fraud};
var dupeEmailCustomers = (from c in loyalty.ContactInformation
where c.ContactType == "EMAIL"
join cu in loyalty.Customer on c.CustomerInternalId equals cu.CustomerInternalId
where cu.Status == Customer.CustomerStates.Active
select c).AsNoTracking()
.Union(from c in loyalty.ContactInformation
where c.ContactType == "EMAIL"
join cu in loyalty.Customer on c.CustomerInternalId equals cu.CustomerInternalId
where cu.Status != Customer.CustomerStates.Active &&
testArray.Contains(cu.StatusReason)
select c).AsNoTracking();
foreach (var cust in dupeEmailCustomers)
{
context.Logger.LogLine($"Found test customer {JsonConvert.SerializeObject(cust)}");
}
}
public APIGatewayProxyResponse PostCustomerProxyResponse(APIGatewayProxyRequest request, ILambdaContext context)
public Functions()
{
_jSchema = new JSchemaGenerator().Generate(typeof(CustomerPayload));
_systemsManagementClient = new AmazonSimpleSystemsManagementClient(RegionEndpoint.APSoutheast2);
SecurityKey = PopulateParameter(ParameterPath + Integration + JWT + "/secret", true);
Issuer = PopulateParameter(ParameterPath + Integration + JWT + "/issuer", false);
ClaimName = PopulateParameter(ParameterPath + Integration + JWT + "/claim", false);
ScpiUser = PopulateParameter(ParameterPath + Integration + SCPI + "/user", false);
ScpiPassword = PopulateParameter(ParameterPath + Integration + SCPI + "/password", true);
//DbUser = PopulateParameter(ParameterPath + ParameterPathDatabase + "/iamuser", false);
}
最佳答案
请试试这个...
var dupeEmailCustomers = ( from c in loyalty.ContactInformation
join cu in loyalty.Customer on c.CustomerInternalId equals cu.CustomerInternalId
where cu.Status == Customer.CustomerStates.Active
&& c.ContactType == "EMAIL"
select c
).AsNoTracking()
.Union(
from c in loyalty.ContactInformation
join cu in loyalty.Customer on c.CustomerInternalId equals cu.CustomerInternalId
where c.ContactType == "EMAIL"
&& cu.Status != Customer.CustomerStates.Active
&& testArray.Contains(cu.StatusReason)
select c
).AsNoTracking();
from c in loyalty.ContactInformation
join cu in loyalty.Customer on c.CustomerInternalId equals cu.CustomerInternalId
where cu.Status == Customer.CustomerStates.Active
&& c.ContactType == "EMAIL"
select c
from c in loyalty.ContactInformation
join cu in loyalty.Customer on c.CustomerInternalId equals cu.CustomerInternalId
where c.ContactType == "EMAIL"
&& cu.Status != Customer.CustomerStates.Active
&& testArray.Contains(cu.StatusReason)
select c
关于c# - Entity Framework Core 3.1.3 在 AWS Lambda 函数和 AWS API Gateway 无服务器 API 中使用的第一个查询非常慢,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/62336039/
可以使用 lambda 和函数创建有序对(Lisp 中的缺点),如 Use of lambda for cons/car/cdr definition in SICP 所示。 它也适用于 Python
我正在尝试从另一个调用一个 AWS lambda 并执行 lambda 链接。这样做的理由是 AWS 不提供来自同一个 S3 存储桶的多个触发器。 我创建了一个带有 s3 触发器的 lambda。第一
根据以下源代码,常规 lambda 似乎可以与扩展 lambda 互换。 fun main(args: Array) { val numbers = listOf(1, 2, 3) f
A Tutorial Introduction to the Lambda Calculus 本文介绍乘法函数 The multiplication of two numbers x and y ca
我想弄清楚如何为下面的表达式绘制语法树。首先,这究竟是如何表现的?看样子是以1和2为参数,如果n是 0,它只会返回 m . 另外,有人可以指出解析树的开始,还是一个例子?我一直找不到一个。 最佳答案
在 C++0x 中,我想知道 lambda 函数的类型是什么。具体来说: #include type1 foo(int x){ return [x](int y)->int{return x * y
我在其中一个职位发布中看到了这个问题,它询问什么是 lambda 函数以及它与高阶函数的关系。我已经知道如何使用 lambda 函数,但不太自信地解释它,所以我做了一点谷歌搜索,发现了这个:What
很难说出这里问的是什么。这个问题是含糊的、模糊的、不完整的、过于宽泛的或修辞性的,无法以目前的形式得到合理的回答。如需帮助澄清此问题以便重新打开它,visit the help center 。 已关
Evaluate (((lambda(x y) (lambda (x) (* x y))) 5 6) 10) in Scheme. 我不知道实际上该怎么做! ((lambda (x y) (+ x x
我正在处理 MyCustomType 的实例集合如下: fun runAll(vararg commands: MyCustomType){ commands.forEach { it.myM
Brian 在他对问题 "Are side effects a good thing?" 的论证中的前提很有趣: computers are von-Neumann machines that are
在 Common Lisp 中,如果我希望两个函数共享状态,我将按如下方式执行 let over lambda: (let ((state 1)) (defun inc-state () (in
Evaluate (((lambda(x y) (lambda (x) (* x y))) 5 6) 10) in Scheme. 我不知道实际上该怎么做! ((lambda (x y) (+ x x
作为lambda calculus wiki说: There are several possible ways to define the natural numbers in lambda cal
我有一个数据类,我需要初始化一些 List .我需要获取 JsonArray 的值(我使用的是 Gson)。 我做了这个函数: private fun arrayToList(data: JsonAr
((lambda () )) 的方案中是否有简写 例如,代替 ((lambda () (define x 1) (display x))) 我希望能够做类似的事情 (empty-lam
我在 Java library 中有以下方法: public void setColumnComparator(final int columnIndex, final Comparator colu
我正在研究一个函数来计算国际象棋游戏中棋子的有效移动。 white-pawn-move 函数有效。当我试图将其概括为任一玩家的棋子 (pawn-move) 时,我遇到了非法函数调用。我已经在 repl
考虑这段代码(在 GCC 和 MSVC 上编译): int main() { auto foo = [](auto p){ typedef decltype(p) p_t;
我正在阅读一个在 lambda 内部使用 lambda 的片段,然后我想通过创建一个虚拟函数来测试它,该函数从文件中读取然后返回最大和最小数字。 这是我想出来的 dummy = lambda path
我是一名优秀的程序员,十分优秀!