后端架构高可用可伸缩讲解之高可用

去年参加了一个技术分享活动,七牛的一个技术大牛给简要的介绍了一些高可用可伸缩的一些最佳实践,虽然只是一次简短的介绍,但是依然从中学到了很多东西,PPT内容主要分以下几个部分:

  • 入口层高可用

  • 业务层高可用

  • 缓存层高可用

  • 数据库高可用

  • 入口层可伸缩

  • 业务层可伸缩

  • 缓存层可伸缩

  • 数据库可伸缩

打算分两次把参加的技术活动日内容归类整理,
第一次主要讲下高可用,第二次讲一下可伸缩


下面来分层介绍实践方法。

入口层高可用

nigix两个 keeplive保活 心跳做好。

  • 使用心跳技术:keeplive提供这个技术

  • 比如机器A IP是1.2.3.4,机器B IP是1.2.3.5,那么再申请一个IP (1.2.3.6)我们称之为心跳IP,平时绑定再A上面,如果A宕机,那么IP会自动绑定到B上面

  • DNS 层面绑定到心跳IP即可

  • 两台机器必须在同一网段

  • 服务监听必须监听所有IP,如果仅仅监听心跳IP,那么从机上的服务(不持有心跳IP的机器)会启动失败

  • 服务器利用率下降(混合部署可以改善这一点)

考虑一个问题,两台机器,两个公网IP,DNS把域名同时定位到两个IP,这算高可用吗

不算,客户端(比如浏览器) 解析完后会随机选一个 IP访问 , 而不是一个失败后就去另一个 。 所以如果一台机器当机 ,那么就有一半左右的用户无法访问 。

业务层高可用

  • 业务层不要有状态 , 状态分散到缓存层和数据库层 。 只要没有状态,业务层的服务死掉后,前面的nginx会自动把流量打到剩下的服务 。 所以,业务层无状态是一个重点。

  • 友情提醒:不要因为想让服务无状态就直接用cookie session, 里边的坑有点大,考察清楚后再用比较好。比如重放攻击 。

缓存层高可用

  • 缓存层分得细一点,保证单台缓存宕机后数据库还能撑得住 。

  • 中小模下缓存层和业务层可以混合部署, 这样可以节省机器

  • 大型规模网站,业务层和缓存层分开部署。

  • 缓存层高可用,缓存可以启用主从两台,主缓存活着的时候,主缓存读,主从缓存都写,主缓存宕机后,从变主,主恢复后, 变成新的从。这样可以保证数据完整性,实现高可用

数据库高可用

  • MySQL有主从模式, 还有主主模式都能满足你的需求

  • MongoDB也有ReplicaSet的概念,基本都能满足大家的需求。
    这里就不做详细介绍了,有兴趣的同学可以自行百度。

高可用小结

原文链接:http://www.cnblogs.com/liuroy/p/6536630.html


.NET社区新闻,深度好文,微信中搜索dotNET跨平台或扫描二维码关注

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

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

相关文章

ssm使用全注解实现增删改查案例——mybatis-config.xml

<?xml version"1.0" encoding"UTF-8" ?> <!DOCTYPE configurationPUBLIC "-//mybatis.org//DTD Config 3.0//EN""http://mybatis.org/dtd/mybatis-3-config.dtd"> <configuration> <settings><!-- 打印查…

React绑定this的三种方式

转载自 React绑定this的三种方式 React可以使用React.createClass、ES6 classes、纯函数3种方式构建组件。使用React.createClass会自动绑定每个方法的this到当前组件&#xff0c;但使用ES6 classes或纯函数时&#xff0c;就要靠手动绑定this了。接下来介绍React中三种绑定th…

2019蓝桥杯省赛---java---B---1(组队)

题目描述 【问题描述】作为篮球队教练&#xff0c;你需要从以下名单中选出 1 号位至 5 号位各一名球员&#xff0c;组成球队的首发阵容。每位球员担任 1 号位至 5 号位时的评分如下表所示。请你计算首发阵容 1 号位至 5 号位的评分之和最大可能是多少&#xff1f;&#xff08;…

ssm使用全注解实现增删改查案例——web.xml

<?xml version"1.0" encoding"UTF-8"?> <web-app version"3.0" xmlns"http://java.sun.com/xml/ns/javaee" xmlns:xsi"http://www.w3.org/2001/XMLSchema-instance" xsi:schemaLocation"http://java.sun.co…

Asp.Net Core Authentication Middleware And Generate Token

或者应该包含什么信息呢&#xff1f; 1.这个人是谁&#xff1f; 2.这个人可以用此token访问什么样的内容&#xff1f;&#xff08;scope&#xff09; 3.token的过期时间 (expire) 4.谁发行的token。 5.其他任何你希望加入的声明&#xff08;Claims&#xff09; 那我们为什么要使…

数据库 - 事务管理(ACID)隔离级别 事务传播行为

转载自 数据库 - 事务管理&#xff08;ACID&#xff09;隔离级别 事务传播行为 总览&#xff1a; 事务的4大特性&#xff08;ACID) 原子性&#xff08;Atomicity&#xff09;   原子性是指事务包含的所有操作要么全部成功&#xff0c;要么全部失败回滚&#xff0c;这和前…

java 限制文本框长度_[Java教程]如何限制textarea文本框的输入字数

[Java教程]如何限制textarea文本框的输入字数0 2015-12-24 15:00:10如何限制textarea文本框的输入字数:在实际应用中&#xff0c;往往需要限制文本框的输入字数的长度&#xff0c;下面就通过一段代码实例简单介绍一下如何实现此功能。代码实例如下:如何限制文本框的输入长度以上…

