| 2016/10/15 | J2EE | 被围观 1,301 views+
1、使用kryo序列化 1.1、先升级消费者 dubbo服务接口新增返回值和方法,消费者先升级,调用服务报错: Caused by: com.alibaba.dubbo.remoting.RemotingException: Fail to decode request due to: RpcInvocation [methodName=dataGrid, parameterTypes=[class com.xxx.ProductInfoDTO, null], arguments=null, attachments={dubbo=2.8.4, input=463, path=com.xxx.product.ProductService, version=0.0.0}] at com.alibaba.dubbo.remoting.exchange.support.DefaultFuture.returnFromResponse(DefaultFuture.java:190) ~[dubbo-2.8.4.jar:2.8.4] at com.alibaba.dubbo.remoting.exchan...
| 2015/3/13 | J2EE | 被围观 3,446 views+
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的设置,单台: # ...
| 2015/3/13 | J2EE | 被围观 2,826 views+
有这样一个场景:使用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("...
| 2015/3/9 | J2EE | 被围观 3,991 views+
获取调用者信息的方法 一般的,我们可以通过堆栈信息获取调用当前方法的类名和方法名 // 通过堆栈信息获取调用当前方法的类名和方法名 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(); ...
| 2015/3/9 | J2EE | 被围观 2,672 views+
当我们使用富文本编辑器的时候,为了确保存储的内容没有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...
| 2015/3/2 | J2EE | 被围观 3,327 views+
1、概述 2、线程安全 2.1、Java语言中的线程安全 按照线程安全的“安全程度”由强至弱来排序,我们可以将Java语言中各种操作共享的数据分为以下5类:不可变、绝对线程安全、相对线程安全、线程建荣和线程对立。 不可变 不可变的对象一定是线程安全的。 保证对象行为不影响自己状态的途径有很多种,其中最简单的就是把对象中带有状态的变量都声明为final。 Java API中符合不可变要求的类型:String,java.lang.Number的部分子类(如Long和Double的数值包装类,BigInteger和BigDecimal等大数据类型但`AtomicInteger`和`AtomicLong`则并非不可变的)。 绝对线程安全 Java API中标注自己是线...
,
| 2015/3/1 | J2EE | 被围观 3,093 views+
《深入理解Java虚拟机:JVM高级特性与最佳实践(第2版)》笔记 1、概述 2、硬件的效率与一致性 基于告诉缓存的存储交互很好地解决了处理器与内存的速度矛盾,但是也为计算机系统带来了更高的复杂度,因为它引入了一个新的问题:缓存一致性。 处理器可能会对输入代码进行乱序执行优化,处理器会在计算之后将乱序执行的结果重组,保证该结果与顺序执行的结果是一致的。 3、Java内存模型 线程的工作内存中保存了被该线程使用到的变量的主内存副本拷贝,线程对变量的所有操作(读取、赋值等)都必须在工作内存中进行。 3.1、主内存与工作内存 3.2、内存间交互操作 3.3、对于volatile型...
,
| 2015/3/1 | J2EE | 被围观 2,468 views+
《深入理解Java虚拟机:JVM高级特性与最佳实践(第2版)》笔记 1、概述 即时编译器并不是虚拟机必需的部分。 本章提及的编译器、即时编译器都是指 HotSpot 虚拟机内的即时编译器,虚拟机也是特指 HotSpot 虚拟机。 2、HotSpot虚拟机内的即时编译器 2.1、解释器与编译器 HotSpot 虚拟机中内置了两个即时编译器,分别称为 Client Compiler 和 Server   Compiler。 HotSpot 虚拟机会根据自身版本与宿主机器的硬件性能自动选择运行模式,用户也可以使用"- client" 或"- server" 参数去强制指定虚拟机运行在 Client 模式或 Server 模式。 参数"- Xint" 强制虚拟机运行于“解释模式”( Interp...
,
| 2015/3/1 | J2EE | 被围观 2,230 views+
《深入理解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 这类...
,
| 2015/3/1 | J2EE | 被围观 2,045 views+
《深入理解Java虚拟机:JVM高级特性与最佳实践(第2版)》笔记 1、概述 物理机的执行引擎是直接建立在处理器、硬件、指令集和操作系统层面上的,而虚拟机的执行引擎则是由自己实现的,因此可以自行制定指令集与执行引擎的结构体系,并且能够执行那些不被硬件直接支持的指令集格式。 2、运行时栈帧结构 栈帧存储了方法的局部变量表、操作数栈、动态连接和方法返回地址等信息。每一个方法从调用开始至执行完成的过程,都对应着一个栈帧在虚拟机栈里面从入栈到出栈的过程。 每一个栈帧都包括了局部变量表、操作数栈、动态连接、方法返回地址和一些额外的附加信息。 对于执行引擎来说,在活...
,
随机文章 本月热门 热评
1 jQuery上传插件Uploadify的使用例子和相关资料 2012/1/11
2 文件管理-外存分配方式 目录管理 存储空间管理 2011/6/30
3 我眼中的工程师文化 2012/12/26
4 jQuery中使用ajax对表单数据进行异步验证 2011/5/13
5 NodeJS学习笔记 – 入门简介 2013/10/9
6 【转】在危机的边缘上 马斯克如何看待失败? 2013/11/4
友情推荐 更多
破博客 文官洗碗安天下,武将打怪定乾坤。多么美好的年代,思之令人泪落。
Mr.5's Life 白天是一名程序员,晚上就是个有抱负的探索者
行知-追寻技术之美 关注大数据,分布式系统
我爱编程 编程成长轨迹
Cynthia's Blog 学习笔记 知识总结 思考感悟
 
猜您喜欢
关于IT宅 文章归档

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

联系我们:admin@itzhai.com

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