加载中
【ES优化】集群单节点cpu彪升问题定位及优化

背景: 五一休假最后一天,发现es集群开始cpu告警,找到大盘一看,一个节点产生cpu彪升;随着查询量的上升,cpu抖动的比较厉害;之前产生过一次,当时没有排查到具体原因,重启单节点之后就恢...

2022/06/30 09:50
1.9K
多输入源数据同步的一点经验

数据同步的需求,在日常的开发运维环境中是比较常见的需求,通过不同业务,不同存储之间的数据同步,继而达到满足不同业务场景的诉求。接下来我们借助笔者参与的 《Mysql->ES 数据同步项目》...

2022/06/29 14:48
66
谈谈数据一致性

微服务之后,由于服务数据的分片,达成一致性的要求会变的相对有难度。一个大的业务流程,微服务进行业务领域的划分,会变成多个子域的业务流程,最终达成一个业务动作。因此,我们可以将数据...

2021/07/04 21:23
49
API设计的一点思路

API是模块或者子系统之间交互的接口定义。好的系统架构离不开好的API设计,而一个设计不够完善的API则注定会导致系统的后续发展和维护非常困难。 以下谈一点API设计的原则。 业务层 业务语义...

2020/08/27 11:35
284
服务化设计的一点思路

1、服务化是什么? 网上有很多的对于服务化理解,我所理解的服务化,是一种服务粒度的切分,包括本质问题的通用解决方案,以及差异解决方案。服务化的目的就是透过场景看自身,而不是将自身去...

2020/08/05 17:27
1K
缓存设计的一点思路

在高并发的场景下,为了提升接口的响应速度,增大系统的吞吐量,我们一般需要增加缓存设计来提升相关的性能。那么对于缓存设计需要注意些什么呢?这便是本博客讨论的内容。 缓存设计需要从多...

2019/05/09 16:21
255
Mysql时间精度丢失问题

这两天发现一个问题,在数据库中使用了DateTime(3)类型的字段,但是发现本地的ide中入库的数据,所有的毫秒数为000,只能精确到秒,但是dev环境的服务器却是可以精确到正常的毫秒数。由于代码...

2019/03/09 10:49
2.3K
SpringMvc初始化的web容器的设置

Spring的IOC容器如何嵌入到我们运行中的容器中的? 通过Servlet来嵌入,通过ContextLoaderListener来进行IOC容器的启动,其实是通过ServletContextListener来监听ServletContext相关的事件来...

2019/02/24 16:57
651
SpringTest+Junit 加载本地Jndi数据源测试

今天写了一个比较长的流程业务,不想启动web容器进行测试,就本地写了一个Junit的测试类进行单元测试,但是由于使用Spring,Junit在使用的时候需要手动加载容器上下文,比较麻烦,所以干脆直...

2018/12/21 17:50
3K
Redis资源池化技术+Sentinel哨兵模式进行集群通信

redis在线上使用的时候,为了高可用和可扩展性,一般不会是单台或者一组的模式运行,而是按照一个集群的模式运行。一个集群包括多组redis,一组redis包含一个master和多个slave,这样我们为了...

2018/12/08 16:58
812
Condition使用的一个小研究

最近发现在项目的框架中,使用了Condition来进行线程间的通信。并且使用的方式是如下的方式。 ...................Thread1........................ try{ Lock.lock(); Condition.await(lon...

2018/11/26 16:42
55
JAVA的SPI和ServiceLoader

SPI即Service Provider Interface,用于提供一些服务给第三方实现或扩展,可以增强框架的扩展或者替换一些组件,其实就是约定的一种规范,可以参考JDBC,不同厂家使用相同的约束去实现不同的...

2018/11/12 16:50
501
Redis中的skipList

SkipList是一种有序的数据结构,它通过在每个节点中维持多个指向其它节点的指针,从而达到快速访问节点的目的。 跳跃表支持平均O(logN),最坏O(N)负责度的节点查找。还可以通过顺序性操作来批...

2018/10/28 23:45
1.4K
JVM内存模型1

1、并发编程的两个关键问题:线程通信和线程同步 线程通信的方式:共享内存和消息传递 内存共享模式是隐式进行通信的,而消息传递则是显示进行通信的 线程同步:用于控制线程间操作发生的相对...

2018/10/03 22:32
59
Spark入门学习——要点3

通常在向Spark传递函数的时候,可以使用驱动器程序中定义的变量,但是集群中运行的每个任务都会得到这些变量的一个新的副本,更新这些副本的值也不会影响到驱动器中对应变量。Spark的两个共享...

2018/09/15 15:36
39
Spark入门学习——要点2

1、PairRDD的转换操作 Pair RDD的转化操作(以键值对集合{(1, 2), (3, 4), (3, 6)}为例) 函数名 目的 示例 结果 reduceByKey(func) 合并具有相同键的值 rdd.reduceByKey((x, y) => x + y) {...

2018/09/14 16:53
44
Spark入门学习——要点1

1、collect() 函数 RDD 还有一个collect() 函数,可以用来获取整个RDD 中的数据。如果你的程序把RDD 筛选到一个很小的规模,并且你想在本地处理这些数据时,就可以使用它。记住,只有当你的整...

2018/09/14 16:45
81
JAVA8中的stream原理解析——1(串行)

常用的流操作 在stream使用之前,我们看下经常使用到的stream中的相关的操作。 在上表中,Stream的操作可以分为两大类:中间操作和结束操作,中间操作只是对操作进行了记录,只有结束操作才会...

2018/08/29 16:46
2.9K
简单分析Guava中RateLimiter中的令牌桶算法的实现

令牌桶算法是网络流量整形(Traffic Shaping)和速率限制(Rate Limiting)中最常使用的一种算法。典型情况下,令牌桶算法用来控制发送到网络上的数据的数目,并允许突发数据的发送。 大小固...

2018/08/01 20:48
2.8W

没有更多内容

加载失败,请刷新页面

返回顶部
顶部