克鲁斯卡尔算法(公交站问题)

应用场景 思路分析 代码实现 package com.atguigu.kruskal;import java.util.Arrays;/*** 创建人 wdl* 创建时间 2021/4/6* 描述*/ public class KruskalCase {private int edgNum;//边的个数private char[] vertexs;//顶点数组private int[][] matrix;//邻接矩阵//使用INF表示…

分布式系列文章——Paxos算法原理与推导

Paxos算法在分布式领域具有非常重要的地位。但是Paxos算法有两个比较明显的缺点&#xff1a;1.难以理解 2.工程实现更难。 网上有很多讲解Paxos算法的文章&#xff0c;但是质量参差不齐。看了很多关于Paxos的资料后发现&#xff0c;学习Paxos最好的资料是论文《Paxos Made Simp…

java的jdbc驱动server_win7下java用jdbc驱动来连接sql server的方法 (转载)

第一步&#xff1a;下载安装Microsoft SQL Server 2000 Service Pack 4&#xff0c;也就是sql2000的sp4补丁地址如下&#xff1a;第二步&#xff1a;下载jdbc的驱动,解压到任一位置中&#xff0c;下载地址&#xff1a;第三步&#xff1a;就是创建一个java工程&#xff0c;再在w…

浅谈流处理算法 (1) – 蓄水池采样

转载自 浅谈流处理算法 (1) – 蓄水池采样 前言 现如今&#xff0c;“大数据 ”已经不是什么新概念&#xff0c;“一千个人眼中有一千个大数据”。社交网络&#xff0c;智能穿戴设备&#xff0c;智能家居&#xff0c;传感器&#xff0c;机器人等每一个热门的词汇背后都是大量…

2018蓝桥杯省赛---java---B---7(螺旋折线)

题目描述 标题&#xff1a;螺旋折线如图p1.png所示的螺旋折线经过平面上所有整点恰好一次。 对于整点(X, Y)&#xff0c;我们定义它到原点的距离dis(X, Y)是从原点到(X, Y)的螺旋折线段的长度。 例如dis(0, 1)3, dis(-2, -1)9 给出整点坐标(X, Y)&#xff0c;你能计算出dis…

微软的.NET Core开始支持Raspberry Pi 3

微软的 .NET Core 正在向 Raspberry Pi 3 发展&#xff0c;并且适用于 ARM 设备的官方 .NET 2.0 核心将于今年晚些时候发布。微软最近开放了 .NET 核心的编程框架&#xff0c;目前的 ARM32 版本&#xff0c;在 Github 上可用&#xff0c;是多方合作的产物。 一位微软发言人告诉…

轩辕剑之天之痕1-5java_轩辕剑游戏 轩辕剑1到5全系列下载

第 5 页 轩辕剑3外传&#xff1a;天之痕【轩辕剑3外传&#xff1a;天之痕(2000)】本作可以说是轩辕剑最有名气的作品&#xff01;&#xff01;&#xff01;没错&#xff0c;一直以来轩辕剑名声最响亮的一部作品就是《天之痕》&#xff0c;到现在电视剧也终于拍出来了&#xff0…

独占锁、共享锁、更新锁,乐观锁、悲观锁

转载自 独占锁、共享锁、更新锁&#xff0c;乐观锁、悲观锁 1、锁的两种分类方式 &#xff08;1&#xff09;从数据库系统的角度来看&#xff0c;锁分为以下三种类型&#xff1a; 独占锁&#xff08;Exclusive Lock&#xff09; 独占锁锁定的资源只允许进行锁定操作的…

2019蓝桥杯省赛---java---B---2(不同子串)

题目描述 思路分析 看到不同&#xff0c;想到set去重 截取想到String.substring() 代码实现 package com.atguigu.TEST;import java.util.HashSet; import java.util.Set;class Main{public static void main(String[] args) {String target"0100110001010001";Se…

ASP.NET Core 程序发布到Linux(Centos7)爬坑实战

前言 前阶段弄了个Linux系统想倒腾倒腾.NET Core,结果看了下网上的资料&#xff0c;大部分都是过期的&#xff0c;走了不少弯路&#xff0c;不过还好&#xff0c;今下午总算捣鼓出来了。Linux命令太多了&#xff0c;唉。血的教训&#xff1a;安装一定要看官网的流程。 开始 首先…

关于Unsafe类的一点研究

转载自 关于Unsafe类的一点研究 Unsafe类是java中非常特别的一个类。它名字就叫做“不安全”&#xff0c;提供的操作可以直接读写内存、获得地址偏移值、锁定或释放线程。 通过正常途径是无法获得Unsafe实例的&#xff0c;首先它的构造方法是私有的&#xff0c;然后&#xf…

2019蓝桥杯省赛---java---B---3(数列求值)

题目描述 思路分析 此题类似于斐波那契数列&#xff0c;但是所求20190324项的最后四位数字&#xff0c;要是单纯按照斐波那契数列的思想求下去&#xff0c; 别说long类型&#xff0c;BigInteger类型都存不了这么大的数&#xff0c;然后我们发现&#xff0c;所求20190324项的最…

Visual Studio 2017 ASP.NET Core开发

Visual Studio 2017 ASP.NET Core开发,Visual Studio 2017 已经内置ASP.NET Core 开发工具. 在选择.NET Core 功能安装以后就可以进行ASP.NET Core开发。 新的ASP.NET Core项目为csproj &#xff0c;打开之前的xproj项目&#xff0c;会提示单向升级&#xff0c;确认以后&#x…