参考地址 http://wiki.apache.org/cassandra/FAQ#working_with_timeuuid_in_java 下载一个包 http://johannburkard.de.../software/uuid/ 代码示例: 代码import java.util.List; import org.apache.thrift.transport.TTransport; import ...; import org.apache.cassandra.thrift.Column; import org.apache.cassandra.thrift.ColumnOrSuperColumn;...import org.apache.cassandra.thrift.ColumnParent; import org.apache.cassandra.thrift.ColumnPath; import... getTimeUUID() { return java.util.UUID.fromString(new com.eaio.uuid.UUID().toString());
接着上篇博客,我们来谈谈java操作cassandra; 上篇博客的环境:jdk1.7 + python2.7.10 + cassandra2.2.8; 由于2.2.8没有对应的驱动文档,那么我们就用...3.0的驱动文档,而驱动则用2.1.10.3版本; 驱动文档:http://docs.datastax.com/en/developer/java-driver/3.0/manual/ 一、驱动下载...; import java.util.concurrent.locks.Lock; import java.util.concurrent.locks.ReentrantLock; import com.datastax.driver.core.Cluster...4、 类似jdbc那样使用预编译占位符 http://docs.datastax.com/en/developer/java-driver/3.0/manual/statements/prepared...实现cassandra的增删改查 基本操作demo
文档地址 http://wiki.apache.org/cassandra/API06,实现了绝大部分示例 代码import java.io.UnsupportedEncodingException;...import java.util.ArrayList; import java.util.HashMap; import java.util.List; import java.util.Map; import... org.apache.cassandra.thrift.Cassandra; import org.apache.cassandra.thrift.Column; import org.apache.cassandra.thrift.ColumnOrSuperColumn... org.apache.cassandra.thrift.ConsistencyLevel; import org.apache.cassandra.thrift.Deletion; import org.apache.cassandra.thrift.InvalidRequestException...; import org.apache.cassandra.thrift.KeyRange; import org.apache.cassandra.thrift.KeySlice; import org.apache.cassandra.thrift.Mutation
; 7 import java.net.InetAddress; 8 import java.sql.Timestamp; 9 import java.util.Date; 10 import...java.util.HashMap; 11 import java.util.Iterator; 12 import java.util.List; 13 import java.util.Map...com.datastax.driver.core.Row; 30 import com.google.common.collect.Maps; 31 32 /** 33 * function: cassandra...} 495 496 if (value == null) { 497 log("Column '{}' Type({}) get cassandra...return DataType.varint(); 665 } 666 667 log("Class '{}' unknow DataType in cassandra
接着上篇博客,我们来谈谈java操作cassandra分页,需要注意的是这个分页与我们平时所做的页面分页是不同的,具体有啥不同,大家耐着性子往下看。 ...具体我们来看下代码,下例是模拟页面分页的请求,实现遍历teacher表中的全部记录: 接口: import java.util.Map; import com.datastax.driver.core.PagingState...interface ICassandraPage { Map page(PagingState pagingState); } 主体代码: import java.util.ArrayList...; import java.util.HashMap; import java.util.List; import java.util.Map; import com.datastax.driver.core.PagingState...在我的项目中,索引修复用到了cassandra的分页,场景如下:cassandra的表不建二级索引,用elasticsearch实现cassandra表的二级索引,那么就会涉及到索引的一致性修复的问题,
Java对象头 锁存在Java对象头里。如果对象是数组类型,则虚拟机用3个Word(字宽)存储对象头,如果对象是非数组类型,则用2字宽存储对象头。在32位虚拟机中,一字宽等于四字节,即32bit。...Java SE1.6为了减少获得锁和释放锁所带来的性能消耗,引入了“偏向锁”和“轻量级锁”,所以在Java SE1.6里锁一共有四种状态,无锁状态,偏向锁状态,轻量级锁状态和重量级锁状态,它会随着竞争情况逐渐升级...另外,JVM对那种会有多线程加锁,但不存在锁竞争的情况也做了优化,听起来比较拗口,但在现实应用中确实是可能出现这种情况,因为线程之前除了互斥之外也可能发生同步关系,被同步的两个线程(一前一后)对共享对象锁的竞争很可能是没有冲突的...偏向锁的设置 关闭偏向锁:偏向锁在Java 6和Java 7里是默认启用的,但是它在应用程序启动几秒钟之后才激活,如有必要可以使用JVM参数来关闭延迟-XX:BiasedLockingStartupDelay...经过调查,目前只是通过汇编暂停了几个CPU周期,除了自旋周期选择,HotSpot还进行许多其他的自旋优化策略,具体如下: 如果平均负载小于CPUs则一直自旋 如果有超过(CPUs/2)个线程正在自旋,则后来线程直接阻塞
这里写目录标题 第一章:Java中代码优化的30个小技巧 1.用String.format拼接字符串 不知道你有没有拼接过字符串,特别是那种有多个参数,字符串比较长的情况。...at java.util.AbstractList.add(AbstractList.java:148) at java.util.AbstractList.add(AbstractList.java...说实话,Java代码优化是一个比较大的话题,它里面可以优化的点非常多,我没办法一一列举完。在这里只能抛砖引玉,介绍一下比较常见的知识点,更全面的内容,需要小伙伴们自己去思考和探索。...2. sql优化 如果优化了索引之后,也没啥效果。 接下来试着优化一下sql语句,因为它的改造成本相对于java代码来说也要小得多。...15 索引优化 sql优化当中,有一个非常重要的内容就是:索引优化。 很多时候sql语句,走了索引,和没有走索引,执行效率差别很大。所以索引优化被作为sql优化的首选。
有必要优化GC吗? 确切的说是 基于Java的应用一定需要进行GC优化吗?...我认为并非所有基于Java的应用都需要进行GC优化,例如基于Java的系统有如下参数或行为: 已经通过-Xms 和 -Xmx 指定了内存大小 包含了 -server 参数 系统中未出现 超时 等日志 换句话说...但是有件事要铭记于心:GC优化是你最后的手段。 思考下GC优化的根本原因:Java中创建的对象由垃圾收集器来清理,同时待清理对象的数量和各类GC的执行次数又和创建对象总数量成正比。...GC优化的步骤 GC优化过程与一般的性能优化类似,下面是我进行GC优化的步骤。 监控GC状态 你需要监控和检查运行中系统的GC状态,监控方式请参考 如何监控Java GC 。...但是,如果你已经分配了10G Java内存,而且没有办法降低内存大小的话,就没办法进行GC优化了。在GC优化之前,你需要思考下为什么需要分配这么大的内存。
代码优化,一个很重要的课题。可能有些人觉得没用,一些细小的地方有什么好修改的,改与不改对于代码的运行效率有什么影响呢?这个问题我是这么考虑的,就像大海里面的鲸鱼一样,它吃一条小虾米有用吗?...代码优化也是一样,如果项目着眼于尽快无BUG上线,那么此时可以抓大放小,代码的细节可以不精打细磨;但是如果有足够的时间开发、维护代码,这时候就必须考虑每个可以优化的细节了,一个一个细小的优化点累积起来,...代码优化的目标是 减小代码的体积 提高代码运行的效率 代码优化细节 1、尽量指定类、方法的final修饰符 带有final修饰符的类是不可派生的。...在Java核心API中,有许多应用final的例子,例如java.lang.String,整个类都是final的。...Java编译器会寻找机会内联所有的final方法,内联对于提升Java运行效率作用重大,具体参见Java运行期优化。此举能够使性能平均提高50%。
java的反射机制属实强大,能解决好些问题 在接手别人写的代码的时候,有一个bean类的get方法特别low,我都看不下去 重复代码写五遍,我都觉得太不合理。之后将其中代码抽取出来修改了下。
在 Java 核心 API 中,有许多应用 final 的例子,例如 java.lang.String,整个类都是 final 的。...Java 编译器会寻找机会内联所有的 final 方法,内联对于提升 Java 运行效率作用重大,具体可以查阅 Java 运行期优化相关资料,此举能够使性能平均提高 50%。 尽量重用对象。...由于 Java 虚拟机不仅要花时间生成对象,以后可能还需要花时间对这些对象进行垃圾回收和处理,因此生成过多的对象将会给程序的性能带来很大的影响。 尽可能使用局部变量。...这个肯定大家都没有疑问的,性能优化的实现而已。 乘法和除法使用移位操作。...不捕获 Java 类库中定义的继承自 RuntimeException 的运行时异常类。
主要从以下两个方面进行了优化,大大提高了网站访问速度: (1)坑爹的Hibernate,from查询。 虽然博主早就明白数据库查询的时候,坚决避免select *。
本文综合了各种Java性能优化的研究成果,涵盖从JDK到Java集合使用、场景用例到和工具。 1. 如果在静态构造器中有繁重的计算,也就是耗费CPU的逻辑代码,请检查其运行时间是否过度?...不要在多线程中共享一个 java.util.Random实例,将其包装在ThreadLocal中,Java7中使用java.util.concurrent.ThreadLocalRandom替代java.util.Random...如果你希望有快速的Base64编码器,使用Java 8的 java.util.Base64 14. 不要使用exception ,每个exception 启动需要1毫秒 15....如果要使用压缩,考虑使用LZ4(https://github.com/lz4/lz4-java) 17. 使用ByteBuffer替代 ByteArrayOutputStream。 18....22.Java 8中使用G1垃圾回收机制时,使用减少字符串重复配置: -XX:+UseG1GC -XX:+UseStringDeduplication。
在 Java 6 中,我们唯一可以做的优化就是通过增加 PermGen 内存空间来提供更多的存储。...可以通过在 JVM 中使用参数来实现:-XX:MaxPermSize=1G从 Java 7 开始,我们可以为 String Pool 指定更多的参数来扩展和减少 String Pool 的大小。...PrintStringTableStatistics如果我们希望增加 String Pool 的 buckets 大小,我们可以使用 JVM 提供的 StringTableSize 参数选项:-XX:StringTableSize=4901在 Java...但是这个值在最近的一些 Java 版本更新中有了改变,从 7u40 到 Java 11 String Pool 的大小为 60013 buckets,在 Java 11 的后续版本中,这个值增加到了 65536...https://www.ossez.com/t/java-string-pool/14017
之前写过一些java性能优化的总结, 但是没有依照具体的实例分析,看起来比较空洞, 此篇我将依照在珍爱网的阅读和 改造别人写的代码的过程中遇到的一些 比较典型的可调优的例子, 接下来将一一做分析对比和优化...一个幻觉,我明明初始化了一个空list, 为什么还报NullPointerException, 因为第二步中dubbo调用返回结果可能会 为null,所以第一步的初始化完全没有 意义(刚new完就被回收)优化结果...在高并发场景下数据库根本扛不住 这样的操作,尽管只是查询解决方案: 批量操作,将每次分页查询出来的10条 数据中的参数装配成列表,交给服务 一次性查询出来10条结果,然后再在上述 代码中循环装配结果信息(java...内存操作 性能和速度远远强于网络传输和数据库IO), 优化完后并不是避免了所有IO和dubbo服务调用, 有原来的40次变成了4次,在并发环境下 和网络不好的场景下性能提升肯定是数量级的 3.无效的返回类型...解决方案:所以,既然是数据库, 那么就让数据库做他最擅长的 存储和查询吧,计算这种事情还是 交给java程序比较好, 另外,在大部分项目中,数据库和 java服务相比,数据库属于稀缺资源, 我们可以对一个
java面试(3)SQL优化 ?...对查询进行优化,要尽量避免全表扫描,首先应考虑在 where 及 order by 涉及的列上建立索引。...任何在where子句中使用is null或is not null的语句优化器是不允许使用索引的。...一般情况下,当你IN中的条件太多,或是无法估计时,优化器倾向于全表扫描。当IN的条件少时,如果优化器认为,INDEX SEEK可以带来好处时,照样会走索引的。...每一个sql都是一个数据库连接 查询语句执行顺序(只在基于规则的优化器中有效): from子句:执行顺序从后向前,从右向左。
优化前每个文件预计在80s左右,在优化完后,每个文件只需要花费9s左右即可完成。 优化手段 1. 尽量不要使用Pattern 由于正则表达式会在遍历字符串的时候进行回溯导致匹配之间过长。...优化方案: 如果有标准格式或者分隔符,例如[...],....#....则尽量使用字符遍历以及StringBuilder.append来组合字符串。 2....优化方案: 通过SimpleDateFormatter.parse("yyy-mm-dd")将当天的时间戳计算,并且将转换结果缓存起来 通过字符匹配,以及char - '0'来转换成数字,通过乘法来得到具体的数值...优化方案: 尽量使用字符串遍历,得到起始与结束的偏移量,通过String(charArray,offset , length)来构建字符串,效率更高 4....SimpleDateFormatter是非线程安全的 SimpleDateFormatter是非线程安全的,需要自己做同步 优化方案 : 尽量使用ThreadLocal保存SimpleDateFormatter
在深入理解Java虚拟机一书中,说到了锁的优化,其中主要说了自旋锁,锁消除,锁粗化,轻量级锁和偏向锁。结合书籍加上一些自己的看法写下这篇文章,希望通过这篇文章,让我们对于锁有一个新的认知。...偏向锁也是JDK 1.6中引入的一项锁优化,它的目的是消除数据在无竞争情况下的同步原语,进一步提高程序的运行性能。...答案是有许多同步措施并不是程序员自己加入的,同步的代码在Java程序中的普遍程度也许超过了大部分读者的想象。...05 — 偏向锁 偏向锁也是JDK 1.6中引入的一项锁优化,它的目的是消除数据在无竞争情况下的同步原语,进一步提高程序的运行性能。...在具体问题具体分析的前提下,有时候使用参数-XX:-UseBiasedLocking来禁止偏向锁优化反而可以提升性能。
利用多核技术,可以有效发挥硬件的能力,提升吞吐量,对于 Java 程序,可以实现并发垃圾收集。但是 Java 利用多核技术也带来了一些问题,主要是多线程共享内存引起了。...所以区别于普通的优化,针对多核平台,需要进行一些特殊的优化。 代码优化 线程数要大于等于核数 如果使用多线程,只有运行的线程数比核数大,才有可能榨干 CPU 资源,否则会有若干核闲置。...相比之下使用 Java 提供的 Lock 对象,性能更高一些。但是到了 Java1.6,发生了变化。...synchronize 在语义上很清晰,可以进行很多优化,有适应自旋,锁消除,锁粗化,轻量级锁,偏向锁等等。导致在 Java1.6 上 synchronize 的性能并不比 Lock 差。...激进优化特性 在 Java1.6 中,激进优化(AggressiveOpts)是默认开启的。激进优化是一般有一些下一个版本才会发布的优化选项。但是有可能造成不稳定。
二、简要介绍 HTTP协议可能是现在Internet上使用得最多、最重要的协议了,越来越多的Java应用程序需要直接通过HTTP协议来访问网络资源。...System.out.println(new String(responseBody)); 下面是程序的完整代码: package test; import java.io.IOException;...GetMethod getMethod = new GetMethod("your url"); 运行该程序可能出现的问题: 1.抛出异常java net.SocketException: Algorithm...后面加入security.provider.3=com.ibm.jsse.IBMJSSEProvider 2.抛出异常java net.SocketException: SSL implementation...出现这个异常可能是你没有把ibmjsse.jar拷贝到java-home>\lib\ext\目录下。