[译] 如何将 Stackdriver 连接到智能家居服务器以进行错误记录
创始人
2025-01-18 18:02:55
0

这个错误可能源于账号连接和 SYNC 同步过程的许多原因。

为了更好地了解这些错误,你可以使用 Stackdriver,Google Cloud 的日志系统。当账户连接或随后的 SYNC 事件发生错误时,它会自动记录错误并向你提供信息。

外链图片转存失败,源站可能有防盗链机制,建议将图片保存下来直接上传

可能来自堆栈驱动程序的错误报告消息的屏幕截图

你收到的日志会自动清除并移除任何个人可识别信息(PII),而且不会包含详细的追踪。

启动时,你可以导航到项目的 Google Cloud 控制台,在抽屉导航的 Stackdriver 部分中选择 Logging 选项:

外链图片转存失败,源站可能有防盗链机制,建议将图片保存下来直接上传

你可以通过 Google Assistant Action > All version_id 来查看专门为你的智能家居实现而出现的错误:

外链图片转存失败,源站可能有防盗链机制,建议将图片保存下来直接上传

尽管很方便,但必须转到单独的页面去查看错误可能不适合你的开发流,而且它可能不会为你提供易于访问的数据,例如,包含在每周统计报表中的数据。让我们看看如何将你的日志从 Stackdriver 导出到你的基础设施中,让你在这些数据之上构建额外的集成。

使用 Stackdriver,你可以设置包含带有特定过滤器的日志接收装置。这个接收装置中的日志可以通过 Cloud 发布/订阅发送到你拥有的端点。

域名验证

在将消息推送到端点之前,你需要验证你自己的域名。你可以通过 Google Cloud 控制台的 APIs & Services 部分进行注册。

外链图片转存失败,源站可能有防盗链机制,建议将图片保存下来直接上传

Credentials > Domain Verification 下,添加一个域名。在添加完你自己的域名之后,你将被带到 Google 搜索控制。在继续操作之前,按照说明完成对你完整的验证:

外链图片转存失败,源站可能有防盗链机制,建议将图片保存下来直接上传

配置发布/订阅

使用Google Cloud 发布/订阅,你可以静任务配置为在某些事件上运行,例如,当新日志出现在 Stackdriver 中时,通过添加过滤器你可以限制触发事件的日志类型。你也可以配置服务器端点来订阅这些事件。

要开始导出 SYNC 错误,请输入过滤器 “text:SYNC”,点击 CREATE EXPORT 按钮。在这里,你可以创建一个连接到 Google Cloud 发布/订阅的主题接收器。这将是你能够在每次出现日志条目时处理事件:

外链图片转存失败,源站可能有防盗链机制,建议将图片保存下来直接上传

在抽屉导航中,打开发布/订阅概述,创建一个新的订阅:

外链图片转存失败,源站可能有防盗链机制,建议将图片保存下来直接上传

这里,你可以新建一个订阅。对于交付类型,输入用于接收订阅的的 URL。为了进行验证域名验证,你必须拥有自己的服务器:

外链图片转存失败,源站可能有防盗链机制,建议将图片保存下来直接上传

在你的服务器上,为了接受端点,你需要添加一个处理器。在这个示例中,它是 /alerts/stackdriver。这是你服务器上的一个钩子。Cloud 发布/订阅会向 URL 发送一个在请求体重包含日志数据的 POST 请求。下面的代码片段显示了使用 Node.js 的实现:

app.post(‘/alerts/stackdriver’, (req, res) => {
console.log(‘post stackdriver called’, req.body);
res.status(204).send(‘success’);
if (!!req.body.message && !!req.body.message.data) {
const data = Buffer.from(req.body.message.data, ‘base64’)
.toString(‘utf8’);
console.log('data: ', data);
// optionally use regexp here to find request id and failure reason
}
});

我们现在可以测试这个发布/订阅主题是否有效。在你的智能家居集成中,设置你的 SYNC 回复返回一个无效的设备类型,例如 LART。以下代码片段是这个响应示例:

const app = smarthome();
app.onSync(body => {
return {
requestId: body.requestId,
payload: {
agentUserId: ‘123’,
devices: [{
type: ‘action.devices.types.LART’
// More metadata
}]
}
}
})

当你尝试连接你的账户时,你会在 Google Assistant 设置中看到一个错误,然后在 StackDriver 中看到与之对应的错误:

外链图片转存失败,源站可能有防盗链机制,建议将图片保存下来直接上传

总结

现在新技术层出不穷,如果每次出新的技术,我们都深入的研究的话,很容易分散精力。新的技术可能很久之后我们才会在工作中用得上,当学的新技术无法学以致用,很容易被我们遗忘,到最后真的需要使用的时候,又要从头来过(虽然上手会更快)。

我觉得身为技术人,针对新技术应该是持拥抱态度的,入了这一行你就应该知道这是一个活到老学到老的行业,所以面对新技术,不要抵触,拥抱变化就好了。

Flutter 明显是一种全新的技术,而对于这个新技术在发布之初,花一个月的时间学习它,成本确实过高。但是周末花一天时间体验一下它的开发流程,了解一下它的优缺点、能干什么或者不能干什么。这个时间,并不是我们不能接受的。

如果有时间,其实通读一遍 Flutter 的文档,是最全面的一次对 Flutter 的了解过程。但是如果我们只有 8 小时的时间,我希望能关注一些最值得关注的点。

(跨平台开发(Flutter)、java基础与原理,自定义view、NDK、架构设计、性能优化、完整商业项目开发等)


《Android学习笔记总结+移动架构视频+大厂面试真题+项目实战源码》点击传送门,即可获取!
5)]
《Android学习笔记总结+移动架构视频+大厂面试真题+项目实战源码》点击传送门,即可获取!

相关内容

热门资讯

微扑克系统发牌规律!微扑克有规... 微扑克系统发牌规律!微扑克有规律,微扑克一般真的有挂,软件教程(有挂普及);1、金币登录送、破产送、...
aapoker辅助!AA PO... aapoker辅助!AA POKER下载软件,AAPoker果然真的有挂,力荐教程(有挂脚本)1、a...
wepoke计算辅助!wepo... wepoke计算辅助!wepok软件透明挂,wepoke的确真的有挂,wpk教程(有挂脚本)1、玩家...
wpk有外挂!wpk德州辅助,... wpk有外挂!wpk德州辅助,WPK其实真的有挂(详细透视辅助挂教程)1、wpk有外挂系统规律教程、...
微扑克ai辅助!微扑克有挂,微... 微扑克ai辅助!微扑克有挂,微扑克就是真的有挂,2025教程(有挂技巧);进入游戏-大厅左侧-新手福...
aapoker辅助工具!aap... aapoker辅助工具!aapoker软件,AAPoKER好像真的有挂,介绍教程(有挂教程)进入游戏...
wepoke辅助插件!wepo... wepoke辅助插件!wepoke软件俱乐部,WepOke一般真的有挂,曝光教程(有挂工具)1、进入...
wpk ai辅助!wpk辅助软... wpk ai辅助!wpk辅助软件,wPk一直真的有挂(详细透视辅助插件教程)1、不需要AI权限,帮助...
微扑克德州专用辅助器!微扑克辅... 微扑克德州专用辅助器!微扑克辅助软件下载,微扑克的确是有挂的,wpk教程(有挂揭秘)1、这是跨平台的...
aapoker外挂!aa扑克平... aapoker外挂!aa扑克平台,AaPOKER确实真的有挂,线上教程(有挂普及)1、AaPOKER...