日韩性视频-久久久蜜桃-www中文字幕-在线中文字幕av-亚洲欧美一区二区三区四区-撸久久-香蕉视频一区-久久无码精品丰满人妻-国产高潮av-激情福利社-日韩av网址大全-国产精品久久999-日本五十路在线-性欧美在线-久久99精品波多结衣一区-男女午夜免费视频-黑人极品ⅴideos精品欧美棵-人人妻人人澡人人爽精品欧美一区-日韩一区在线看-欧美a级在线免费观看

歡迎訪問 生活随笔!

生活随笔

當(dāng)前位置: 首頁 > 编程语言 > C# >内容正文

C#

java .net 互通redis_C# servicestack.redis 互通 java jedis

發(fā)布時(shí)間:2025/3/15 C# 35 豆豆
生活随笔 收集整理的這篇文章主要介紹了 java .net 互通redis_C# servicestack.redis 互通 java jedis 小編覺得挺不錯(cuò)的,現(xiàn)在分享給大家,幫大家做個(gè)參考.

本文是基于jedis的一致性環(huán)哈希來修改的,.net選的是servicestack.redis組件來修改

無奈兩個(gè)組件都有各自的一致性環(huán)哈希算法,不兼容,那就選一個(gè)作為標(biāo)準(zhǔn),修改另一個(gè)咯。本文選擇jedis的一致性環(huán)哈希作為標(biāo)準(zhǔn),進(jìn)而修改.net來適應(yīng)jedis

jedis的邏輯是給每個(gè)redis節(jié)點(diǎn)構(gòu)造160個(gè)虛擬節(jié)點(diǎn),放入一顆二叉樹中(key/value:key是一個(gè)long值,根據(jù)哈希算法算出來的一個(gè)long、value是節(jié)點(diǎn)id,是個(gè)string)。

OK,邏輯清楚了,那就簡單了,給c#端寫個(gè)一模一樣的一致性環(huán)哈希算法。

public?class?Sharded

{????????private?object?nodes_lock?=?new?object();????????private?RedBlackTreeMap?nodes?=?new?RedBlackTreeMap();????????private?IHash?hashAlgo?=?new?MD5_LongSUM_Multiply_Hash();

public?void?AddTarget(int?index,?string?shard)

{????????????lock?(nodes_lock)

{????????????????for?(int?n?=?0;?n?

{????????????????????var?hashKey?=?"SHARD-"?+?index?+?"-NODE-"?+?n;????????????????????long?hashValue?=?this.hashAlgo.Hash(hashKey);

nodes.SetOrAddValue(hashValue,?shard);

}

}

}????????public?string?GetShardInfo(string?key)

{????????????long?searchHashKey?=?this.hashAlgo.Hash(key);????????????long?nearestKey;????????????string?shard;????????????lock?(nodes_lock)

{????????????????if?(this.nodes.NearestGreater(searchHashKey,?out?nearestKey))

{

shard?=?this.nodes.GetValue(nearestKey);????????????????????return?shard;

}????????????????if?(this.nodes.Least(out?searchHashKey,?out?shard))????????????????????return?shard;

}????????????throw?new?Exception("GetShardInfo?exception");

}

}

其中RedBlackTreeMap這個(gè)是TreeLib中的組件,需要在nuget上引用。

MD5_LongSUM_Multiply_Hash,這是個(gè)MD5算法,輸入為string,輸出為long。

此處由于考慮到輸出不是string,因此自己又改了改,讓他輸出long

public?class?MD5_LongSUM_Multiply_Hash?:?IHash

{????????public?long?Hash(string?key)

{????????????var?md5=?Md5Hash(key);????????????if?(string.IsNullOrEmpty(md5))

Log.GetLog().Info("Hash,?md5?is?null?or?empty");????????????var?convertedKeyBytes?=?Encoding.UTF8.GetBytes(md5);

long?value?=?1;????????????foreach(var?b?in?convertedKeyBytes)

value?*=?b*-1;????????????return?value;

}????????private?string?Md5Hash(string?input)

{

MD5CryptoServiceProvider?md5Hasher?=?new?MD5CryptoServiceProvider();????????????if?(string.IsNullOrEmpty(input))

Log.GetLog().Info("Md5Hash,?input?is?null?or?empty");????????????byte[]?data?=?md5Hasher.ComputeHash(Encoding.Default.GetBytes(input));

StringBuilder?sBuilder?=?new?StringBuilder();????????????for?(int?i?=?0;?i?

{

sBuilder.Append(data[i].ToString("x2"));

}????????????return?sBuilder.ToString();

}

}

剩下的就是java端的這個(gè)輸入string,輸出long的算法,需要和.net的輸入輸出一致了。

那就也寫一個(gè)哈希算法,讓他輸入string,輸出long,和.net的一致,這里只要java/.net用同一種md5算法,后續(xù)的md5變成long就很容易了。

import?org.springframework.security.authentication.encoding.MessageDigestPasswordEncoder;import?redis.clients.util.Hashing;import?redis.clients.util.SafeEncoder;import?java.io.UnsupportedEncodingException;/**

*?Created?by?z?on?2017/4/12.?*/public?class?MD5_SUM_Hash?implements?Hashing?{

MessageDigestPasswordEncoder?encoder=new?MessageDigestPasswordEncoder("MD5");????public?long?hash(String?key)?{????????return?this.hash(SafeEncoder.encode(key));

}????public?long?hash(byte[]?bytes)?{

String?converted_str=?null;????????try?{

converted_str?=?new?String(bytes,?"UTF8");

}?catch?(UnsupportedEncodingException?e)?{

e.printStackTrace();

}

String?result=encoder.encodePassword(converted_str,?null);????????try?{

bytes=result.getBytes("UTF8");

}?catch?(UnsupportedEncodingException?e)?{

e.printStackTrace();

}????????long?value?=?1;????????for(byte?b?:?bytes)

value?*=?b*-1;????????return?value;

}

}

org.springframework.security

spring-security-core

總結(jié)

以上是生活随笔為你收集整理的java .net 互通redis_C# servicestack.redis 互通 java jedis的全部內(nèi)容,希望文章能夠幫你解決所遇到的問題。

如果覺得生活随笔網(wǎng)站內(nèi)容還不錯(cuò),歡迎將生活随笔推薦給好友。