{"id":50428,"date":"2022-12-25T06:45:48","date_gmt":"2023-03-23T02:19:42","guid":{"rendered":"https:\/\/www.silicloud.com\/zh\/blog\/%e4%bd%bf%e7%94%a8consistenthashinggroup%e8%bf%9b%e8%a1%8cakka%e5%88%86%e5%b8%83%e5%bc%8f%e5%b9%b6%e8%a1%8c%e5%a4%84%e7%90%86%e7%9a%84%e5%a4%87%e5%bf%98%e5%bd%95%e3%80%82\/"},"modified":"2024-04-29T06:53:41","modified_gmt":"2024-04-28T22:53:41","slug":"%e4%bd%bf%e7%94%a8consistenthashinggroup%e8%bf%9b%e8%a1%8cakka%e5%88%86%e5%b8%83%e5%bc%8f%e5%b9%b6%e8%a1%8c%e5%a4%84%e7%90%86%e7%9a%84%e5%a4%87%e5%bf%98%e5%bd%95%e3%80%82","status":"publish","type":"post","link":"https:\/\/www.silicloud.com\/zh\/blog\/%e4%bd%bf%e7%94%a8consistenthashinggroup%e8%bf%9b%e8%a1%8cakka%e5%88%86%e5%b8%83%e5%bc%8f%e5%b9%b6%e8%a1%8c%e5%a4%84%e7%90%86%e7%9a%84%e5%a4%87%e5%bf%98%e5%bd%95%e3%80%82\/","title":{"rendered":"\u4f7f\u7528ConsistentHashingGroup\u8fdb\u884cAkka\u5206\u5e03\u5f0f\u5e76\u884c\u5904\u7406\u7684\u5907\u5fd8\u5f55"},"content":{"rendered":"<p>\u6211\u60f3\u505a\u7684\u4e8b\u60c5<\/p>\n<ul class=\"post-ul\">\n<li style=\"list-style-type: none;\">\n<ul class=\"post-ul\">key\u306b\u3088\u308a\u5206\u6563\u4e26\u5217\u51e6\u7406\u3092akka\u3092\u4f7f\u3063\u3066\u5b9f\u73fe<\/ul>\n<\/li>\n<\/ul>\n<p>&nbsp;<\/p>\n<ul class=\"post-ul\">\n<li style=\"list-style-type: none;\">\n<ul class=\"post-ul\">\u540c\u3058key\u306b\u7d10\u3065\u304f\u30c7\u30fc\u30bf\u306f\u540c\u3058node, worker\u3067\u51e6\u7406\u3055\u305b\u308b<\/ul>\n<\/li>\n<\/ul>\n<p>key\u306b\u5bfe\u3059\u308bon memory\u96c6\u8a08\u51e6\u7406\u7684\u306a\u3082\u306e\u3092\u3057\u3066\u3044\u308b\u3002<\/p>\n<p>\u96c6\u8a08\u7d50\u679c\u306fdb(cassandra\u306b\u5404node, worker\u4e0a\u3067insert\u51e6\u7406\u3092\u3059\u308b\u3002\uff09<br \/>\n\u73fe\u5728\u306e\u3068\u3053\u308d\u3001driver\u4e0a\u3067file\u8aad\u307f\u8fbc\u307f\u3057\u3066\u30011 thread\u3067\u6574\u5f62\u3057\u3066\u3001\u5404node, worker\u306b\u9001\u3063\u3066\u3044\u308b\u304c\u3001\u3053\u308c\u3092map reduce type\u306e\u51e6\u7406\u306b\u3059\u308b\u3002<\/p>\n<p>original\u7248\u306egearpump. plagger\u306e\u6d41\u308c\u3092\u304f\u3080\uff1ftiny map reduce system<\/p>\n<pre class=\"post-pre\"><code>akka {\r\n  actor {\r\n    provider = \"akka.cluster.ClusterActorRefProvider\"\r\n\r\n    deployment {\r\n      \/router {\r\n        router = consistent-hashing-group\r\n        \/\/router = round-robin-pool\r\n        routees.paths = [\r\n          \"akka.tcp:\/\/system@1\u53f7:2550\/user\/workers\/w1\",\r\n          \"akka.tcp:\/\/system@1\u53f7:2550\/user\/workers\/w2\",\r\n          \"akka.tcp:\/\/system@2\u53f7:2550\/user\/workers\/w3\",\r\n          \"akka.tcp:\/\/system@2\u53f7:2550\/user\/workers\/w4\",\r\n          \"akka.tcp:\/\/system@3\u53f7:2550\/user\/workers\/w5\",\r\n          \"akka.tcp:\/\/system@3\u53f7:2550\/user\/workers\/w6\",\r\n        ]\r\n        nr-of-instances = 1\r\n      }\r\n      target.nodes = [\r\n        \"akka.tcp:\/\/system@1\u53f7:2550\",\r\n        \"akka.tcp:\/\/system@2\u53f7:2550\",\r\n        \"akka.tcp:\/\/system@3\u53f7:2550\",\r\n      ]\r\n    }\r\n  }\r\n\r\n<\/code><\/pre>\n<pre class=\"post-pre\"><code><span class=\"k\">class<\/span> <span class=\"nc\">Workers<\/span> <span class=\"k\">extends<\/span> <span class=\"nc\">Actor<\/span> <span class=\"o\">{<\/span>\r\n  <span class=\"nv\">context<\/span><span class=\"o\">.<\/span><span class=\"py\">actorOf<\/span><span class=\"o\">(<\/span><span class=\"nc\">Props<\/span><span class=\"o\">[<\/span><span class=\"kt\">Worker<\/span><span class=\"o\">],<\/span> <span class=\"s\">\"w1\"<\/span><span class=\"o\">)<\/span>\r\n  <span class=\"nv\">context<\/span><span class=\"o\">.<\/span><span class=\"py\">actorOf<\/span><span class=\"o\">(<\/span><span class=\"nc\">Props<\/span><span class=\"o\">[<\/span><span class=\"kt\">Worker<\/span><span class=\"o\">],<\/span> <span class=\"s\">\"w2\"<\/span><span class=\"o\">)<\/span>\r\n  <span class=\"nv\">context<\/span><span class=\"o\">.<\/span><span class=\"py\">actorOf<\/span><span class=\"o\">(<\/span><span class=\"nc\">Props<\/span><span class=\"o\">[<\/span><span class=\"kt\">Worker<\/span><span class=\"o\">],<\/span> <span class=\"s\">\"w3\"<\/span><span class=\"o\">)<\/span>\r\n  <span class=\"nv\">context<\/span><span class=\"o\">.<\/span><span class=\"py\">actorOf<\/span><span class=\"o\">(<\/span><span class=\"nc\">Props<\/span><span class=\"o\">[<\/span><span class=\"kt\">Worker<\/span><span class=\"o\">],<\/span> <span class=\"s\">\"w4\"<\/span><span class=\"o\">)<\/span>\r\n  <span class=\"nv\">context<\/span><span class=\"o\">.<\/span><span class=\"py\">actorOf<\/span><span class=\"o\">(<\/span><span class=\"nc\">Props<\/span><span class=\"o\">[<\/span><span class=\"kt\">Worker<\/span><span class=\"o\">],<\/span> <span class=\"s\">\"w5\"<\/span><span class=\"o\">)<\/span>\r\n  <span class=\"nv\">context<\/span><span class=\"o\">.<\/span><span class=\"py\">actorOf<\/span><span class=\"o\">(<\/span><span class=\"nc\">Props<\/span><span class=\"o\">[<\/span><span class=\"kt\">Worker<\/span><span class=\"o\">],<\/span> <span class=\"s\">\"w6\"<\/span><span class=\"o\">)<\/span>\r\n\r\n  <span class=\"k\">def<\/span> <span class=\"nf\">receive<\/span> <span class=\"k\">=<\/span> <span class=\"o\">{<\/span>\r\n    <span class=\"k\">case<\/span> <span class=\"n\">message<\/span> <span class=\"k\">=&gt;<\/span> <span class=\"o\">{<\/span>\r\n      <span class=\"nf\">println<\/span><span class=\"o\">(<\/span><span class=\"n\">message<\/span><span class=\"o\">)<\/span>\r\n    <span class=\"o\">}<\/span>\r\n  <span class=\"o\">}<\/span>\r\n<span class=\"o\">}<\/span>\r\n\r\n<\/code><\/pre>\n<pre class=\"post-pre\"><code><span class=\"k\">object<\/span> <span class=\"nc\">Node<\/span> <span class=\"o\">{<\/span>\r\n\r\n  <span class=\"k\">def<\/span> <span class=\"nf\">main<\/span><span class=\"o\">(<\/span><span class=\"n\">args<\/span><span class=\"k\">:<\/span> <span class=\"kt\">Array<\/span><span class=\"o\">[<\/span><span class=\"kt\">String<\/span><span class=\"o\">])<\/span><span class=\"k\">:<\/span> <span class=\"kt\">Unit<\/span> <span class=\"o\">=<\/span> <span class=\"o\">{<\/span>\r\n    <span class=\"k\">val<\/span> <span class=\"nv\">host<\/span> <span class=\"k\">=<\/span> <span class=\"nf\">args<\/span><span class=\"o\">(<\/span><span class=\"mi\">0<\/span><span class=\"o\">)<\/span>\r\n    <span class=\"k\">val<\/span> <span class=\"nv\">port<\/span> <span class=\"k\">=<\/span> <span class=\"nf\">args<\/span><span class=\"o\">(<\/span><span class=\"mi\">1<\/span><span class=\"o\">)<\/span>\r\n\r\n    <span class=\"nv\">System<\/span><span class=\"o\">.<\/span><span class=\"py\">setProperty<\/span><span class=\"o\">(<\/span><span class=\"s\">\"akka.remote.netty.tcp.hostname\"<\/span><span class=\"o\">,<\/span> <span class=\"n\">host<\/span><span class=\"o\">)<\/span>\r\n    <span class=\"nv\">System<\/span><span class=\"o\">.<\/span><span class=\"py\">setProperty<\/span><span class=\"o\">(<\/span><span class=\"s\">\"akka.remote.netty.tcp.port\"<\/span><span class=\"o\">,<\/span> <span class=\"n\">port<\/span><span class=\"o\">)<\/span>\r\n\r\n    <span class=\"c1\">\/\/ akka system<\/span>\r\n    <span class=\"k\">val<\/span> <span class=\"nv\">system<\/span> <span class=\"k\">=<\/span> <span class=\"nc\">ActorSystem<\/span><span class=\"o\">(<\/span><span class=\"s\">\"system\"<\/span><span class=\"o\">)<\/span>\r\n    <span class=\"nv\">system<\/span><span class=\"o\">.<\/span><span class=\"py\">actorOf<\/span><span class=\"o\">(<\/span><span class=\"nc\">Props<\/span><span class=\"o\">[<\/span><span class=\"kt\">Workers<\/span><span class=\"o\">],<\/span> <span class=\"n\">name<\/span><span class=\"o\">=<\/span><span class=\"s\">\"workers\"<\/span><span class=\"o\">)<\/span>\r\n  <span class=\"o\">}<\/span>\r\n<span class=\"o\">}<\/span>\r\n<\/code><\/pre>\n<pre class=\"post-pre\"><code><span class=\"c1\">\/\/ akka system<\/span>\r\n    <span class=\"k\">val<\/span> <span class=\"nv\">system<\/span> <span class=\"k\">=<\/span> <span class=\"nc\">ActorSystem<\/span><span class=\"o\">(<\/span><span class=\"s\">\"system\"<\/span><span class=\"o\">)<\/span>\r\n    <span class=\"k\">val<\/span> <span class=\"nv\">master<\/span> <span class=\"k\">=<\/span> <span class=\"nv\">system<\/span><span class=\"o\">.<\/span><span class=\"py\">actorOf<\/span><span class=\"o\">(<\/span><span class=\"nc\">Props<\/span><span class=\"o\">[<\/span><span class=\"kt\">Master<\/span><span class=\"o\">],<\/span> <span class=\"n\">name<\/span> <span class=\"k\">=<\/span> <span class=\"s\">\"master\"<\/span><span class=\"o\">)<\/span>\r\n\r\n    <span class=\"nc\">Cluster<\/span><span class=\"o\">(<\/span><span class=\"n\">system<\/span><span class=\"o\">).<\/span><span class=\"py\">subscribe<\/span><span class=\"o\">(<\/span><span class=\"n\">master<\/span><span class=\"o\">,<\/span> <span class=\"n\">classOf<\/span><span class=\"o\">[<\/span><span class=\"kt\">ClusterDomainEvent<\/span><span class=\"o\">])<\/span>\r\n\r\n    <span class=\"c1\">\/\/ generate routees<\/span>\r\n    <span class=\"nv\">system<\/span><span class=\"o\">.<\/span><span class=\"py\">actorOf<\/span><span class=\"o\">(<\/span><span class=\"nc\">Props<\/span><span class=\"o\">[<\/span><span class=\"kt\">Workers<\/span><span class=\"o\">],<\/span> <span class=\"n\">name<\/span><span class=\"o\">=<\/span><span class=\"s\">\"workers\"<\/span><span class=\"o\">)<\/span>\r\n\r\n    <span class=\"k\">val<\/span> <span class=\"nv\">router<\/span> <span class=\"k\">=<\/span> <span class=\"nv\">system<\/span><span class=\"o\">.<\/span><span class=\"py\">actorOf<\/span><span class=\"o\">(<\/span><span class=\"nv\">FromConfig<\/span><span class=\"o\">.<\/span><span class=\"py\">props<\/span><span class=\"o\">(<\/span><span class=\"nc\">Props<\/span><span class=\"o\">[<\/span><span class=\"kt\">Aggregation<\/span><span class=\"o\">]),<\/span> <span class=\"s\">\"router\"<\/span><span class=\"o\">)<\/span>\r\n\r\n\r\n<span class=\"o\">.<\/span>\r\n<span class=\"o\">.<\/span>\r\n<span class=\"o\">.<\/span>\r\n<span class=\"o\">.<\/span>\r\n\r\n<span class=\"nv\">router<\/span><span class=\"o\">.<\/span><span class=\"py\">tell<\/span><span class=\"o\">(<\/span><span class=\"nc\">ConsistentHashableEnvelope<\/span><span class=\"o\">(<\/span><span class=\"nc\">Request<\/span><span class=\"o\">(<\/span><span class=\"n\">data<\/span><span class=\"o\">),<\/span> <span class=\"n\">key<\/span><span class=\"o\">),<\/span> <span class=\"n\">master<\/span><span class=\"o\">)<\/span>\r\n\r\n<\/code><\/pre>\n<h1>\u5907\u5fd8\u5f55<\/h1>\n<ul class=\"post-ul\">\n<li style=\"list-style-type: none;\">\n<ul class=\"post-ul\">path\u306b\u5bfe\u5fdc\u3059\u308bactor\u3092\u4f5c\u308b\u306b\u306f\u3001\u304f\u3089\u3059\u3092\u30cd\u30b9\u30c8\u3059\u308b\u3057\u304b\u306a\u3044\uff1f<\/ul>\n<\/li>\n<\/ul>\n<p>\/user\/mappers\/m1\u3092\u4f5c\u308b\u306b\u306f\u3001Mappers actor\u3092\u4f5c\u3063\u3066\u305d\u306e\u4e2d\u3067Mapper actor\u3092name=m1\u3067\u4f5c\u308b\u5fc5\u8981\u304c\u3042\u308b\uff1f\u3053\u3093\u306a\u9762\u5012\u306a\u3053\u3068\u3059\u308b\u5fc5\u8981\u304c\u3042\u308b\u304b\uff1f for group router\u306e\u5834\u5408<br \/>\npool\u306e\u5834\u5408\u306f\u81ea\u52d5\u3067\u4f5c\u3063\u3066\u304f\u308c\u308b\u304c\u3001\u3053\u306e\u968e\u5c64\u69cb\u9020\u3082\u4e0a\u306e\u3088\u3046\u306a\u611f\u3058<\/p>\n<p>worker\u3067\u843d\u3061\u3066\u3082\u3001driver\u3092\u518d\u8d77\u52d5\u3055\u305b\u308c\u3070\u518d\u5ea6\u5168worker\u3067\u51e6\u7406\u3092\u5b9f\u65bd\u3067\u304d\u308b\u3002<\/p>\n<p>error handling\u7b49\u306f\u304b\u306a\u308a\u5148<\/p>\n","protected":false},"excerpt":{"rendered":"<p>\u6211\u60f3\u505a\u7684\u4e8b\u60c5 key\u306b\u3088\u308a\u5206\u6563\u4e26\u5217\u51e6\u7406\u3092akka\u3092\u4f7f\u3063\u3066\u5b9f\u73fe &nbsp; \u540c\u3058key\u306b\u7d10\u3065\u304f\u30c7\u30fc\u30bf\u306f\u540c\u3058no [&hellip;]<\/p>\n","protected":false},"author":5,"featured_media":0,"comment_status":"closed","ping_status":"open","sticky":false,"template":"","format":"standard","meta":{"footnotes":""},"categories":[1],"tags":[],"class_list":["post-50428","post","type-post","status-publish","format-standard","hentry","category-uncategorized"],"yoast_head":"<!-- This site is optimized with the Yoast SEO Premium plugin v21.5 (Yoast SEO v21.5) - https:\/\/yoast.com\/wordpress\/plugins\/seo\/ -->\n<title>\u4f7f\u7528ConsistentHashingGroup\u8fdb\u884cAkka\u5206\u5e03\u5f0f\u5e76\u884c\u5904\u7406\u7684\u5907\u5fd8\u5f55 - Blog - Silicon Cloud<\/title>\n<meta name=\"robots\" content=\"index, follow, max-snippet:-1, max-image-preview:large, max-video-preview:-1\" \/>\n<link rel=\"canonical\" href=\"https:\/\/www.silicloud.com\/zh\/blog\/\u4f7f\u7528consistenthashinggroup\u8fdb\u884cakka\u5206\u5e03\u5f0f\u5e76\u884c\u5904\u7406\u7684\u5907\u5fd8\u5f55\u3002\/\" \/>\n<meta property=\"og:locale\" content=\"zh_CN\" \/>\n<meta property=\"og:type\" content=\"article\" \/>\n<meta property=\"og:title\" content=\"\u4f7f\u7528ConsistentHashingGroup\u8fdb\u884cAkka\u5206\u5e03\u5f0f\u5e76\u884c\u5904\u7406\u7684\u5907\u5fd8\u5f55\" \/>\n<meta property=\"og:description\" content=\"\u6211\u60f3\u505a\u7684\u4e8b\u60c5 key\u306b\u3088\u308a\u5206\u6563\u4e26\u5217\u51e6\u7406\u3092akka\u3092\u4f7f\u3063\u3066\u5b9f\u73fe &nbsp; \u540c\u3058key\u306b\u7d10\u3065\u304f\u30c7\u30fc\u30bf\u306f\u540c\u3058no [&hellip;]\" \/>\n<meta property=\"og:url\" content=\"https:\/\/www.silicloud.com\/zh\/blog\/\u4f7f\u7528consistenthashinggroup\u8fdb\u884cakka\u5206\u5e03\u5f0f\u5e76\u884c\u5904\u7406\u7684\u5907\u5fd8\u5f55\u3002\/\" \/>\n<meta property=\"og:site_name\" content=\"Blog - Silicon Cloud\" \/>\n<meta property=\"article:published_time\" content=\"2023-03-23T02:19:42+00:00\" \/>\n<meta property=\"article:modified_time\" content=\"2024-04-28T22:53:41+00:00\" \/>\n<meta name=\"author\" content=\"\u6e05, \u5b87\" \/>\n<meta name=\"twitter:card\" content=\"summary_large_image\" \/>\n<meta name=\"twitter:label1\" content=\"\u4f5c\u8005\" \/>\n\t<meta name=\"twitter:data1\" content=\"\u6e05, \u5b87\" \/>\n\t<meta name=\"twitter:label2\" content=\"\u9884\u8ba1\u9605\u8bfb\u65f6\u95f4\" \/>\n\t<meta name=\"twitter:data2\" content=\"1 \u5206\" \/>\n<script type=\"application\/ld+json\" class=\"yoast-schema-graph\">{\"@context\":\"https:\/\/schema.org\",\"@graph\":[{\"@type\":\"WebPage\",\"@id\":\"https:\/\/www.silicloud.com\/zh\/blog\/%e4%bd%bf%e7%94%a8consistenthashinggroup%e8%bf%9b%e8%a1%8cakka%e5%88%86%e5%b8%83%e5%bc%8f%e5%b9%b6%e8%a1%8c%e5%a4%84%e7%90%86%e7%9a%84%e5%a4%87%e5%bf%98%e5%bd%95%e3%80%82\/\",\"url\":\"https:\/\/www.silicloud.com\/zh\/blog\/%e4%bd%bf%e7%94%a8consistenthashinggroup%e8%bf%9b%e8%a1%8cakka%e5%88%86%e5%b8%83%e5%bc%8f%e5%b9%b6%e8%a1%8c%e5%a4%84%e7%90%86%e7%9a%84%e5%a4%87%e5%bf%98%e5%bd%95%e3%80%82\/\",\"name\":\"\u4f7f\u7528ConsistentHashingGroup\u8fdb\u884cAkka\u5206\u5e03\u5f0f\u5e76\u884c\u5904\u7406\u7684\u5907\u5fd8\u5f55 - Blog - Silicon Cloud\",\"isPartOf\":{\"@id\":\"https:\/\/www.silicloud.com\/zh\/blog\/#website\"},\"datePublished\":\"2023-03-23T02:19:42+00:00\",\"dateModified\":\"2024-04-28T22:53:41+00:00\",\"author\":{\"@id\":\"https:\/\/www.silicloud.com\/zh\/blog\/#\/schema\/person\/1a6ecd3d914d22a5ac32791ffc1fbd8e\"},\"breadcrumb\":{\"@id\":\"https:\/\/www.silicloud.com\/zh\/blog\/%e4%bd%bf%e7%94%a8consistenthashinggroup%e8%bf%9b%e8%a1%8cakka%e5%88%86%e5%b8%83%e5%bc%8f%e5%b9%b6%e8%a1%8c%e5%a4%84%e7%90%86%e7%9a%84%e5%a4%87%e5%bf%98%e5%bd%95%e3%80%82\/#breadcrumb\"},\"inLanguage\":\"zh-Hans\",\"potentialAction\":[{\"@type\":\"ReadAction\",\"target\":[\"https:\/\/www.silicloud.com\/zh\/blog\/%e4%bd%bf%e7%94%a8consistenthashinggroup%e8%bf%9b%e8%a1%8cakka%e5%88%86%e5%b8%83%e5%bc%8f%e5%b9%b6%e8%a1%8c%e5%a4%84%e7%90%86%e7%9a%84%e5%a4%87%e5%bf%98%e5%bd%95%e3%80%82\/\"]}]},{\"@type\":\"BreadcrumbList\",\"@id\":\"https:\/\/www.silicloud.com\/zh\/blog\/%e4%bd%bf%e7%94%a8consistenthashinggroup%e8%bf%9b%e8%a1%8cakka%e5%88%86%e5%b8%83%e5%bc%8f%e5%b9%b6%e8%a1%8c%e5%a4%84%e7%90%86%e7%9a%84%e5%a4%87%e5%bf%98%e5%bd%95%e3%80%82\/#breadcrumb\",\"itemListElement\":[{\"@type\":\"ListItem\",\"position\":1,\"name\":\"\u9996\u9875\",\"item\":\"https:\/\/www.silicloud.com\/zh\/blog\/\"},{\"@type\":\"ListItem\",\"position\":2,\"name\":\"\u4f7f\u7528ConsistentHashingGroup\u8fdb\u884cAkka\u5206\u5e03\u5f0f\u5e76\u884c\u5904\u7406\u7684\u5907\u5fd8\u5f55\"}]},{\"@type\":\"WebSite\",\"@id\":\"https:\/\/www.silicloud.com\/zh\/blog\/#website\",\"url\":\"https:\/\/www.silicloud.com\/zh\/blog\/\",\"name\":\"Blog - Silicon Cloud\",\"description\":\"\",\"inLanguage\":\"zh-Hans\"},{\"@type\":\"Person\",\"@id\":\"https:\/\/www.silicloud.com\/zh\/blog\/#\/schema\/person\/1a6ecd3d914d22a5ac32791ffc1fbd8e\",\"name\":\"\u6e05, \u5b87\",\"image\":{\"@type\":\"ImageObject\",\"inLanguage\":\"zh-Hans\",\"@id\":\"https:\/\/www.silicloud.com\/zh\/blog\/#\/schema\/person\/image\/\",\"url\":\"https:\/\/secure.gravatar.com\/avatar\/4b2016c18459a605fc469c7566608f5686491baa112d0871ee613f61b7210565?s=96&d=mm&r=g\",\"contentUrl\":\"https:\/\/secure.gravatar.com\/avatar\/4b2016c18459a605fc469c7566608f5686491baa112d0871ee613f61b7210565?s=96&d=mm&r=g\",\"caption\":\"\u6e05, \u5b87\"},\"url\":\"https:\/\/www.silicloud.com\/zh\/blog\/author\/qingyu\/\"},{\"@type\":\"ImageObject\",\"inLanguage\":\"zh-Hans\",\"@id\":\"https:\/\/www.silicloud.com\/zh\/blog\/%e4%bd%bf%e7%94%a8consistenthashinggroup%e8%bf%9b%e8%a1%8cakka%e5%88%86%e5%b8%83%e5%bc%8f%e5%b9%b6%e8%a1%8c%e5%a4%84%e7%90%86%e7%9a%84%e5%a4%87%e5%bf%98%e5%bd%95%e3%80%82\/#local-main-organization-logo\",\"url\":\"\",\"contentUrl\":\"\",\"caption\":\"Blog - Silicon Cloud\"}]}<\/script>\n<!-- \/ Yoast SEO Premium plugin. -->","yoast_head_json":{"title":"\u4f7f\u7528ConsistentHashingGroup\u8fdb\u884cAkka\u5206\u5e03\u5f0f\u5e76\u884c\u5904\u7406\u7684\u5907\u5fd8\u5f55 - Blog - Silicon Cloud","robots":{"index":"index","follow":"follow","max-snippet":"max-snippet:-1","max-image-preview":"max-image-preview:large","max-video-preview":"max-video-preview:-1"},"canonical":"https:\/\/www.silicloud.com\/zh\/blog\/\u4f7f\u7528consistenthashinggroup\u8fdb\u884cakka\u5206\u5e03\u5f0f\u5e76\u884c\u5904\u7406\u7684\u5907\u5fd8\u5f55\u3002\/","og_locale":"zh_CN","og_type":"article","og_title":"\u4f7f\u7528ConsistentHashingGroup\u8fdb\u884cAkka\u5206\u5e03\u5f0f\u5e76\u884c\u5904\u7406\u7684\u5907\u5fd8\u5f55","og_description":"\u6211\u60f3\u505a\u7684\u4e8b\u60c5 key\u306b\u3088\u308a\u5206\u6563\u4e26\u5217\u51e6\u7406\u3092akka\u3092\u4f7f\u3063\u3066\u5b9f\u73fe &nbsp; \u540c\u3058key\u306b\u7d10\u3065\u304f\u30c7\u30fc\u30bf\u306f\u540c\u3058no [&hellip;]","og_url":"https:\/\/www.silicloud.com\/zh\/blog\/\u4f7f\u7528consistenthashinggroup\u8fdb\u884cakka\u5206\u5e03\u5f0f\u5e76\u884c\u5904\u7406\u7684\u5907\u5fd8\u5f55\u3002\/","og_site_name":"Blog - Silicon Cloud","article_published_time":"2023-03-23T02:19:42+00:00","article_modified_time":"2024-04-28T22:53:41+00:00","author":"\u6e05, \u5b87","twitter_card":"summary_large_image","twitter_misc":{"\u4f5c\u8005":"\u6e05, \u5b87","\u9884\u8ba1\u9605\u8bfb\u65f6\u95f4":"1 \u5206"},"schema":{"@context":"https:\/\/schema.org","@graph":[{"@type":"WebPage","@id":"https:\/\/www.silicloud.com\/zh\/blog\/%e4%bd%bf%e7%94%a8consistenthashinggroup%e8%bf%9b%e8%a1%8cakka%e5%88%86%e5%b8%83%e5%bc%8f%e5%b9%b6%e8%a1%8c%e5%a4%84%e7%90%86%e7%9a%84%e5%a4%87%e5%bf%98%e5%bd%95%e3%80%82\/","url":"https:\/\/www.silicloud.com\/zh\/blog\/%e4%bd%bf%e7%94%a8consistenthashinggroup%e8%bf%9b%e8%a1%8cakka%e5%88%86%e5%b8%83%e5%bc%8f%e5%b9%b6%e8%a1%8c%e5%a4%84%e7%90%86%e7%9a%84%e5%a4%87%e5%bf%98%e5%bd%95%e3%80%82\/","name":"\u4f7f\u7528ConsistentHashingGroup\u8fdb\u884cAkka\u5206\u5e03\u5f0f\u5e76\u884c\u5904\u7406\u7684\u5907\u5fd8\u5f55 - Blog - Silicon Cloud","isPartOf":{"@id":"https:\/\/www.silicloud.com\/zh\/blog\/#website"},"datePublished":"2023-03-23T02:19:42+00:00","dateModified":"2024-04-28T22:53:41+00:00","author":{"@id":"https:\/\/www.silicloud.com\/zh\/blog\/#\/schema\/person\/1a6ecd3d914d22a5ac32791ffc1fbd8e"},"breadcrumb":{"@id":"https:\/\/www.silicloud.com\/zh\/blog\/%e4%bd%bf%e7%94%a8consistenthashinggroup%e8%bf%9b%e8%a1%8cakka%e5%88%86%e5%b8%83%e5%bc%8f%e5%b9%b6%e8%a1%8c%e5%a4%84%e7%90%86%e7%9a%84%e5%a4%87%e5%bf%98%e5%bd%95%e3%80%82\/#breadcrumb"},"inLanguage":"zh-Hans","potentialAction":[{"@type":"ReadAction","target":["https:\/\/www.silicloud.com\/zh\/blog\/%e4%bd%bf%e7%94%a8consistenthashinggroup%e8%bf%9b%e8%a1%8cakka%e5%88%86%e5%b8%83%e5%bc%8f%e5%b9%b6%e8%a1%8c%e5%a4%84%e7%90%86%e7%9a%84%e5%a4%87%e5%bf%98%e5%bd%95%e3%80%82\/"]}]},{"@type":"BreadcrumbList","@id":"https:\/\/www.silicloud.com\/zh\/blog\/%e4%bd%bf%e7%94%a8consistenthashinggroup%e8%bf%9b%e8%a1%8cakka%e5%88%86%e5%b8%83%e5%bc%8f%e5%b9%b6%e8%a1%8c%e5%a4%84%e7%90%86%e7%9a%84%e5%a4%87%e5%bf%98%e5%bd%95%e3%80%82\/#breadcrumb","itemListElement":[{"@type":"ListItem","position":1,"name":"\u9996\u9875","item":"https:\/\/www.silicloud.com\/zh\/blog\/"},{"@type":"ListItem","position":2,"name":"\u4f7f\u7528ConsistentHashingGroup\u8fdb\u884cAkka\u5206\u5e03\u5f0f\u5e76\u884c\u5904\u7406\u7684\u5907\u5fd8\u5f55"}]},{"@type":"WebSite","@id":"https:\/\/www.silicloud.com\/zh\/blog\/#website","url":"https:\/\/www.silicloud.com\/zh\/blog\/","name":"Blog - Silicon Cloud","description":"","inLanguage":"zh-Hans"},{"@type":"Person","@id":"https:\/\/www.silicloud.com\/zh\/blog\/#\/schema\/person\/1a6ecd3d914d22a5ac32791ffc1fbd8e","name":"\u6e05, \u5b87","image":{"@type":"ImageObject","inLanguage":"zh-Hans","@id":"https:\/\/www.silicloud.com\/zh\/blog\/#\/schema\/person\/image\/","url":"https:\/\/secure.gravatar.com\/avatar\/4b2016c18459a605fc469c7566608f5686491baa112d0871ee613f61b7210565?s=96&d=mm&r=g","contentUrl":"https:\/\/secure.gravatar.com\/avatar\/4b2016c18459a605fc469c7566608f5686491baa112d0871ee613f61b7210565?s=96&d=mm&r=g","caption":"\u6e05, \u5b87"},"url":"https:\/\/www.silicloud.com\/zh\/blog\/author\/qingyu\/"},{"@type":"ImageObject","inLanguage":"zh-Hans","@id":"https:\/\/www.silicloud.com\/zh\/blog\/%e4%bd%bf%e7%94%a8consistenthashinggroup%e8%bf%9b%e8%a1%8cakka%e5%88%86%e5%b8%83%e5%bc%8f%e5%b9%b6%e8%a1%8c%e5%a4%84%e7%90%86%e7%9a%84%e5%a4%87%e5%bf%98%e5%bd%95%e3%80%82\/#local-main-organization-logo","url":"","contentUrl":"","caption":"Blog - Silicon Cloud"}]}},"_links":{"self":[{"href":"https:\/\/www.silicloud.com\/zh\/blog\/wp-json\/wp\/v2\/posts\/50428","targetHints":{"allow":["GET"]}}],"collection":[{"href":"https:\/\/www.silicloud.com\/zh\/blog\/wp-json\/wp\/v2\/posts"}],"about":[{"href":"https:\/\/www.silicloud.com\/zh\/blog\/wp-json\/wp\/v2\/types\/post"}],"author":[{"embeddable":true,"href":"https:\/\/www.silicloud.com\/zh\/blog\/wp-json\/wp\/v2\/users\/5"}],"replies":[{"embeddable":true,"href":"https:\/\/www.silicloud.com\/zh\/blog\/wp-json\/wp\/v2\/comments?post=50428"}],"version-history":[{"count":2,"href":"https:\/\/www.silicloud.com\/zh\/blog\/wp-json\/wp\/v2\/posts\/50428\/revisions"}],"predecessor-version":[{"id":83719,"href":"https:\/\/www.silicloud.com\/zh\/blog\/wp-json\/wp\/v2\/posts\/50428\/revisions\/83719"}],"wp:attachment":[{"href":"https:\/\/www.silicloud.com\/zh\/blog\/wp-json\/wp\/v2\/media?parent=50428"}],"wp:term":[{"taxonomy":"category","embeddable":true,"href":"https:\/\/www.silicloud.com\/zh\/blog\/wp-json\/wp\/v2\/categories?post=50428"},{"taxonomy":"post_tag","embeddable":true,"href":"https:\/\/www.silicloud.com\/zh\/blog\/wp-json\/wp\/v2\/tags?post=50428"}],"curies":[{"name":"wp","href":"https:\/\/api.w.org\/{rel}","templated":true}]}}