2017-12-06 17:02:02 |  0 Comments

jvm系列(一)之内存模型

自从接触java以来,一直就有学习java虚拟机的内存模型,但是从来都没有深入系统的了解,对内存模型的认识还比较模糊,今天恰巧有看到相关的文章,觉得还是需要整理一下 己的认知才能有所收获。 # JVM内存结构 Java内存模型是指Java虚拟机的内存模型,我们来看下Java内存模型的图片: ![](https://leanote.com/api/file/getImage?fileId=59d
 2017-12-06 17:02:02 |  0 Comments

JVM系列(二)之类加载

# 什么是类的加载 类加载是指将源代码编译后的.class加载到内存中初始化待程序使用的过程,类加载过程会做两件事,一是将类的描述信息加载至方法区,二是在堆内存区生产java.lang.Class对象的实例
 2017-12-06 17:02:02 |  0 Comments

JVM系列(三)之GC

#什么是GC Java GC(Garbage Collection,垃圾收集,垃圾回收)机制,是Java与C++/C的主要区别之一,作为Java开发者,一般不需要专门编写内存回收和垃圾清理代码,对内存泄露和溢出的问题,也不需要像C程序员那样战战兢兢。这是因为在Java虚拟机中,存在自动内存管理和垃圾清扫机制。概括地说,该机制对JVM(Java Virtual Machine)中的内存进行标记,并
 2017-12-06 17:02:02 |  0 Comments

JVM系列(四)之GC调优

# JVM内存参数调优 ## 为什么要GC调优?   或者说的更确切一些,对于基于Java的服务,是否有必要优化GC?应该说,对于所有的基于Java的服务,并不总是需要进行GC优化,但当你的系统时常报了内存溢出或者java程序运行缓慢时,优先排查是否是程序导致的内存泄漏,再看你是否需要JVM参数调优。   想一下进行GC优化的最根本原因,垃圾收集器清除在Java程序中创建的对象,GC执行的次数
 2017-12-06 17:02:02 |  0 Comments

jvm系列(四):jvm调优-命令篇

运用jvm自带的命令可以方便的在生产监控和打印堆栈的日志信息帮忙我们来定位问题!虽然jvm调优成熟的工具已经有很多:jconsole、大名鼎鼎的VisualVM,IBM的Memory Analyzer等等,但是在生产环境出现问题的时候,一方面工具的使用会有所限制,另一方面喜欢装X的我们,总喜欢在出现问题的时候在终端输入一些命令来解决。所有的工具几乎都是依赖于jdk的接口和底层的这些命令,研究这些
 2017-12-06 17:02:02 |  0 Comments

记一笔JVM线上调优过程

最近一个测试环境的api-gateway一直报请求超时,并且未发现报错异常信息,于是开始排查是否是JVM参数不对导致用户线程挂起。 排查过程如下: 1. 查看目标机器的进程pid ``` [baibei@CBEC-UAT-1 uat]$ jps -l 27723 com.baibei.apigateway.Application ``` 2. 查看jvm内存使用情况 ``` [baibei@C
 2017-12-06 17:02:02 |  0 Comments

关于volatile关键字原理解析

volatile这个关键字我们在实际开发过程中,或多或少都使用过,但是对于其背后的实现原理机制还是不够清晰,接下来满满梳理一番。 ## 我们来看一段代码 ``` i = i + 1; ``` 一个简单的对i变量的递增操作,在单线程执行的情况下,没有什么问题,但是在多线程情况下,结果就会有问题了。原因是因为计算机的内存模型为每个线程分配了CPU高速缓存,来加快CPU的处理速度。 假如现i的初始
 2017-12-06 17:02:02 |  0 Comments

JVM系列之(五)之class编译

java反编译命令 ``` javap -c -verbose xxx.class ```
 2017-11-16 19:14:15 |  0 Comments

Spring Cloud Stream 使用笔记

#Spring Cloud Stream Spring 已经对JMS中间件做了很多封装,比如Spring对ampq队列协议的封装`spring-rabbit.jar``,以及企业集成的实现`Spring Integration`(解决服务间的异步通讯交互问题),而Spring Cloud Stream是对针对消息中间件的进一步封装,Stream已经支持Kafka/Rabbit MQ/Redis/
 2017-11-06 20:29:23 |  0 Comments

Spring Cloud微服务实践

# 什么是Spring Cloud 看完《微服务设计》后,算是补上了自己在服务化这块的理论知识,在业界,一般有两种微服务的实践方法:基于dubbo的微服务架构、基于Spring Cloud的微服务架构。从概念上来讲,Dubbo和Spring Cloud并不能放在一起对比,因为Dubbo仅仅是一个RPC框架,实现Java程序的远程调用,实施服务化的中间件则需要自己开发;而Spring Cloud则
 2017-07-11 17:33:20 |  0 Comments

