- html - 出于某种原因,IE8 对我的 Sass 文件中继承的 html5 CSS 不友好?
- JMeter 在响应断言中使用 span 标签的问题
- html - 在 :hover and :active? 上具有不同效果的 CSS 动画
- html - 相对于居中的 html 内容固定的 CSS 重复背景?
我需要已部署使用Sql Server Service Broker外部激活机制(通过Feature Pack中的Service Broker外部激活器)的实际生产应用程序的任何人的一些指导。
当前的心态:
我的规范很简单(或者至少我这么认为),所以我在考虑以下基本流程:
将类似于
http://schemas.microsoft.com/SQL/ServiceBroker/EndDialog
(END DIALOG)):try{..}catch(Exception e){..} finally{ Environment.Exit(0) }
。这个假设正确吗? 最佳答案
问:所描述的体系结构是否存在重大设计缺陷?
答:几个小津贴:
-在等待打开事务的同时等待HTTP请求完成是不好的。无论如何,您都无法实现数据库和HTTP之间的事务一致性,因此,当HTTP速度较慢时,不要冒险进行数分钟的事务扩展。典型的模式是{开始tran/receive/begin conversation timer/commit}然后不带任何DB xact发出HTTP调用。如果HTTP调用成功,则{开始xact/发送响应/结束对话/提交}。如果HTTP失败(或客户端崩溃),请让对话时间再次激活您。您将收到一个计时器消息(无正文),您需要从表中获取与该句柄关联的项目ID。
问:订单完成状态跟踪似乎不正确。有更好的方法吗?也许使用队列保留?
答:我对状态跟踪的一种批评是依赖于扫描订单商品,以确定当前处理的商品是最后一个商品(5.3.4)。例如,您可以添加以下信息:这是在项目状态下要处理的“最后一个”项目,因此您知道在处理项目时需要报告完成情况。 RETENTION仅在调试中或当您具有需要运行“逻辑回滚”并补偿对话错误的操作的逻辑时才有用。
问:我的直觉告诉我,在任何情况下,被激活的外部exe都不会以0以外的退出代码终止,因此最终应该尝试使用{..} catch(Exception e){..} {Environment.Exit( 0)}在Main中。这个假设正确吗?
答:最重要的是激活的进程在队列上发出RECEIVE语句。如果失败,则队列监视器may enter the notified state forever。如果我没记错的话,退出代码是无关紧要的。与任何后台进程一样,捕获和记录异常非常重要,否则,当它开始失败时,您甚至都不会知道它有问题。除了受约束的try/catch块外,UI应用程序的联播 Application.ThreadException
和UI和非UI应用程序的 AppDomain.UnhandledException
。
问:您将如何组织DB代码中的错误处理?错误日志表足够了吗?
答:我会在后面跟进。错误日志表足够恕我直言。
问:如何组织外部exe C#代码中的错误处理?错误记录表相同吗?
答:我之所以创建bugcollect.com正是因为我必须使用自己的应用程序来处理此类问题。问题不仅仅在于日志记录,您还希望进行一些汇总和分析(至少检测重复的报告),并抑制一些“现场”部署配置事故带来的错误泛滥。说实话,如今有更多选择,例如。 exceptron.com。当然,我认为FogBugs还具有日志记录功能。
问:我已经看过SQL Server Service Broker产品样本,但是对于我看来更简单的情况,Service Broker界面似乎有些过分。对于更简单的Service Broker对象模型,还有其他选择吗?
最后,一个简单的问题:是的,这太过分了。没有简单的模型。
问:Service Broker的任何跨版本“便携式”管理工具是否能够至少排出有害消息?
答:带毒消息的问题是带毒消息的定义随您的代码the poison message is whatever message breaks the current guards set in place to detect it更改。
问:您是否有上述任何示例的代码示例?
答:不可以
还有一点:尝试避免从DB1到DB2的任何引用(例如,在DB1中激活了4.3.4并从DB2读取项目表)。这将创建跨数据库依赖关系,当a)一个DB处于脱机状态(例如,用于维护)或过载时,或者b)您添加了HA/DR的数据库镜像并且一个DB进行故障转移时,该依赖关系就会中断。即使DB1和DB2在不同的机器上(并且没有链接的服务器),也请尝试使代码正常工作。如有必要,将更多信息添加到消息有效负载中。而且,如果以这种方式进行构造,则DB2可以位于不同的机器上,甚至可以存在多个DB2机器来扩展HTTP/PDF编写工作。
最后:这种设计将非常缓慢。我说的是每秒很慢的低速消息,涉及许多对话框/消息,而max_queue_readers 1的所有内容。您可能会接受,也可能无法接受。
关于sql-server - SQL Server Service Broker-外部激活的控制台应用程序的详尽使用示例,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/13616014/
在为代理到 Zookeeper 身份验证实现 SSL 时,我在代理 2 节点上遇到了以下异常 从 SSL 设置中,集群配置了 SSL 身份验证 Broker 1 成功连接到 zookeeper,但在
我想读取 some_dir/activemq.xml 文件,以便可以使用 org.apache.activemq.broker.BrokerService 创建代理,该代理将具有所提供文件的所有配置。
我在 fi-lab 上创建了一个新的 Orion 实例,以便将它连接到我们管理的 CEP 实例。将存储在我的 Orion 实例上的数据必须由位于 orion.lab.fi-ware.eu:1026 的
我想使用IB Api,但无法弄清楚我们如何请求完整的符号列表和信息。 在我找到的文档中:reqScannerParameters()-但不清楚如何获取例如纳斯达克股票的 list ? 有没有更好的办法
我已经开始将 IB 与 IBridgePy 结合使用,我想知道是否有可能以某种方式执行任何回溯测试,有没有人如何做到这一点? 最佳答案 IB 没有现成的回测/重放工具。基本上,您必须下载历史数据并通过
我是Pact(消费者驱动的测试)的新手,并且使用gradle,我曾在这个著名的研讨会上尝试使用Java和Pact Brocker https://github.com/Mikuu/Pact-JVM-E
在我的IDE中,我能够利用一个spring-boot应用程序,该应用程序将生成消息(使用Kafkaproducer)给外部kafka代理。但是,一旦我将我的spring-boot应用程序托管在dock
我正在用 C# 移植 Java 应用程序,我需要构建嵌入式 ActiveMQ 实例。 在 Java 中,我可以使用 BrokerService 类,但我在 .Net 的 Apache.Nms 命名空间
我的本地计算机上有一个消息生成器,在远程主机 (aws) 上有一个代理。 生产者发送消息后,我等待并调用远程主机上的控制台消费者并查看过多的日志。没有来自生产者的值(value)。 生产者在调用s
我正在开发一个物联网项目,到目前为止一切顺利,我可以使用我在网络上找到的免费代理在客户端之间共享数据... 我的用例是关于温度传感器的,该传感器将消息发布并保留到主题房间/温度 由于消息被保留,cli
我读到的所有地方都说由服务代理处理的消息是按照它们到达的顺序处理的,但是如果你创建一个表、消息类型、契约(Contract)、服务等,并且在激活时有一个存储过程等待 2秒并将消息插入表中,将最大队列读
我有一个 SQL Server 2008 R2 实现,并为在同一个机器上运行的 .Net/IIS 网站打开了 Service Broker。 当 global.asax application_sta
在我的发布场景中,我们有多个部署者将内容推送到文件系统和数据库(代理)。页面和二进制文件放在文件系统上,其他所有内容都放在 Broker 中。我们有一位部署者将内容放入数据库。这是推荐的最佳做法吗?
我们将 MongoDB 用于我们的内部部署环境。 Orion 何时正式支持 AWS DocumentDB Orion 会在支持 DocumentDb 后放弃 MongoDB 还是在 future 同时
我已经在单台服务器上使Kafka(使用Docker镜像)工作,在同一台/一台Server X上安装了Zookeeper + Kafka Broker。 如果我需要在服务器Y上添加其他代理(以实现 fl
所以问题是,当我尝试与上下文代理建立连接时,我是否正在尝试更新实体或读取值。只有当我第二次询问时它才回复正常。 Context Broker 版本:0.24.0(我从 0.20.0 更新,因为我认为这
我在同一个实例上有两个数据库。 一个叫 ICMS,一个叫 CarePay_DEV1 当 ICMS (Source) 发生变化时,它需要向 CarePay_Dev1 (Destination) 发送消息
即使我指定 Receive Top(25) 等,我也一次只能收到一条消息出列。不确定我在 sproc 中做错了什么?可能是一些微不足道的事情,但我没有看到问题。 过程: CREATE PROCEDUR
我们在位置 A 有 Mosquito 代理,而 Rabbit MQ 在云中。我们已经连接了两个经纪人。来自 Mosquito 中配置的 Topic 的数据将在 Rabbit MQ 中的 AMQ.Top
我正在使用 Apache Kafka。我将巨大的数据库转储到 Kafka 中,其中每个数据库的表都是一个主题。 在主题完全消耗之前我无法删除它。我无法设置基于时间的保留策略,因为我不知道主题何时会被消
我是一名优秀的程序员,十分优秀!