摘要: 什么是单例?为什么要用单例? 一个类被设计出来,就代表它表示具有某种行为(方法),属性(成员变量),而一般情况下,当我们想使用这个类时,会使用new关键字,这时候jvm会帮我们构造一个该类的实例。而我们知道,对于new这个关键字以及该实例,相对而言是比较耗费资源的。所以如果我们能够想办法在jvm启动 阅读全文
posted @ 2019-08-25 17:06 青紫天涯 阅读(256) 评论(0) 推荐(0) 编辑
摘要: 前言 在实际工作中,线程是一个我们经常要打交道的角色,它可以帮我们灵活利用资源,提升程序运行效率。但是我们今天不是探讨线程!我们今天来聊聊另一个与线程息息相关的角色:线程池.本篇文章的目的就是全方位的解析线程池的作用,以及jdk中的接口,实现以及原理,另外对于某些重要概念,将从源码的角度探讨。 ti 阅读全文
posted @ 2019-08-25 16:58 青紫天涯 阅读(223) 评论(0) 推荐(0) 编辑
摘要: 7.redis 集群模式的工作原理能说一下么?在集群模式下,redis 的 key 是如何寻址的?分布式寻址都有哪些算法?了解一致性 hash 算法吗? 考点分析 在前几年,redis 如果要搞几个节点,每个节点存储一部分的数据,得借助一些中间件来实现,比如说有 codis,或者 twemproxy 阅读全文
posted @ 2019-08-25 16:45 青紫天涯 阅读(282) 评论(0) 推荐(0) 编辑
摘要: 1.项目中缓存是如何使用的?为什么要用缓存?缓存使用不当会造成什么后果? 面试题剖析 为什么要用缓存? 用缓存,主要有两个用途:高性能、高并发。 高性能 假设这么个场景,你有个操作,一个请求过来,吭哧吭哧你各种乱七八糟操作 mysql,半天查出来一个结果,耗时 600ms。但是这个结果可能接下来几个 阅读全文
posted @ 2019-08-25 16:37 青紫天涯 阅读(235) 评论(0) 推荐(0) 编辑
摘要: 简介 Spark中的OOM问题不外乎以下两种情况 map执行中内存溢出 shuffle后内存溢出 map执行中内存溢出代表了所有map类型的操作。包括:flatMap,filter,mapPatitions等。 shuffle后内存溢出的shuffle操作包括join,reduceByKey,rep 阅读全文
posted @ 2019-08-25 12:57 青紫天涯 阅读(4654) 评论(1) 推荐(0) 编辑
摘要: 一、如何检查namenode是否正常运行?重启namenode的命令是什么? 通过节点信息和浏览器查看,通过脚本监控 hadoop-daemon.sh start namenode hdfs-daemon.sh start namenode 二、hdfs存储机制是怎样的? 1) client端发送写 阅读全文
posted @ 2019-08-25 12:39 青紫天涯 阅读(17807) 评论(1) 推荐(1) 编辑