sqlserver date类型和字符串比较_基于SQL Server数据库搭建主从复制实现读写分离实战演练...

6caf802d15e3c4d8576a69a948ed8466.png

一、课程介绍

读写分离(主从同步)从字面意思就可以理解,就是把对数据库的读操作和写操作分离开。读写分离在网站发展初期可以一定程度上缓解读写并发时产生锁的问题,将读写压力分担到多台服务器上。读写分离的基本原理是让主数据库处理事务性增、改、删操作(INSERT、UPDATE、DELETE),而从数据库处理SELECT查询操作。随着系统的业务量不断增长数据多了之后,对数据库的读、写就会很多。分库减少单台数据库的压力。本文以MS SQL Server数据库为例主库负责写数据、读数据。读库仅负责读数据。写库就一个,读库可以有多个。

在上一节分享课程中《.NET Core基于SQL Server数据库实现读写分离实战演练》我们已经学会了如何在.NET Core代码层面如何通过数据库中间件来操作我们的读写分离的数据库。本节课程接着上一节课程中遗留的问题,废话不多说直接进入本次课程的主题。

.1、本次分享课程适合人群如下
1)、有一定的.NET Core开发基础。
2)、有一定的SQL SERVER基础知识。
3)、学习和了解.Net Core跨平台开发技术。
如果您同样对本次分享《基于SQL Server数据库搭建主从复制实现读写分离实战演练》课程感兴趣的话,那么请跟着阿笨一起学习吧。一句话总结今天我们学习达到的目标?如何基于SQL Sever数据库搭建主从同步实现读写分离。
废话不多说,直接上干货,我们不生产干货,我们只是干货的搬运工。

94afc1d742fae1045b2fea299ea66673.png

二、Microsoft SQL Server常见的几种实现读写分离方案

2.1、SQL Server提供了三种技术实现读写分离

SQL Server提供了三种技术,可以用于读写分离的实现:日志传送、事务复制和SQL Server 2012以上版本中新增的功能Always On技术。这三种技术的比较如下:

fd7bba74364a802ebc90ee3af0ad5ac0.png

.NET高级进阶之基于SQL Server搭建主从复制实现读写分离实战演练

配置复制就没有数据库镜像和AlwaysOn的要求那么高,只需要两台服务器能通过TCP进行通讯即可,两台服务器操作系统和SQL版本都可以不完全一致,而且两台服务器也不需要加入域,所以配置复制订阅就简单多了,但是复制订阅主要是针对数据表而不能像镜像和AlwaysOn那样配置整个数据库,这也是它的缺点吧。

综上:考虑到简单性和实用性,这里阿笨推荐采用事务复制技术来实现SQL SERVER读写分离。

三、Microsoft SQL Server 2014主从复制环境搭建实战演练

1)、同台服务器不同数据库实现主从复制

在《.NET Core基于SQL Server数据库实现读写分离实战演练》分享课程中已经演示过。

2)、不同服务器不同数据库实现主从复制(由于篇幅较长,单独课程进行分享)

afc2fb76ad5bc81cff921d1c70462ca9.png

.NET高级进阶之基于SQL Server搭建主从复制实现读写分离实战演练

   读写分离就是主从集群,一主多从或者一主一丛都是可以的,就是数据库主机复制写入操作,从机负责读的操作,主机写入以后再同步给从机;

四、思考与总结

4.1、总结:怎么开发中我们的程序使用数据库主从?

一个是主连接字符串,另外是一个或者多个从的字符配置,我们要实现读写分离就是去实现读取的时候用从库的连接字符串,写入的时候用主库的连接字符串,说到这里我想大家应该很明确自己的思路明确一点,那就是我们读的时候用从库,写的时候用主库。

1)、根据切换数据库连接字符串R/W来实现手动的读写分离。缺点:不灵活,扩展低,不具备高可用,稳定性差,侵入式太强,只适合小项目临时应急使用。
2)、第三方数据库中间件比如阿里巴巴的MyCat、 360开发的atlas  等等。缺点:重量级,入门门槛难度大,学习成本高。
3)、.NET Core开源数据库访问组件。优点:灵活,真真实现读写分离。 

4.2、思考:如何保证数据库主从复制的高可用呢?

0a3b5504c468f581d7102b41594ee8a3.png

基于SQL Server搭建主从复制实现读写分离实战演练

虚拟IP(VIP)。缺点:需要运维人员支持(基于VIP的keepalived高可用集群架构)!

