- android - 多次调用 OnPrimaryClipChangedListener
- android - 无法更新 RecyclerView 中的 TextView 字段
- android.database.CursorIndexOutOfBoundsException : Index 0 requested, 光标大小为 0
- android - 使用 AppCompat 时,我们是否需要明确指定其 UI 组件(Spinner、EditText)颜色
我有一个非常简单的 Lambda 函数,我使用运行 ECS 任务的 IOT 按钮来调用它,这是非常轻量级的东西。我一直对添加跟踪很感兴趣,发现从 Lambda 获得的“一键式”跟踪并不能提供开箱即用的功能。
我一直在阅读一些关于 Decorators 的帖子和 SDK Github以及 AWS 文档 Python tracing for Lambda并认为这应该很容易。
我的函数的开头如下
import boto3
from aws_xray_sdk.core import xray_recorder
@xray_recorder.capture("handler")
def handler(event,context):
client = boto3.client('ecs')
response = client.run_task(
---python code---
return str(response)
现在的测试给我一个这样的错误:
Response:
{
"errorMessage": "Unable to import module 'lambda_function'"
}
Request ID:
"REQID...e3f379f4702a"
Function Logs:
START RequestId: REQID...e3f379f4702a Version: $LATEST
Unable to import module 'lambda_function': No module named 'aws_xray_sdk'
控制台中的我的处理程序只是lambda_function.handler
,并在添加该检测之前工作。我尝试在代码中使用 Subsegments
代替其他一些品种,但遇到了同样的问题。对于 Python,我还是个新手,所以我不确定下一步该检查哪里,或者我是否正确地执行了此操作。
如果适用的话,我已经在控制台中编写了代码,并且也不使用 Layers 或 ZIP 打包
最佳答案
弄清楚我做错了什么(一些事情),但幸运的是,对于我的自尊来说,命名约定并不是错误的事情。
aws-xray-sdk 是一个外部依赖项,需要内置而不是在控制台中执行,我还进行了几次打包并看到了 module missing
Queue
的错误包含在 multiprocessing
中Python 3.x 的库。
在 Cloud9 IDE 中,我执行了以下步骤
mkdir package && cd package
pip install multiprocessing --system -t ./
pip3 install boto3 --system -t ./
pip install aws-xray-sdk --system -t ./
chmod -R 755 .
zip -r ../myDeploymentPackage.zip .
cd -
aws s3 cp myDeploymentPackage.zip s3://<my-bucket>/<my-path>/
在 Lambda 控制台中,我指定了上传的 Zip 文件的当前版本的 URL,在控制台中启用了 X 射线跟踪,并且它工作得很好。我还必须稍微修改一下 Python 代码的编写方式,以利用修补 boto3
以及自动检测,因为该功能非常简单,并且使用 Boto 对不同的服务进行一到两次调用,所以它现在看起来像这样:
import boto3
from aws_xray_sdk.core import xray_recorder
from aws_xray_sdk.core import patch
patch(['boto3'])
@xray_recorder.capture("handler")
def handler(event,context):
client = boto3.client('<service here>')
关于python - 使用 X-Ray 检测 Python 3.6 Lambda 函数会导致错误,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/56872793/
有没有办法停止ray.tune实验(例如使用 PBT)当明显过度拟合或一个指标长时间没有改善时? 最佳答案 现在,这在 Tune 中得到了很好的支持,https://github.com/ray-pr
在 SimpleCorridor 之后我可以创建自己的环境并训练模型!好的。但是当我尝试评估这个经过训练的模型时,rllib 无法识别我的自定义环境。 如何在自定义环境中评估经过训练的模型? 当我像建
我正在运行 Ray Serve 来托管 ray 远程函数的 HTTP API。有没有比下面更好的方法在前台运行 Ray Serve(即非守护进程模式)。代码直接取自射线服务示例: import os
下面的代码完成了所需的行为。是否可以从前两个函数传递第二个参数而不必过早地调用 ray.get? @ray.remote def color(): image=cv2.imread("fram
我目前正在尝试理解由 Kevin Beason (smallpt: http://www.kevinbeason.com/smallpt/) 开发的光线追踪器,如果我正确理解代码,他会随机选择反射或折
当我在 Node 上运行 app.js 时,我在命令行中收到此错误: FATAL ERROR: v8::HandleScope::CreateHandle() Cannot create a hand
我想知道 - 是否有一种直接的方法可以在退出之前等待所有任务完成运行而不跟踪所有 ObjectID(和 get()ing他们)?用例是当我启动 @remote 以保存输出时,例如,在不需要返回结果的情
所以我只是跑了一个 tune实验并得到以下输出: +--------------------+------------+-------+-------------+----------------+-
我可以访问节点集群,我的理解是,一旦我在具有相同 Redis 地址的每个节点上启动 ray,头节点就可以访问所有节点的所有资源。 主要脚本: export LC_ALL=en_US.utf-8 exp
我正在寻找一个好的光线八叉树相交算法,它以迭代的方式为我提供光线穿过的叶子。我计划在 CPU 上实现它,因为我还不想深入研究 CUDA :) 目前,我的 Voxel raycaster 仅在 XxYx
来自 RISE 实验室的射线库 (https://rise.cs.berkeley.edu/blog/pandas-on-ray/) 我正在使用 64 位 Windows 10 专业版并从 Anaco
0. ray 简介 ray是开源分布式计算框架,为并行处理提供计算层,用于扩展AI与Python应用程序,是ML工作负载统一工具包 Ray AI Runtime
我有一个看起来更复杂的脚本: import ray var1 = 0 var2 = 0 @ray.remote def create(n): global var1 global va
我正在编写一个项目,该项目多次使用相同的数据进行写入,并且我一直在使用 ray 在集群设置中对其进行扩展,但是文件太大而无法来回发送/保存射线对象一直存储。有没有办法在远程函数调用之间将 python
我用 ray 创建了一个简单的远程函数,它占用的内存很少。但是,运行一小段时间后,内存稳步增加,并且出现 RayOutOfMemoryError 异常。 下面的代码是这个问题的一个非常简单的例子。 “
要检测一个点是否在多边形中,您可以从该点到无穷远投影一条线,然后查看它与多少个多边形顶点相交......足够简单。我的问题是,如果射线在其中一个点上与多边形相交,则将其视为与两个线段相交,并被视为在多
我有一个相当大的 Python 程序(~800 行),它具有以下结构: 设置说明,我在其中处理用户提供的输入文件并定义对程序执行具有全局性的变量/对象。 Main 函数,它利用前面的设置阶段并调用程序
正如您在图像中看到的那样,我在球体顶部看到了一个黑色圆圈,并且图像看起来有颗粒感。它应该更清晰,但是有这些小的黑白点。 这是阴影射线的代码 int pos = 0; float intersect(c
我有一个相当大的 Python 程序(~800 行),它具有以下结构: 设置说明,我在其中处理用户提供的输入文件并定义对程序执行具有全局性的变量/对象。 Main 函数,它利用前面的设置阶段并调用程序
我正在尝试实现一个“光线选择器”以在我的项目中选择对象。我不完全理解如何实现这一点,但我从概念上理解它应该如何工作。我一直在努力学习如何做到这一点,但我发现大多数教程都让我难以理解。我当前的代码基于我
我是一名优秀的程序员,十分优秀!