Mysql 时间字段的ON UPDATE CURRENT_TIMESTAMP

**最近项目中mysql 由于表中时间字段中不小心使用了ON UPDATE CURRENT_TIMESTAMP,导致表中的任何一个字段更新,时间字段都会更这个时间** ![](https://leanote.com/api/file/getImage?fileId=59649b6dab6441206700189c) 使用以下语句更新掉就解决了,在此记一笔 ``` ALTER TABLE `t_t
 2017-07-04 13:47:54 |  0 Comments

Linux 查找日志常用命令和技巧

#1. tail & head ``` #查询最后100行日志 tail -n 100 info.log 查询从100行之后的所有日志 tail -n +100 info.log 查询日志文件中的头10行日志; head -n 10 info.log 查询日志文件除了最后10行的其他所有日志; head -n -10 info.log ``` #2. 场景一:查找关键字附近的日志 ##1 .获取关键字的行号 ``` #-n 显示行号 cat -n test.log |grep "关键字" ``` ![](https://leanote.com/api/file/get
 2017-06-13 12:49:47 |  0 Comments

Spring boot 配置自定义Json类型转换

## 项目中遇到一个问题,就是由于我们数据库表ID使用分布式唯一算法生成的Long类型,所以有很长(19位数字),导致转成json传至前端js使用时报错,因为js的数字类型最大只能表示15个数字长度,见[Js 的number对象说明](http://www.w3school.com.cn/js/js_obj_number.asp) ## 解决方案:使用Spring自定义的Json序列化,将过长
 2017-06-12 15:37:39 |  0 Comments

spring boot + redis session 配置

#最近比较忙,都没忘记整理写文章了,刚好想起来,记录一下spring boot 使用xml方式配置redis session的方法,关于使用xml配置还是使用spring注解方式来配置就不在这里讨论了,我觉得看个人喜好吧,我是觉得配置相关还是抽离出来到配置文件中比较好一点。废话不多说,看配置 # 1.在pom.xml中引入jar ``` org.springfra
 2017-04-07 18:11:15 |  1 Comments

git重命名的坑

如果使用git命令进行仅涉及大小写的重命名,git 默认是把你的动作忽略的,所以当你删掉本地代码,重新pull代码时,你会发现文件还是重命名之前的,神奇吧,记下这个坑,等着你们踩着坑来这看吧,坏笑/ 解决方法如下: - 设置git库为大小写敏感(不建议) ``` git config core.ignorecase false ``` 用这种方法进行重命名,用git status就可以识别
 2017-04-06 10:58:13 |  0 Comments

使用Maven命令指定上传打包到私库

我们一般在pom.xml中加入`distributionManagement` ``` internal.repo MyCo Internal Repository Host to Company Repository ``` 来指定setting.xml中的server私库地址,然后通过`mvn clean i
 2017-03-29 13:51:21 |  0 Comments

Spring Cloud Eureka Server注册服务器高可用配置

# Eureka Server的高可用 Eureka Server除了单点运行之外,还可以通过运行多个实例,并进行互相注册的方式来实现高可用的部署,所以我们只需要将Eureke Server配置其他可用的serviceUrl就能实现高可用部署。 下面我们来构建一个三节点的服务注册中心。 ## 使用yml方式配置 在Eureka Server中配置如下 ``` spring: applic
 2017-03-29 13:51:21 |  0 Comments

Spring Cloud 配置中心Config Server

Spring Config Server是Spring Cloud的子项目,它提供配置集中管理方案 #使用 ## 在pom.xml加入 ``` org.springframework.cloud spring-cloud-starter-parent Camden.SR6
 2017-03-29 13:51:21 |  0 Comments

Spring Cloud服务注册发现之Eureka

#Eureka Server ## 在Spring Boot项目的pom.xml中加入`spring-cloud-starter-eureka-server` 使用Spring Cloud需要在pom.xml中加入Spring Cloud的父级引用,让Spring帮我们管理依赖版本 ``` org.springframework.clou
 2017-03-29 13:51:21 |  0 Comments

使用Spring Cloud Feign作为HTTP客户端调用远程HTTP服务

#什么是Feign Feign是一种声明式、模板化的HTTP客户端。在Spring Cloud中使用Feign, 我们可以做到使用HTTP请求远程服务时能与调用本地方法一样的编码体验,开发者完全感知不到这是远程方法,更感知不到这是个HTTP请求。 #使用Feign ## 在service的pom.xml中加入 ``` org.springframe
Title - Artist
0:00