[Kogel.Subscribe.Mssql]SQL Server增量订阅,数据库变更监听
此框架是SQL Server增量订阅,用来监听增删改数据库数据变更
目前仅支持SQL Server,Nuget上可以下载安装
或者使用Nuget命令添加包
dotnet add package Kogel.Subscribe.Mssql --version 0.0.0.1
(一)定义需要监听表的实体类
/// <summary>
///
/// </summary>
[Display(Rename = "t_oms_order_detail")]
[ElasticsearchType(RelationName = "t_oms_order_detail", IdProperty = "Id")]
public class OmsOrderDetail : IBaseEntity<OmsOrderDetail, int>
{
/// <summary>
///
/// </summary>
[Identity]
[Display(Rename = "id")]
[Nest.PropertyName("id")]
public override int Id { get; set; } /// <summary>
///
/// </summary>
[Display(Rename = "name")]
[Nest.PropertyName("name")]
public string Name { get; set; } /// <summary>
///
/// </summary>
[Display(Rename = "trade_id")]
[Nest.PropertyName("trade_id")]
public int? TradeId { get; set; } /// <summary>
///
/// </summary>
[Display(Rename = "descption")]
[Nest.PropertyName("descption")]
public string Descption { get; set; } /// <summary>
///
/// </summary>
[Display(Rename = "create_time")]
[Nest.PropertyName("create_time")]
public DateTime CreateTime { get; set; }
}
[Display]和[Identity]属于Kogel.Dapper.Extension的特性如果[想了解更多请点击],[ElasticsearchType]和[Nest.PropertyName]属于Elasticsearch特性,如果没用到可以忽略
(二)定义表订阅
/// <summary>
/// 定义表订阅
/// </summary>
public class OmsOrderDetailSubscribe : Subscribe<OmsOrderDetail>
{
/// <summary>
/// 设置连接配置
/// </summary>
/// <param name="builder"></param>
public override void OnConfiguring(OptionsBuilder<OmsOrderDetail> builder)
{
//此连接字符串账号需要有管理员权限
builder.BuildConnection("数据库连接字符串");
}
}
如果需要此表对应多张分表可以设置
//配置所有表分片
builder.BuildShards(new List<string>
{
"t_oms_order_detail_1",
"t_oms_order_detail_2",
"t_oms_order_detail_3"
})
(1).如果想推送订阅到RabbitMQ中
builder.BuilderRabbitMQ(new RabbitMQ.Client.ConnectionFactory
{
HostName = "localhost",
UserName = "guest",
Password = "guest"
})
可以通过BuildTopic设置交换机名称
builder.BuildTopic("kogel_subscribe_order_detail")
(2).如果想推送订阅到Kafka中
builder.BuildKafka(new ProducerConfig
{
BootstrapServers = "localhost:9092",
Acks = Acks.None
})
可以通过BuildTopic设置Topic名称
builder.BuildTopic("kogel_subscribe_order_detail")
(3).如果想推送订阅到Elasticsearch中
builder.BuildElasticsearch(new ElasticsearchConfig<OmsOrderDetail>
{
Settings = new Nest.ConnectionSettings(new Uri("http://localhost:9200/")),
})
如果有设置Basic授权
builder.BuildElasticsearch(new ElasticsearchConfig<OmsOrderDetail>
{
Settings = new Nest.ConnectionSettings(new Uri("http://localhost:9200/"))
.BasicAuthentication("账号","密码")
})
如果想根据自己定义的分片逻辑插入到多个ES索引中可以通过WriteInterceptor
/// <summary>
/// 设置连接配置
/// </summary>
/// <param name="builder"></param>
public override void OnConfiguring(OptionsBuilder<OmsOrderDetail> builder)
{
//此连接字符串账号需要有管理员权限
builder.BuildConnection("数据库连接字符串");
//定义推送ES
builder.BuildElasticsearch(new ElasticsearchConfig<OmsOrderDetail>
{
Settings = new Nest.ConnectionSettings(new Uri("http://localhost:9200/"))
.BasicAuthentication("账号", "密码"),
WriteInterceptor = message => WriteInterceptor(message)
});
} /// <summary>
/// 定义自己的索引逻辑
/// </summary>
/// <param name="messages"></param>
/// <returns></returns>
private EsSubscribeMessage<OmsOrderDetail> WriteInterceptor(SubscribeMessage<OmsOrderDetail> message)
{
string esIndexName;
//这里写自己索引分片的业务逻辑
if (message.Result.Id % 3 == 0)
{
esIndexName = $"kogel_orders_2";
}
else
{
esIndexName = $"kogel_orders_1";
}
return message.ToEsSubscribeMessage(esIndexName);
}
并且ES索引不存在的时候会动态创建
(4).如果想自定义实现订阅逻辑,在可以Subscribe订阅类中重写
/// <summary>
/// 订阅变更 (每一次sql的执行会触发一次Subscribe)
/// </summary>
/// <param name="messageList">消息列表表示所有影响到的数据变更(会受BuildLimit限制,没有查询完成的会在下一次查出)</param>
public override void Subscribes(List<SubscribeMessage<T>> messageList)
{
foreach (var message in messageList)
{
Console.WriteLine($"执行动作:{message.Operation},更新的表:{message.TableName},更新的id:{message.Result.GetId()}");
}
}
以上订阅的优先级:

