Flink项目构建模板 - Gradle 环境 Gradle:7.x Java:8 相较于官方模板 升级Gradle Shadow版本 移出过时仓库JCenter 修改过时语法 仓库改为阿里镜像 buildscript { repositories { maven { ...
Java 并发 - synchronized关键字使用
1. synchronized的使用 1.1 synchronized的作用范围 synchronized可以根据锁的对象,把锁分为两种,分别是类锁和对象锁 1.1 对象锁 手动指定锁定对象,也可是是this,也可以是自定义的锁 private final Object lock1 = new Object(); public void printStr1() {...
MySQL 中执行计划分析 - Optimizer trace表
1. 概述 对于 MySQL 5.6 以及之前的版本来说,查询优化器就像是一个黑盒子一样,你只能通过 EXPLAIN 语句查看到最后优化器决定使用的执行计划,却无法知道它为什么做这个决策。 在 MySQL 5.6 以及之后的版本中,MySQL 提出了一个 optimizer trace 的功能,这个功能可以让我们方便的查看优化器生成执行计划的整个过程。 2.Optimize...
Java 基础 - 注解机制详解
1. Java注解概述 注解是JDK1.5版本开始引入的一个特性,用于对代码进行说明,可以对包、类、接口、字段、方法参数、局部变量等进行注解。它主要的作用有以下四方面: 生成文档,通过代码里标识的元数据生成javadoc文档。 编译检查,通过代码里标识的元数据让编译器在编译期间进行检查验证。 编译时动态处理,编译时通过代码里标识的元数据动态处理,例如动态生成代码。 运...
MySQL - 事件调度器(Event Schedule)
1.概述 事件调度器(Event Schedule)类似于Linux中的crontab(也就是定时任务),下面介绍事件调度器的基本使用方法 2.使用 2.1 查看事件调度器状态以及相关操作 # 查看状态 show variables like '%event_scheduler%'; +---------------+-----+ |Variable_name |Value| ...
MySQL - 执行计划
1.概述 一条查询语句在经过MySQL查询优化器的各种基于成本和规则的优化会后生成一个所谓的执行计划,这个执行计划展示了接下来具体执行查询的方式,比如多表连接的顺序是什么,对于每个表采用什么访问方法来具体执行查询等等。 如果需要查询具体的执行计划,可通过在查询语句前追加EXPLAIN进行查看,例如: flink_data_qnh> EXPLAIN SELECT 1 +--...
MySQL索引与MongoDB索引的区别
MySQL索引与MongoDB索引的区别 1. 背景 最近学习了MySQL的索引的相关内容,而目前生产系统上使用的使MongoDB,遂对这两个不同数据库的索引进行了下对比。这里的MySQL值得使Innodb存储引擎。 2. 两个数据库之间的区别 MySQL中的Innodb采用的使B+Tree作为索引的结构,而MongoDB使用的使B-Tree作为索引结构,所以这两个数据库索引之间...
MySQL - MySQL中的索引
1. 概述 定义:索引是存储引擎用于快速找到记录的一种数据结构。举例说明:如果查找一本书中的某个特定主题,一般会先看书的目录(类似索引),找到对应页面。在MySQL,存储引擎采用类似的方法使用索引,高效获取查找的数据。 索引的分类 从存储结构上来划分 Btree 索引(B+tree,B-tree) 哈希索引 full-index 全文...
数据结构 - B树和B+树
1. 背景 最近在学习数据库相关的知识,了解到数据库很多是采用B-/+树作为索引,例如Mysql的InnoDB引擎使用的B+树、MongoDB默认采用B树作为索引。 在计算机科学中,B树(英语:B-tree)是一种自平衡的树,能够保持数据有序。这种数据结构能够让查找数据、顺序访问、插入数据及删除的动作,都在对数时间内完成。B树,概括来说是一个一般化的二叉查找树(binary s...
Java 日志框架
1. 背景 用了几年的Java日志框架,但却对里面的逻辑关系不是特别清楚,准备花时间理清一下其中的关系以及基本的使用说明 1.1 常见Java日志框架 Log4j Log4j 是 Apache 的一个 Java 的日志库,通过使用 Log4j,我们可以控制日志信息输送的目的地(控制台、文件、数据库等);我们也可以控制每一条日志的输出格式;通过定义每一条日志信息的级别,我们能够更加细致...