代码改变世界

使用binlog2sql做数据恢复的简单示例

2017-10-17 11:59 by 飘扬的红领巾, 268 阅读, 收藏, 编辑
正文内容加载中...

MyCAT-EYE开源

2017-09-29 17:34 by 飘扬的红领巾, 415 阅读, 收藏, 编辑
摘要: MyCAT EYE MySQL数据库监控工具,实现了对MySQL节点的管理和监控,可供开发人员和DBA使用。后续版本将整合MyCAT2.0的管理和配置。 开源地址: https://gitee.com/redtie/mycateye 演示地址: 开发人员视图:http://120.77.46.146:7001 DBA或管理人员视图:http://120.77.46.146:7002 登录用户名、密...阅读全文

深入理解JVM(八)——java堆分析

2017-09-12 11:39 by 飘扬的红领巾, 505 阅读, 收藏, 编辑
摘要: 上一节介绍了针对JVM的监控工具,包括JPS可以查看当前所有的java进程,jstack查看线程栈可以帮助你分析是否有死锁等情况,jmap可以导出java堆文件在MAT工具上进行分析等等。这些工具都非常有用,但要用好他们需要不断的进行实践分析。本文将介绍使用MAT工具进行java堆分析的案例。 内存溢出(OOM)的原因 我们常见的OOM(OutOfMemoryError)发生的原因不只是堆...阅读全文

NOSQL EYE开源

2017-09-06 12:04 by 飘扬的红领巾, 610 阅读, 收藏, 编辑
摘要: 简介 NOSQL数据库监控工具,目前实现了对Redis、MongoDB的监控功能。 功能列表 下载地址 http://git.oschina.net/redtie/nosqleye 演示地址 http://106.14.181.95:7004 登录用户名、密码:admin/admin 安装环境 推荐阅读全文

深入理解JVM(七)——性能监控工具

2017-09-01 17:20 by 飘扬的红领巾, 527 阅读, 收藏, 编辑
摘要: 前言 工欲善其事必先利其器,性能优化和故障排查在我们大都数人眼里是件比较棘手的事情,一是需要具备一定的原理知识作为基础,二是需要掌握排查问题和解决问题的流程、方法。本文就将介绍利用性能监控工具,帮助开发者更快更准的找到问题产生的根源。本文分为三部分,第一部分将介绍在Linux环境下的常用监控工具,第阅读全文

深入理解JVM(六)——类加载器原理

2017-08-25 17:41 by 飘扬的红领巾, 90 阅读, 收藏, 编辑
摘要: 我们知道我们编写的java代码,会经过编译器编译成字节码文件(class文件),再把字节码文件装载到JVM中,映射到各个内存区域中,我们的程序就可以在内存中运行了。那么字节码文件是怎样装载到JVM中的呢?中间经过了哪些步骤?常说的双亲委派模式又是怎么回事?本文主要搞清楚这些问题。 类装载流程 1、加载 加载是类装载的第一步,首先通过class文件的路径读取到二进制流,并解析二进制流将里面...阅读全文

深入理解JVM(五)——垃圾回收器

2017-08-21 09:46 by 飘扬的红领巾, 171 阅读, 收藏, 编辑
摘要: 轻松学习JVM(五)——垃圾回收器 上一篇我们介绍了常见的垃圾回收算法,不同的算法各有各的优缺点,在JVM中并不是单纯的使用某一种算法进行垃圾回收,而是将不同的垃圾回收算法包装在不同的垃圾回收器当中,用户可以根据自身的需求,使用不同的垃圾回收器,以便让自己的java程序性能到达最佳。 在介绍垃圾回收阅读全文

深入理解JVM(四)——垃圾回收算法

2017-08-18 15:30 by 飘扬的红领巾, 483 阅读, 收藏, 编辑
摘要: 我们都知道java语言与C语言最大的区别就是内存自动回收,那么JVM是怎么控制内存回收的,这篇文章将介绍JVM垃圾回收的几种算法,从而了解内存回收的基本原理。 stop the world 在介绍垃圾回收算法之前,我们需要先了解一个词“stop the world”,stop the world会在阅读全文

深入理解JVM(三)——配置参数

2017-08-15 11:10 by 飘扬的红领巾, 225 阅读, 收藏, 编辑
摘要: JVM配置参数分为三类参数: 1、跟踪参数 2、堆分配参数 3、栈分配参数 这三类参数分别用于跟踪监控JVM状态,分配堆内存以及分配栈内存。 跟踪参数 跟踪参数用于跟踪监控JVM,往往被开发人员用于JVM调优以及故障排查。 1、当发生GC时,打印GC简要信息 使用-XX:+PrintGC或-verb阅读全文

深入理解JVM(二)——内存模型、可见性、指令重排序

2017-08-14 09:16 by 飘扬的红领巾, 480 阅读, 收藏, 编辑
摘要: 上一篇我们介绍了JVM的基本运行流程以及内存结构,对JVM有了初步的认识,这篇文章我们将根据JVM的内存模型探索java当中变量的可见性以及不同的java指令在并发时可能发生的指令重排序的情况。 内存模型 首先我们思考一下一个java线程要向另外一个线程进行通信,应该怎么做,我们再把需求明确一点,一阅读全文