240 发简信
IP属地:海南
  • 120
    非常适合开发学习的Nginx教程

    引言: 现如今作为一名Java开发工程师,不会点运维相关的技术都不好意思出去面试,本文是从0开始基于Docker搭建的Nginx,实现了Nginx的基本使用 (前提是需要懂一...

  • 120
    MetaQ中间件原理

    metaq是阿里团队的消息中间件,之前也有用过和了解过kafka,据说metaq是基于kafka的源码改过来的,他们之间的区别在哪里,接下来一探究竟。 由此实现一个重要的功能...

  • 抢红包算法

    抢红包大家都知道,但发出一个固定金额的红包,由若干个人来抢,需要满足哪些规则? 所有人抢到金额之和等于红包金额,不能超过,也不能少于。 每个人至少抢到一分钱。 要保证所有人抢...

  • 监听Mysql Binlog

    代码见:https://github.com/giafei/mysql-binlog-watcher 这个组件基于一个很现实的需求,系统随着业务发展而扩张时,总会碰到新业务需...

  • 兄弟 面试题未完待续啊。。。。哈哈

    java深入源码级的面试题

    1.哪些情况下的对象会被垃圾回收机制处理掉? 对象不可达时会被标记回收,哪些可以作为GCRoot呢,虚拟机栈,方法区中类静态属性引用的对象,方法区中常量引用的对象,本地方法栈...

  • 120
    Java面试:并发常见问题之CAS

    查看原文请点击:原文地址 一、前情回顾上篇文章给大家聊了一下volatile的原理,具体参见:《大白话聊聊Java并发面试问题之volatile到底是什么?》。这篇文章给大家...

  • oracle不支持布尔类型,一般使用char(1),0-true,1-false 或者int表示

    PostgreSQL笔记

    1.时间 四种方式查询当前时间now() , current_date, current_time, current_timestamp, 其中now() 等同于 cur...

  • PostgreSQL笔记

    1.时间 四种方式查询当前时间now() , current_date, current_time, current_timestamp, 其中now() 等同于 cur...

  • 120
    不怕难之BlockingQueue及其实现

    1. 前言 BlockingQueue即阻塞队列,它是基于ReentrantLock,依据它的基本原理,我们可以实现Web中的长连接聊天功能,当然其最常用的还是用于实现生产者...

  • SpringBoot/SpringCloud推荐博客

    https://www.fangzhipeng.com/spring-cloud.html

  • BASE理论

    BASE是Basically Available(基本可用)、Soft state(软状态)和Eventually consistent(最终一致性)三个短语的缩写。BASE理论是对CAP中一致性和可用性权衡的结果,其来源于对大规模互联网系统分布式实践的总结, 是基于CAP定理逐步演化而来的。BASE理论的核心思想是:即使无法做到强一致性,但每个应用都可以根据自身业务特点,采用适当的方式来使系统达到最终一致性。接下来看一下BASE中的三要素:

    1、基本可用

    基本可用是指分布式系统在出现不可预知故障的时候,允许损失部分可用性----注意,这绝不等价于系统不可用。比如:

    (1)响应时间上的损失。正常情况下,一个在线搜索引擎需要在0.5秒之内返回给用户相应的查询结果,但由于出现故障,查询结果的响应时间增加了1~2秒

    (2)系统功能上的损失:正常情况下,在一个电子商务网站上进行购物的时候,消费者几乎能够顺利完成每一笔订单,但是在一些节日大促购物高峰的时候,由于消费者的购物行为激增,为了保护购物系统的稳定性,部分消费者可能会被引导到一个降级页面

    2、软状态

    软状态指允许系统中的数据存在中间状态,并认为该中间状态的存在不会影响系统的整体可用性,即允许系统在不同节点的数据副本之间进行数据同步的过程存在延时

    3、最终一致性

    最终一致性强调的是所有的数据副本,在经过一段时间的同步之后,最终都能够达到一个一致的状态。因此,最终一致性的本质是需要系统保证最终数据能够达到一致,而不需要实时保证系统数据的强一致性。

    总的来说,BASE理论面向的是大型高可用可扩展的分布式系统,和传统的事物ACID特性是相反的,它完全不同于ACID的强一致性模型,而是通过牺牲强一致性来获得可用性,并允许数据在一段时间内是不一致的,但最终达到一致状态。但同时,在实际的分布式场景中,不同业务单元和组件对数据一致性的要求是不同的,因此在具体的分布式系统架构设计过程中,ACID特性和BASE理论往往又会结合在一起。

    Java帝国之分布式事务解决方案

    1 前情提要 上回说到IO大臣一直被JDBC大臣打压, 为了搞掉JDBC大臣, 他忍辱负重、历经千辛万苦终于搞出了分布式事务的标准Java Transaction API,...

  • 120
    Java帝国之分布式事务解决方案

    1 前情提要 上回说到IO大臣一直被JDBC大臣打压, 为了搞掉JDBC大臣, 他忍辱负重、历经千辛万苦终于搞出了分布式事务的标准Java Transaction API,...

  • 120
    RabbitMQ-01基本概念

    MQ应用场景介绍: 1.异步处理2.应用解耦3.流量削峰4.日志处理 RabbitMQ的安装(Windows版本),Linux需要下载linux相应的安装包 1.官网下载地址...

  • Cron(表达式)详解

    常用定时任务框架有Quartz和Spring提供的@Schedule注解,两者都使用了Cron表达式,下面详细讲解下Cron的语法规则:Cron支持7个域,分别是:秒 分 时...

  • 120
    最近面试 Java 后端开发的感受

    原文地址: www.cnblogs.com/JavaArchitect/p/10011253.html 在上周,我密集面试了若干位Java后端的候选人,工作经验在3到5年间。...