1)、怎么实现故障检测的那?

心跳,采用定时发送一个数据包,如果机器多长时间没响应,就认为是发生故障,自动切换到热备的机器上去。

2)、怎么实现自动切换那?

虚IP。何为虚IP那,就是一个未分配给真实主机的IP,也就是说对外提供数据库服务器的主机除了有一个真实IP外还有一个虚IP,使用这两个IP中的 任意一个都可以连接到这台主机,所有项目中数据库链接一项配置的都是这个虚IP,当服务器发生故障无法对外提供服务时,动态将这个虚IP切换到备用主机。

.NET Core支持数据库读写分离的组件比较多,比如:FreeSql ,SmartSql,SqlSugar(在《.NET Core基于SQL Server数据库实现读写分离实战演练》中已经分享)等等。

最后送大家一句话:希望大家在.NET Core的学习道路上一直跟着阿笨坚持下去。

9d95341f1a11fd44459100a6cbe7dcda.png

腾讯课堂

1e7e8c7c6662451cd0e0f11563510737.png

网易云课堂

b42a17ffacbb01bfc9d539060b3ea115.png

不信的话,扫一扫

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.mzph.cn/news/533837.shtml

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

linux非标准头文件,Linux学习:unix的标准化的实现(Linux中各种限制-数据类型-各种标准化头文件介绍)...

