最近在研究"一致性HASH算法"(ConsistentHashing),用于解决memcached集群中当服务器出现增减变动时对散列值的影响。后来在JAVAEYE上的一篇文章中,找到了其中的KetamaHash算法的JAVA实现(一种基于虚拟结点的HASH算法),于是为了加深理解,对照JAVA版本,用C#重写了一个。放到这里,如果大家感兴趣的话,可以下载测试一下,如果发现写法有问题请及时告之我,以便我及时修正。下面是对Ketama的介绍:Ketamaisa
系统 2019-08-29 23:33:42 3053
HTTP协议本身是“连接-请求-应答-关闭连接”的模式,是一种无状态协议;然而随着web动态化的需求,我们往往需要把两次连续的请求关联起来,从而使得客户端和服务端的会话变得有状态。Session就是满足这种需求的一种实现方式。它的基本原理是服务器端为每一个session管理一份会话信息数据。而客户端和服务器端依靠一个全局唯一标示符——sessionID来访问会话信息数据。当用户访问web应用时,服务器端会先检查客户端的请求里是否包含sessionID,如果
系统 2019-08-29 22:39:41 3053
摘要:很久没有接触过php的东西了,今天有个程序需要一个php的运行环境。由于只需要简单的跑一下程序,因此觉得没有必要弄一个LAMP的环境(如果需要配LAMP环境的话可以参考我写的关于PHP的blog),不如直接用IIS来运行吧。主要内容:使用IIS运行PHP程序一、使用IIS运行PHP程序1.首先下载PHP,这里我下载的是php5.2.14(如果是其他高版本的话可能找不到php5isapi.dll,其相关配置方法暂且不论),建议下载zip压缩包,不需安装
系统 2019-08-29 22:18:44 3053
iOS开发键盘添加工具条(toolbar)原文地址http://gaohaijun.blog.163.com/blog/static/17669827120119233349519/IOS开发中,iphone/ipad/itouch采用的触摸设计,本身没有硬件键盘,一般都是点击输入框之后,弹出一个虚拟键盘出来,因此开发中,经常在完成编辑输入之后,要写程序代码来关闭软键盘的输出,非常繁琐,当然关闭软键盘的方式有很多。本文要分享的是一个键盘顶部工具条的类,通过
系统 2019-08-29 22:00:31 3053
初学MySQL,记录一下MySQL用c语言编程时遇到的问题。这是我的源程序:1intmain(void)2{3MYSQL*mysql=NULL;456if((mysql=mysql_init(mysql))==NULL)7{8fprintf(stderr,"CannotinitializeMySQL");9return1;10}11if(mysql_real_connect(mysql,"localhost","kerry","beck123",NULL,
系统 2019-08-12 01:51:54 3053
有许多技术可用于用PHP读取和编写XML。本文提供了三种方法读取XML:使用DOM库、使用SAX解析器和使用正则表达式。还介绍了使用DOM和PHP文本模板编写XML。
完整的jBPM4PVM介绍发表在《程序员》第8期,这里截取部分的意思是PVM的过程调度是非常灵活的,PVM提供了一套和token类似的execution过程调度机制,通过对execution的完全操控,节点运行期行为有了无限的可能。PVM的流程定义模型首先要说明的是,上图里的类全是接口。位于最上层的是ObservableElement,其提供给流程元素以附加Event(事件)的能力。在ObservableElementImpl里,它持有一个events的集
系统 2019-08-12 09:30:16 3052
password用于修改mysql的用户密码,如果是应用与web程序建议使用md5()函数,password函数旧版16位,新版41位,可用selectlength(password('123456'))察看。password函数加密不可逆,如果和数据库里加密后内容比较时可以采用password(pwd)==字段内容的方式;md5函数加密后32位,此加密算法不可逆,其实md5算法是信息摘要算法,如果拿来做压缩也是有损压缩,理论上即使有反向算法也无法恢复信息
系统 2019-08-12 01:54:42 3052
ON、WHERE、HAVING都能通过限制条件筛选数据,但他们的使用及其不同。下面我们来分析三者之间的区别。1.ON和WHERE所有的查询都回产生一个中间临时报表,查询结果就是从返回临时报表中得到。ON和WHERE后面所跟限制条件的区别,主要与限制条件起作用的时机有关,ON根据限制条件对数据库记录进行过滤,然后生产临时表;而WHERE是在临时表生产之后,根据限制条件从临时表中筛选结果。因为以上原因,ON和WHERE的区别主要有下:1)返回结果:在左外(右外
系统 2019-08-12 01:52:47 3052
查看当前连接系统参数:SHOWVARIABLESLIKE'%char%';mysql>showvariableslike'char%';+--------------------------+----------------|Variable_name|Value+--------------------------+----------------|character_set_client|gbk|character_set_connection|gbk
系统 2019-08-12 01:52:36 3052