我在javascript和web开发方面缺乏经验.我正在进行的项目是一般公司培训计划的一部分.我们已被指示使用Google Chrome作为主要测试浏览器.
本质上,我正在编写一个将在公司内部网外部的客户端上运行的应用程序.Connections将通过我们的单点登录服务器传递给内部服务.单点登录服务对服务器端应用程序基本上是透明的 - 它拦截对内部服务的请求,并在必要时提示输入凭据.据我所知,它会在发送的每个请求中更改会话cookie.
我已经使用HTTP GET和POST连接建立了与服务的连接.但是,有一项服务需要HTTP PUT请求.这就是麻烦的来源.
运行脚本时,Chrome javascript控制台会出现以下错误:
Uncaught NetworkError: A network error occurred.
Run Code Online (Sandbox Code Playgroud)
错误太模糊了.当我查看Chrome开发人员标签中的"网络"标签时,它会显示请求,但它没有任何响应数据.
为了好奇,我右键单击了请求并将其复制为cURL请求.我通过-b标志将会话cookie附加到请求中.cURL返回HTTP 302,并在服务器上引用make cookie脚本.作为PUT请求,没有任何重定向导致请求失败?但我不肯定这是Chrome/js中发生的事情.
有没有办法可以获得有关错误的更多信息?
我对开发内部服务供我们使用的团队没有100%的信心,因此使用PUT请求确实是不可能的......服务仍在开发中.
需要明确的是,如果可能的话,整体问题是我需要这个PUT请求通过我们的SSO应用程序.
我已经构建了一个 Kafka Streams 应用程序。这是我的第一个,所以我正在从概念验证的思维方式转变为“我如何将其产品化?” 心态。
tl;dr 版本:我正在寻找 kafka 流部署建议和技巧,特别是与更新您的应用程序代码相关的。
我已经能够找到很多关于 Kafka 和 Streams API 如何工作的文档,但我找不到关于实际部署 Streams 应用程序的任何内容。
初始部署似乎相当简单 - 有用于配置 Kafka 集群的良好文档,然后您必须为您的应用程序创建主题,然后您就可以启动它并发布数据以供处理。
但是如果您想稍后升级您的应用程序怎么办?具体来说,如果更新包含对拓扑的更改。我的应用程序在窗口中进行了大量的数据丰富和聚合,因此将来可能需要调整处理。
我的理解是,改变处理顺序或在拓扑中插入额外的步骤会导致每个处理步骤的内部 ID 发生变化,这意味着最多会创建新的状态存储,而先前的状态将丢失,最坏的情况是处理步骤启动时从不正确的状态存储主题中读取。这意味着您要么必须重置应用程序,要么为新版本提供新的应用程序 ID。但是这样做有一些问题:
我能想到的缓解这种情况的唯一方法是:
现在这“没问题”,因为我的应用程序是唯一一个从源主题读取的内容,并且除了提供给同一应用程序中的下一个处理器之外,当前不使用中间主题。但是,我可以看到这变得非常混乱。
有没有更好的方法来处理应用程序更新?或者我的步骤通常与大多数开发人员所做的一样吗?