作为Linux的前身,unix标准化是十分重要的。我在这里挑几个重要的点说明。1:Linux中各种限制。Linux中限制有编译时限制和运行时限制,另外有一些限制是由于我们的实现不同而不同,因此我们需要调用对应的函数获取对应的值不同。(eg&…

python怎么导入大小字母_python遍历小写英文字母的方法

python遍历小写英文字母的方法在c、c等语言中,可以用字符1的for循环来遍历小写的26个英文字母,但是由于python语言的特殊性,通过a 1这种代码并不能成功遍历,以下是在python中遍历英文字母的简洁代码:import stringfor…

51单片机怎么显示当前时间_(进阶篇)51单片机之按键控制蜂鸣器、数码管、按键值移位显示...

一、实操演示- 按键控制蜂鸣器1、图文详细独立按键硬件电路蜂鸣器硬件电路2、连接方式:J20的第3号引脚连接到J7引脚,即P15连接J7。J29的第7、8号引脚连接到JP1的第1、2号引脚,即P31连接k1,P30连接k2。下载程序后,观察现…

linux怎么运行g77,Linux安装g77编译器的技巧

在Ubuntu10.10系统中,g77已经被gfortran完全替代了,但并不能完全兼容过去的g77,这样就不能使用一些用977编译的程序了。所以我们只能自己再安装g77了。今天华军小编给大家展示的是Linux安装g77编译器的技巧,精心挑选的内容希望大家…

oracle 结果集已耗尽_java.sql.SQLException: 结果集已耗尽

编写了jsp谁能帮忙看下有什么问题编写了jsp 谁能帮忙看下 有什么问题技术交流ResultSet rsnull;String str"select publish_id,publish_name,publish_time,publish_text from comment_tb order by publish_time desc ";query.connect();rsquery.select(str);while(rs…

vs使用未初始化的内存怎么解决_遇到C语言内存错误怎么办?一定要找准这六个原因...

一、没有为指针分配内存定义了指针变量,但是没有为指针分配内存,即指针没有指向一块合法的内存。浅显的例子就不举了,这里举几个比较隐蔽的例子。1、结构体成员指针未初始化struct student { char *name; int score; }stu,*pstu; int main() …

linux服务器如何设置双网卡,linux服务器设置(双网卡共享上网)

一、网络拓补结构:服务器:两网卡的设置:eth0:202.96.168.100 掩码:255.255.255.0 网关:202.96.168.68 #与 Inte.Net 相联eth1:192.168.1.1掩码:255.255.255.0#与局域网相联客户机子网段:192.1…

pwn环境搭建_pwndbg、pwntools环境搭建(Unix系统)

目录[TOC]pwndbg环境搭建项目地址https://github.com/pwndbg/pwndbg搭建过程1、安装环境基础gitpythonpython-pip2、安装过程使用git命令克隆远程项目到本地。git clone https://github.com/pwndbg/pwndbg进入项目根目录并执行一键安装脚本cd pwndbg && ./setup.sh该脚…

cad求和插件_黑科技 | 无BIM建模下平面CAD自动生成门窗表

如果你接到的施工图既不是用天正出的,也不是用revit出的,还得统计门窗表,那么你需要读完这篇文章。为了能够让自己和所有底层同行们从这项无脑又烧脑的机械劳动中解脱,C君近期利用茶余饭后的时间开发了一个小插件,可以…

linux数据库实例开机启动,linux下数据库实例开机自启动设置

linux下数据库实例开机自启动设置 1、修改/oratab [rootorg54 ~]# vi/etc/oratab --把N改为Y,如下提示 # This file is used by ORACLEutilities. It is created by root.sh # and updated by the Database ConfigurationAssistant when creating # a datablinux下数…

panic 苹果aop_Go Web开发之Revel - 拦截器

一个拦截器是一个框架在调用action方法前或后调用的函数. 它允许一种AOP的形式, 它经常被用于做下面几种事情:Request loggingError handlingStats keeping在Revel里, 一个拦截器能接受两种形式:1. 函数拦截器: 一个函数满足没有访问特定的应用程序Controller被调用在应用程序中…

make找不到linux内核函数,linux内核make menuconfig出错

今天实验刚从服务器上迁移过来的维护的linux 9260的内核,使用make menuconfig时出错,报错为:yongtaoyongtao-desktop:~/public/linux_release/linux-2.6.24$ make menuconfigHOSTCC scripts/kconfig/conf.oHOSTCC scripts/kconfig/kxgettex…

tensorboard ckpt pb 模型的输出节点_算法工程化系列——模型固化

摘要基于tensorflow训练的模型一般被保存为ckpt形式的文件,随着当前深度学习模型网络越来越大,对应模型也会非常大。当对外提供服务的时候,如果采用ckpt的形式,服务进程被调起来非常困难,且推理服务一般速度也较慢(会达…

深度linux内核升级,深度操作系统 2020.11.11 更新发布:内核升级

原标题:深度操作系统 2020.11.11 更新发布:内核升级IT之家11月11日消息 今日,深度操作系统宣布2020.11.11 更新现已发布。本次更新包括升级内核、Debian 10.6 仓库以及系统安全性更新。系统安全方面,本次更新修复了 Firefox-ESR 安…

unity 使用mysql实现登录注册_用mysql实现登录注册功能

1、创建用户表表结构如下idunameupwdisdelete注意:需要对密码进行加密。如果使用md5加密,则密码包含32个字符。如果使用sha1加密,则密码包含40个字符,这里使用这种方式。md5加密方式:import hashlibpwd 123456my_md5 …

python爬电影_使用Python多线程爬虫爬取电影天堂资源

最近花些时间学习了一下Python,并写了一个多线程的爬虫程序来获取电影天堂上资源的迅雷下载地址,代码已经上传到GitHub上了,需要的同学可以自行下载。刚开始学习python希望可以获得宝贵的意见。 先来简单介绍一下,网络爬虫的基本实…

打不开磁盘配额linux,九度OJ 1455 珍惜现在,感恩生活 -- 动态规划(背包问题)...

题目描述:为了挽救灾区同胞的生命,心系灾区同胞的你准备自己采购一些粮食支援灾区,现在假设你一共有资金n元,而市场有m种大米,每种大米都是袋装产品,其价格不等,并且只能整袋购买。请问&#xf…

erp 维护费 要交吗_ERP系统维护费

今年8月,SAP中国公司宣布2009年1月1日前将由传统支持服务转向企业级支持服务(SAP Enterprise Support)。同时将开始实施渐进式定价方案,并预计在2012年之前,逐渐将所有客户从现行的SAP Standard/Premium Support的定价协议过渡为SAP Enterpri…

sentinel 端口_Sentinel原理:控制台是如何获取到实时数据的

Sentinel 系列教程,现已上传到 github 和 gitee 中:GitHub:https://github.com/all4you/sentinel-tutorialGitee:https://gitee.com/all_4_you/sentinel-tutorialSentinel 能够被大家所认可,除了他自身的轻量级&#x…

linux桌面时区设置,如何在Ubuntu 20.04上设置或更改时区

对于许多与系统相关的任务和进程,使用正确的时区至关重要。 例如,cron守护程序使用系统的时区执行cron作业,而日志文件中的时间戳基于系统的同一时区。在Ubuntu上,系统的时区是在安装过程中设置的,但以后可以轻松更改。…