Hello, I'm arthinking.
指弹吉他 && 技术
2015/3/13 15:34
1、配置 1.1、安装 sudo apt-get install memcached 1.2、启动 Memcached的基本设置: -p 监听的端口 -l 连接的IP地址, 默认是本机 -d start 启动memcached服务 -d restart 重起memcached服务 -d stop|shutdown 关闭正在运行的memcached服务 -d install 安装memcached服务 -d uninstall 卸载memcached服务 -u 以的身份运行 (仅在以root运行的时候有效) -m 最大内存使用,单位MB。默认64MB -M 内存耗尽时返回错误,而不是删除项 -c 最大同时连接数,默认是1024 -f 块大小增长因子,默认是1.25 -n 最小分配空间,key+value+flags默认是48 -h 显示帮助 mixi的设置,单台: # ...
阅读(713 views+) 标签: ,
2015/3/13 15:10
有这样一个场景:使用getMulti一次性读取一个系列的所有手机100个key,请求了100万次,系统最初只有一个MC服务器,随着访问量的增加,负载加大了,于是增加了几个MC服务器,但结果负载反而更加大了。 原因是开始那100个key在一台服务器上获取,现在分不到了几MC服务器,需要访问的服务器增多了,而关键性的因素是我们用到的MC客户端memcached-client,其中的AscIIClient如下: public Map<String, Object> getMulti(String[] keys, Integer[] hashCodes, boolean asString) { if ((keys == null) || (keys.length == 0)) { if (log.isErrorEnabled()) log.error("...
阅读(604 views+) 标签: ,
2015/3/9 22:34
获取调用者信息的方法 一般的,我们可以通过堆栈信息获取调用当前方法的类名和方法名 // 通过堆栈信息获取调用当前方法的类名和方法名 String className = ""; String methodName = ""; Class clazz = null; StackTraceElement[] elements = new Throwable().getStackTrace(); for (int i = 0; i < elements.length; i++){ if (this.getClass().getName().equals(elements[i].getClassName())){ // 获取堆栈的下一个元素,就是调用者元素 // 如果想要获取当前方法所在类的信息,直接读取elements[i]就可以了 className = elements[i + 1].getClassName(); ...
阅读(611 views+) 标签: ,
2015/3/9 10:36
当我们使用富文本编辑器的时候,为了确保存储的内容没有XSS注入问题,比较安全的做法是对输入的内容进行过滤。 常见的XSS注入方式可以参考这里: https://www.owasp.org/index.php/XSS_Filter_Evasion_Cheat_Sheet Jsoup中提供给了白名单过滤的功能,但是并没有对属性进行校验,而属性中可能包含JS脚本或者是CSS注入,所以除了设置白名单的标签和属性之外,也需要对属性进行过滤。以下是一个过滤程序,允许你对属性进行自定义的过滤设置,并且允许动态的刷新白名单列表,方便在运行时增减支持从标签。 https://github.com/arthinking/java-code/tree/master/src/main/java/me/arthinki...
阅读(570 views+) 标签:
2015/3/2 9:55
1、概述 2、线程安全 2.1、Java语言中的线程安全 按照线程安全的“安全程度”由强至弱来排序,我们可以将Java语言中各种操作共享的数据分为以下5类:不可变、绝对线程安全、相对线程安全、线程建荣和线程对立。 不可变 不可变的对象一定是线程安全的。 保证对象行为不影响自己状态的途径有很多种,其中最简单的就是把对象中带有状态的变量都声明为final。 Java API中符合不可变要求的类型:String,java.lang.Number的部分子类(如Long和Double的数值包装类,BigInteger和BigDecimal等大数据类型但`AtomicInteger`和`AtomicLong`则并非不可变的)。 绝对线程安全 Java API中标注自己是线...
阅读(815 views+) 标签: ,
2015/3/1 23:57
《深入理解Java虚拟机:JVM高级特性与最佳实践(第2版)》笔记 1、概述 2、硬件的效率与一致性 基于告诉缓存的存储交互很好地解决了处理器与内存的速度矛盾,但是也为计算机系统带来了更高的复杂度,因为它引入了一个新的问题:缓存一致性。 处理器可能会对输入代码进行乱序执行优化,处理器会在计算之后将乱序执行的结果重组,保证该结果与顺序执行的结果是一致的。 3、Java内存模型 线程的工作内存中保存了被该线程使用到的变量的主内存副本拷贝,线程对变量的所有操作(读取、赋值等)都必须在工作内存中进行。 3.1、主内存与工作内存 3.2、内存间交互操作 3.3、对于volatile型...
阅读(787 views+) 标签: ,
2015/3/1 22:46
《深入理解Java虚拟机:JVM高级特性与最佳实践(第2版)》笔记 1、概述 即时编译器并不是虚拟机必需的部分。 本章提及的编译器、即时编译器都是指 HotSpot 虚拟机内的即时编译器,虚拟机也是特指 HotSpot 虚拟机。 2、HotSpot虚拟机内的即时编译器 2.1、解释器与编译器 HotSpot 虚拟机中内置了两个即时编译器,分别称为 Client Compiler 和 Server   Compiler。 HotSpot 虚拟机会根据自身版本与宿主机器的硬件性能自动选择运行模式,用户也可以使用"- client" 或"- server" 参数去强制指定虚拟机运行在 Client 模式或 Server 模式。 参数"- Xint" 强制虚拟机运行于“解释模式”( Interp...
阅读(594 views+) 标签: ,
2015/3/1 22:41
《深入理解Java虚拟机:JVM高级特性与最佳实践(第2版)》笔记 1、概述 Java语言的“编译期”是一段不确定的操作过程,可能是: 前端编译器(编译器的前端)把Java文件转换为class文件;Sun 的 Javac、 Eclipse   JDT 中的增量式编译器( ECJ)[ 1]。 后端编译器(JIT编译期 Just in time compiler)把字节码变成机器码;JIT 编译器: HotSpot   VM 的 C1、 C2 编译器。 静态编译器(AOT编译器 ahead of time compiler)直接把Java编译成本地机器代码; AOT 编译器: GNU   Compiler   for   the   Java( GCJ)[ 2]、 Excelsior JET[ 3]。 本章讨论第一类编译过程。 Javac 这类...
阅读(655 views+) 标签: ,
2015/3/1 22:35
《深入理解Java虚拟机:JVM高级特性与最佳实践(第2版)》笔记 1、概述 能通过程序进行操作的,主要是字节码生成与类加载器这两部分的功能。 2、案例分析 2.1、Tomcat:正统的类加载器架构 主流的 Java   Web 服务器,如 Tomcat、 Jetty、 WebLogic、 WebSphere 或其他笔者没有列举的服务器,都实现了自己定义的类加载器(一般都不止一个)。因为一个功能健全的 Web 服务器,要解决如下几个问题: 部署在同一个服务器上的两个 Web 应用程序所使用的 Java 类库可以实现相互隔离。 部署在同一个服务器上的两个 Web 应用程序所使用的 Java 类库可以互相共享。 服务器需要尽可能地...
阅读(449 views+) 标签: ,
2015/3/1 22:27
《深入理解Java虚拟机:JVM高级特性与最佳实践(第2版)》笔记 1、概述 物理机的执行引擎是直接建立在处理器、硬件、指令集和操作系统层面上的,而虚拟机的执行引擎则是由自己实现的,因此可以自行制定指令集与执行引擎的结构体系,并且能够执行那些不被硬件直接支持的指令集格式。 2、运行时栈帧结构 栈帧存储了方法的局部变量表、操作数栈、动态连接和方法返回地址等信息。每一个方法从调用开始至执行完成的过程,都对应着一个栈帧在虚拟机栈里面从入栈到出栈的过程。 每一个栈帧都包括了局部变量表、操作数栈、动态连接、方法返回地址和一些额外的附加信息。 对于执行引擎来说,在活...
阅读(681 views+) 标签: ,
2014/12/9 21:34
##Maven项目目录结构如下: project - src - main - java - resources - webapp - WEB-INF - classes - lib - target - project-snapshot - WEB-INF - classes - lib - classes 其中 project-snapshot就是maven编译生成的项目目录了,我们一般使用这个目录对项目进行部署,这样问题来了: 每次改动JSP文件或者Java文件,都得重新用maven编译一下,以便生成代码到该目录,有没有方便点的做法呢...
阅读(1,059 views+) 标签:
2014/12/8 8:45
《深入理解Java虚拟机:JVM高级特性与最佳实践(第2版)》笔记 1、概述 虚拟机把描述类的数据从 Class 文件加载到内存,并对数据进行校验、转换解析和初始化,最终形成可以被虚拟机直接使用的 Java 类型,这就是虚拟机的类加载机制。 Java 里天生可以动态扩展的语言特性就是依赖运行期动态加载和动态连接这个特点实现的。 2、类加载的时机 加载( Loading)、 验证( Verification)、 准备( Preparation)、 解析( Resolution)、 初始化( Initialization)、 使用( Using) 和卸载( Unloading) 7 个阶段。 其中验证、准备、解析 3 个部分统称为连接( Linking)。 加载、验证、...
阅读(627 views+) 标签: ,
2014/12/8 0:11
类从被加载到JVM内存开始,到卸载出内存,整个周期包括:加载、验证、准备、解析、初始化、使用和卸载。而虚拟机规范严格规定了有且只有五种情况必须对类进行初始化(link),这几种情况被称为对类的主动引用,其他的情况被称为被动引用(link),其中就包括调用一个类的常量,不会触发定义常量的类的初始化,这是因为常量(字符串类型或基本数据类型)在编译阶段会存入调用类的常量池中。 问题描述如下: 更新一个常量类class到服务器之后,其他引用这个常量的地方并没有做出改动,导致问题的出现。 对常量问题的思考: 一般在系统运行事情不会发生变化的东西才可以定义为常量,常量可以...
阅读(472 views+) 标签: ,
2014/12/7 23:06
《深入理解Java虚拟机:JVM高级特性与最佳实践(第2版)》笔记 1、概述 2、无关性的基石 JVM 设计者通过 JSR- 292 基本兑现了对 Java 虚拟机进行适当的扩展,以便更好地支持其他语言运行于 JVM 之上这个承诺。 Java 虚拟机不和包括 Java 在内的任何语言绑定,它只与“ Class 文件”这种特定的二进制文件格式所关联 #3、Class类文件的结构 任何一个 Class 文件都对应着唯一一个类或接口的定义信息,但反过来说,类或接口并不一定都得定义在文件里(譬如类或接口也可以通过类加载器直接生成)。 Class 文件是一组以 8 位字节为基础单位的二进制流。 根据 Java 虚拟机规范的规定, Class 文件...
阅读(520 views+) 标签: ,
2014/11/30 22:20
《深入理解Java虚拟机:JVM高级特性与最佳实践(第2版)》笔记 - 自动内存管理机制(调优案例分析与实战) 1、概述 2、案例分析 2.1、高性能硬件上的程序部署策略 一个部署问题 √ 控制 Full GC 频率的关键是看应用中绝大多数对象能否符合“朝生夕灭”的原则,即大多数对象的生存时间不应太长,尤其是不能有成批量的、长生存时间的大对象产生,这样才能保障老年代空间的稳定。 如果读者计划使用 64 位 JDK 来管理大内存,还需要考虑下面可能面临的问题:内存回收导致的长时间停顿;相同程序在 64 位 JDK 消耗的内存一般比 32 位 JDK 大,这是由于指针膨胀,以及数据类型对齐补白等因素导致的...
阅读(885 views+) 标签: ,
2014/11/26 22:31
《深入理解Java虚拟机:JVM高级特性与最佳实践(第2版)》笔记 - 自动内存管理机制(虚拟机性能监控与故障处理工具) 虚拟机性能监控与故障处理工具 1、概述 给一个系统定位问题的时候,知识、经验是关键基础,数据是依据,工具是运用知识处理数据的手段。这里说的数据包括:运行日志、异常堆栈、 GC 日志、线程快照( threaddump/ javacore 文件)、堆转储快照( heapdump/ hprof 文件)等。 2、JDK的命令行工具 如果读者在工作中需要监控运行于 JDK 1. 5 的虚拟机之上的程序,在程序启动时请添加参数"- Dcom. sun. management. jmxremote" 开启 JMX 管理功能,否则由于部分工具都是基于...
阅读(816 views+) 标签: ,
2014/11/26 11:30
《深入理解Java虚拟机:JVM高级特性与最佳实践(第2版)》笔记 - 自动内存管理机制(垃圾收集器与内存分配策略) 垃圾收集器与内存分配策略 1、概述 当需要排查各种内存溢出、内存泄漏问题时,当垃圾收集成为系统达到更高并发量的瓶颈时,我们就需要对这些“自动化”的技术实施必要的监控和调节。 其中程序计数器、虚拟机栈、本地方法栈 3 个区域随线程而生,随线程而灭; 而 Java 堆和方法区则不一样,一个接口中的多个实现类需要的内存可能不一样,一个方法中的多个分支需要的内存也可能不一样,我们只有在程序处于运行期间时才能知道会创建哪些对象。 2、对象已死吗 2.1、引用技术算法 ...
阅读(1,250 views+) 标签: ,
2014/11/12 12:15
在代码中调用了一个新的方法,发现应用里面的相关功能慢了2~3秒钟酱。查看程序并没有特殊的处理,只是多了几条sql,新增了几个字段。那末,我们来抓一下慢语句看看,是否有优化的空间。 俗话说的好,在IT娱乐圈混的,怎能不学会分析SQL日志进行优化呢,首先来介绍一下MySQL中的慢语句分析的方法。 开启慢查询日志 在mysql会话中输入如下命令查看慢查询的配置: show variables like "%slow%"; log_slow_queries 这个就是慢查询的配置啦,如果没有需要在my.cnf里面配置一下喔。 分析日志的工具 mysqldumpslow 用法参考 http://dev.mysql.com/doc/refman/5.1/en/mysqldumpslow....
阅读(834 views+) 标签: ,
2014/11/11 21:28
《深入理解Java虚拟机:JVM高级特性与最佳实践(第2版)》笔记 - 自动内存管理机制(Java内存区域与内存溢出异常) 1、Java内存区域与内存溢出异常 1.1、概述 1.2、运行时数据区域 Java 虚拟机运行时数据区 1.2.1、程序计数器 由于 Java 虚拟机的多线程是通过线程轮流切换并分配处理器执行时间的方式来实现的,在任何一个确定的时刻,一个处理器(对于多核处理器来说是一个内核)都只会执行一条线程中的指令。因此,为了线程切换后能恢复到正确的执行位置,每条线程都需要有一个独立的程序计数器,各条线程之间计数器互不影响,独-立存储,我们称这类内存区域为“线程私有”的内存。 如...
阅读(1,432 views+) 标签: ,
2014/11/10 23:02
小哥最近在分析项目中的内存泄露情况,使用了Eclipse Memory Analyzer,移步到这里下载最新版本: http://www.eclipse.org/mat/ 我们知道,不同版本的虚拟机和JDK版本,垃圾回收机制和内存空间布局都是有所差别的,我使用的是这个版本的JDK java version "1.6.0_26" Java(TM) SE Runtime Environment (build 1.6.0_26-b03) Java HotSpot(TM) Client VM (build 20.1-b02, mixed mode, sharing) 1、下面监控一下我开发环境下的Resin服务器: 首先,运行JDK bin目录下的jconsole.exe文件,链接到Resin服务器: 进入之后,就可以查看到堆内存,类,CPU的使用情况了。 细心的读者...
阅读(1,185 views+) 标签: ,
关于IT宅 文章归档

IT宅中的文章除了标题注明转载或有特别说明的文章,均为IT宅的技术知识总结,学习笔记或随笔。如果喜欢,请使用文章下面提供的分享组件。转载请注明出处并加入文章的原链接。 感谢大家的支持。

联系我们:admin@itzhai.com

Theme by arthinking. Copyright © 2011-2015 IT宅.com 保留所有权利.