摘要:
一、Redis Client介绍1.1、简介Jedis Client是Redis官网推荐的一个面向java客户端,库文件实现了对各类API进行封装调用。Jedis源码工程地址:https://github.com/xetorthio/jedis1.2、使用Redis Client最好选用与服务端对应... 阅读全文
posted @ 2016-01-26 17:32
开发者里程碑
阅读(896)
评论(0)
推荐(0)
摘要:
开始在 Java 中使用 Redis 前, 我们需要确保已经安装了 redis 服务及 Java redis 驱动,且你的机器上能正常使用 Java。(1)Java的安装配置可以参考我们的Java开发环境配置(2)安装了 redis 服务;请参考:Windows环境下使用Redis缓存工具的图文详细... 阅读全文
posted @ 2016-01-26 16:43
开发者里程碑
阅读(307)
评论(0)
推荐(0)
摘要:
一、简介 redis是一个key-value存储系统。和Memcached类似,它支持存储的value类型相对更多,包括string(字符串)、list(链表)、set(集合)和zset(有序集合)。 这些数据类型都支持push/pop、add/remove及取交集并集和差集及更丰富的操作,... 阅读全文
posted @ 2016-01-26 16:42
开发者里程碑
阅读(599)
评论(0)
推荐(0)
摘要:
阅读全文
posted @ 2016-01-26 14:08
开发者里程碑
阅读(122)
评论(0)
推荐(0)
摘要:
用Redis构建分布式锁在不同进程需要互斥地访问共享资源时,分布式锁是一种非常有用的技术手段。 有很多三方库和文章描述如何用Redis实现一个分布式锁管理器,但是这些库实现的方式差别很大,而且很多简单的实现其实只需采用稍微增加一点复杂的设计就可以获得更好的可靠性。这篇文章的目的就是尝试提出一种官方权... 阅读全文
posted @ 2016-01-26 13:54
开发者里程碑
阅读(267)
评论(0)
推荐(0)
摘要:
Java NIO 管道是2个线程之间的单向数据连接。Pipe有一个source通道和一个sink通道。数据会被写到sink通道,从source通道读取。这里是Pipe原理的图示:创建管道通过Pipe.open()方法打开管道。例如:Pipe pipe = Pipe.open();向管道写数据要向管道... 阅读全文
posted @ 2016-01-26 13:51
开发者里程碑
阅读(191)
评论(0)
推荐(0)
摘要:
Java NIO中的 ServerSocketChannel 是一个可以监听新进来的TCP连接的通道, 就像标准IO中的ServerSocket一样。ServerSocketChannel类在 java.nio.channels包中。这里有个例子:ServerSocketChannel server... 阅读全文
posted @ 2016-01-26 13:50
开发者里程碑
阅读(233)
评论(0)
推荐(0)
摘要:
Java NIO中的DatagramChannel是一个能收发UDP包的通道。因为UDP是无连接的网络协议,所以不能像其它通道那样读取和写入。它发送和接收的是数据包。打开 DatagramChannel下面是 DatagramChannel 的打开方式:DatagramChannel channel... 阅读全文
posted @ 2016-01-26 13:50
开发者里程碑
阅读(224)
评论(0)
推荐(0)
摘要:
Java NIO中的FileChannel是一个连接到文件的通道。可以通过文件通道读写文件。FileChannel无法设置为非阻塞模式,它总是运行在阻塞模式下。打开FileChannel在使用FileChannel之前,必须先打开它。但是,我们无法直接打开一个FileChannel,需要通过使用一个... 阅读全文
posted @ 2016-01-26 13:49
开发者里程碑
阅读(218)
评论(0)
推荐(0)
摘要:
Java NIO中的SocketChannel是一个连接到TCP网络套接字的通道。可以通过以下2种方式创建SocketChannel:打开一个SocketChannel并连接到互联网上的某台服务器。一个新连接到达ServerSocketChannel时,会创建一个SocketChannel。打开 S... 阅读全文
posted @ 2016-01-26 13:49
开发者里程碑
阅读(262)
评论(0)
推荐(0)
摘要:
Selector(选择器)是Java NIO中能够检测一到多个NIO通道,并能够知晓通道是否为诸如读写事件做好准备的组件。这样,一个单独的线程可以管理多个channel,从而管理多个网络连接。下面是本文所涉及到的主题列表:为什么使用Selector?Selector的创建向Selector注册通道S... 阅读全文
posted @ 2016-01-26 13:47
开发者里程碑
阅读(241)
评论(0)
推荐(0)
摘要:
在Java NIO中,如果两个通道中有一个是FileChannel,那你可以直接将数据从一个channel(译者注:channel中文常译作通道)传输到另外一个channel。transferFrom()FileChannel的transferFrom()方法可以将数据从源通道传输到FileChan... 阅读全文
posted @ 2016-01-26 13:46
开发者里程碑
阅读(273)
评论(0)
推荐(0)
摘要:
Java NIO开始支持scatter/gather,scatter/gather用于描述从Channel(译者注:Channel在中文经常翻译为通道)中读取或者写入到Channel的操作。分散(scatter)从Channel中读取是指在读操作时将读取的数据写入多个buffer中。因此,Chann... 阅读全文
posted @ 2016-01-26 13:46
开发者里程碑
阅读(198)
评论(0)
推荐(0)
摘要:
Java NIO中的Buffer用于和NIO通道进行交互。如你所知,数据是从通道读入缓冲区,从缓冲区写入到通道中的。缓冲区本质上是一块可以写入数据,然后可以从中读取数据的内存。这块内存被包装成NIO Buffer对象,并提供了一组方法,用来方便的访问该块内存。下面是NIO Buffer相关的话题列表... 阅读全文
posted @ 2016-01-26 13:45
开发者里程碑
阅读(169)
评论(0)
推荐(0)
摘要:
Java NIO的通道类似流,但又有些不同:既可以从通道中读取数据,又可以写数据到通道。但流的读写通常是单向的。通道可以异步地读写。通道中的数据总是要先读到一个Buffer,或者总是要从一个Buffer中写入。正如上面所说,从通道读取数据到缓冲区,从缓冲区写入数据到通道。如下图所示:Channel的... 阅读全文
posted @ 2016-01-26 13:44
开发者里程碑
阅读(184)
评论(0)
推荐(0)
摘要:
Java NIO 由以下几个核心部分组成:ChannelsBuffersSelectors虽然Java NIO 中除此之外还有很多类和组件,但在我看来,Channel,Buffer 和 Selector 构成了核心的API。其它组件,如Pipe和FileLock,只不过是与三个核心组件共同使用的工具... 阅读全文
posted @ 2016-01-26 13:43
开发者里程碑
阅读(159)
评论(0)
推荐(0)
摘要:
1. 背景1.1. Java线程模型的演进1.1.1. 单线程时间回到十几年前,那时主流的CPU都还是单核(除了商用高性能的小机),CPU的核心频率是机器最重要的指标之一。在Java领域当时比较流行的是单线程编程,对于CPU密集型的应用程序而言,频繁的通过多线程进行协作和抢占时间片反而会降低性能。1... 阅读全文
posted @ 2016-01-26 13:42
开发者里程碑
阅读(636)
评论(0)
推荐(0)

浙公网安备 33010602011771号