(三)订阅启动
启动监听所有继承自Subscribe<T>的类,在应用程序启动时执行即可
ApplicationProgram.Run();
如果是基础BaseSubscribe<T>中间基类需要定义成abstract,例如
/// <summary>
/// 基础配置类需要定义成abstract
/// </summary>
/// <typeparam name="T"></typeparam>
public abstract class BaseSubscribe<T> : Subscribe<T>
where T : class, IBaseEntity
{
}
关闭监听,在应用程序退出时执行即可
ApplicationProgram.Close();
(四)其他配置
builder.BuildCdcConfig(new CdcConfig
{
//扫描间隔(每次扫描变更表的间隔,单位毫秒) 默认10000毫秒/10秒
ScanInterval = 10000, //变更捕捉文件在DB保存的时间(默认三天)
Retention = 60 * 24 * 3, //是否首次扫描表全部数据再监听变更(默认false)
IsFirstScanFull = false, //每次检索的变更量(默认10条)
Limit = 10, //变更扫描的偏移量位置(默认从最后中止处开始)
OffsetPosition = OffsetPositionEnum.Abort
})
框架开源,完整框架源码可以去Github上下载:
https://github.com/a935368322/Kogel.Subscribe.Mssql
如有问题也可以加QQ群讨论:
技术群 710217654
[Kogel.Subscribe.Mssql]SQL Server增量订阅,数据库变更监听的更多相关文章
- sql server 警报管理,实时监听数据库动向,运筹帷幄之中
工作这么多年了,无论是身边的同学还是同事,发现只要搞程序员的都有一个通病---懒.懒到谁都不愿意加班,尤其是"义务"加班.即使大家都不愿意加班,但是很多时候项目赶着上线或者上线之后 ...
- 使用SQL Server Audit记录数据库变更
最近工作中有一个需求,就是某一个比较重要的业务表经常被莫名其妙的变更.在SQL Server中这类工作如果不事前捕获记录的话,无法做到.对于捕获变更来说,可以考虑的选择包括Trace,CDC. ...
- SQL Server CDC配合Kafka Connect监听数据变化
写在前面 好久没更新Blog了,从CRUD Boy转型大数据开发,拉宽了不少的知识面,从今年年初开始筹备.组建.招兵买马,到现在稳定开搞中,期间踏过无数的火坑,也许除了这篇还很写上三四篇. 进入主题, ...
- Atitit.数据库新特性战略规划 mssql sql server 2008 SQL2012 SQL2014
Atitit.数据库新特性 mssql sql server 2008 SQL2012 SQL2014 1. Sql2012 新特性 1 1.1. 增加了Sequence对象. 1 1.2. 新的分页 ...
- 【SQL Server复制】数据库复制:修改表结构、新增表、新增存储过程 会被复制到订阅服务器?
转自:https://www.cnblogs.com/happyday56/p/3849018.html 关键字:sql server复制 [SQL Server高可用性]数据库复制:修改表结构.新增 ...
- SQL Server 中心订阅模型(多发布单订阅)
原文:SQL Server 中心订阅模型(多发布单订阅) 大多数SQL Server 复制拓扑都是基于中心发布模型,它是由一个发布复制到一个或者多个订阅.另一个复制模型是中心订阅模型,它使用事务复制由 ...
- 【SQL Server高可用性】数据库复制:SQL Server 2008R2中通过数据库复制,把A表的数据复制到B表
原文:[SQL Server高可用性]数据库复制:SQL Server 2008R2中通过数据库复制,把A表的数据复制到B表 经常在论坛中看到有人问数据同步的技术,如果只是同步少量的表,那么可以考虑使 ...
- SQL Server 2008 master 数据库损坏解决总结
SQL Server 2008 master数据库损坏后,SQL SERVER服务启动失败,查看错误日志,你会看到下面错误信息: 2015-10-27 10:15:21.01 spid6s ...
- SQL Server删除distribution数据库二
以前总结过一遍博文SQL Server删除distribution数据库,里面介绍了如何删除distribution数据库.今天介绍一个删除distribution的特殊案例, 在这之前,我不知道这个 ...
- SQL SERVER 2012 修改数据库默认位置不立即生效
今天修改SQL SERVER 2012的数据库默认位置:即数据文件.日志文件默认位置时遇到一个问题,单击"服务器属性"(Server Properties)--> 数据库设置 ...
随机推荐
- .Net 不受 EAR 的约束
NPUlrk :https://github.com/NPUlrk 同学在 dotnet/runtime 仓库提出了一共问题: https://github.com/dotnet/runtime/d ...
- Kubernetes 多租户:Pod 安全策略
默认情况下,Kubernetes 允许创建一个有特权容器的 Pod,这些容器很可能会危机系统安全,而 Pod 安全策略(PSP)则通过确保请求者有权限按配置来创建 Pod,从而来保护集群免受特权 Po ...
- kubeadm init 命令执行流程
- 天翼云主机某一IP多次登录失败导致IP被锁无法登录,天翼云主机莫名其妙无法远程登陆
情况说明: 直接使用该IP通过ssh远程连接失败,但是先通过ssh远程连接其他主机上,然后在这个主机上再ssh刚才连接失败的主机,就能登陆上. 说明,root用户不是被锁了, 而是远程登陆IP被锁了 ...
- kubernetes1.20 部署 traefik2.3
一.概述 Traefik 是一个开源的可以使服务发布变得轻松有趣的边缘路由器.它负责接收你系统的请求,然后使用合适的组件来对这些请求进行处理. 除了众多的功能之外,Traefik 的与众不同之处还在于 ...
- 几篇关于MySQL数据同步到Elasticsearch的文章---第二篇:canal 实现Mysql到Elasticsearch实时增量同步
文章转载自: https://mp.weixin.qq.com/s?__biz=MzI2NDY1MTA3OQ==&mid=2247484377&idx=1&sn=199bc88 ...
- C#高级特性(反射)
今天来讲解反射的应用: 一.反射是什么? 简诉一下,反射就是.Net Framework 的一个帮助类库,可以获取并使用metadata(元数据清单):说的通俗易懂点,就是不用通过引用,仍然可以使用其 ...
- .NET下数据库的负载均衡(有趣实验)
相关下载: 数据库的负载均衡-示例代码(dp1-DbBalance.rar) 数据库的负载均衡-示例代码(dp1-DbBalance.rar) 支持.Net/.Net Core/.Net Framew ...
- HTML&CSS-盒模型运用居中方式合集
方法:定位,外边距,内边距,层级,边框: 一个元素: 两个元素: 三个元素. <!DOCTYPE html> <html lang="en"> <he ...
- NOI2015 洛谷P1955 程序自动分析(并查集+离散化)
这可能是我目前做过的最简单的一道noi题目了...... 先对e=1的处理,用并查集:再对e=0查询,如果这两个在同一集合中,则为""NO",最后都满足的话输出" ...