artillery/docs/building-blocks/primitives.html

57 lines
17 KiB
HTML

<!DOCTYPE html>
<html lang="en-US">
<head>
<meta charset="utf-8">
<meta name="viewport" content="width=device-width,initial-scale=1">
<title>Primitives | Artillery</title>
<meta name="description" content="Cluster management &amp; Distributed data protocol">
<meta name="generator" content="VuePress 1.3.1">
<link rel="preload" href="/assets/css/0.styles.40eef163.css" as="style"><link rel="preload" href="/assets/js/app.a6f18760.js" as="script"><link rel="preload" href="/assets/js/3.294f849a.js" as="script"><link rel="preload" href="/assets/js/7.9042a811.js" as="script"><link rel="prefetch" href="/assets/js/1.2f71ac0b.js"><link rel="prefetch" href="/assets/js/10.e2c4e6dd.js"><link rel="prefetch" href="/assets/js/4.b92d7a52.js"><link rel="prefetch" href="/assets/js/5.b60eac8b.js"><link rel="prefetch" href="/assets/js/6.d6285a75.js"><link rel="prefetch" href="/assets/js/8.f2fbc9e9.js"><link rel="prefetch" href="/assets/js/9.7cb4df56.js">
<link rel="stylesheet" href="/assets/css/0.styles.40eef163.css">
</head>
<body>
<div id="app" data-server-rendered="true"><div class="theme__container sidebar-open"><div class="menu__container"><a style="display:;"><img src="" style="display:;"> <img src="" style="display:none;"></a></div> <div class="row"><div class="col-md-3 col-lg-2 sidebar__container" style="display:none;"><div class="sidebar"><!----><div class="group"><div class="group__title">home</div> <div class="group__body"><div class="group__category category"><div class="category__label"><a href="/" class="sidebar-link router-link-active">Homepage</a></div></div> </div></div><div class="group"><div class="group__title">getting-started</div> <div class="group__body"><!----> <div name="/getting-started/getting-started.html" class="group__category category"><div class="category__label"><a href="/getting-started/getting-started.html" class="sidebar-link">Getting Started</a></div> <div class="category__headers"><div class="category__header-item"><a href="/getting-started/getting-started.html#basics" class="sidebar-link">Basics</a></div></div><div class="category__headers"><div class="category__header-item"><a href="/getting-started/getting-started.html#distributed-data" class="sidebar-link">Distributed Data</a></div></div><div class="category__headers"><div class="category__header-item"><a href="/getting-started/getting-started.html#hierarchy-management" class="sidebar-link">Hierarchy Management</a></div></div></div></div></div><div class="group"><div class="group__title">building-blocks</div> <div class="group__body"><!----> <div name="/building-blocks/primitives.html" class="group__category category category--selected category--active"><div class="category__label"><a href="/building-blocks/primitives.html" class="sidebar-link router-link-exact-active router-link-active">Primitives</a></div> <div class="category__headers"><div class="category__header-item"><a href="/building-blocks/primitives.html#service-discovery-primitives" class="sidebar-link">Service Discovery Primitives</a></div></div><div class="category__headers"><div class="category__header-item"><a href="/building-blocks/primitives.html#udp-anycast" class="sidebar-link">Udp Anycast</a></div></div></div></div></div><div class="group"><div class="group__title">examples</div> <div class="group__body"><!----> <div name="/examples/cluster-examples.html" class="group__category category"><div class="category__label"><a href="/examples/cluster-examples.html" class="sidebar-link">Local Examples</a></div> <div class="category__headers"><div class="category__header-item"><a href="/examples/cluster-examples.html#cluster-examples" class="sidebar-link">Cluster Examples</a></div></div><div class="category__headers"><div class="category__header-item"><a href="/examples/cluster-examples.html#launching-a-local-ap-cluster" class="sidebar-link">Launching A Local Ap Cluster</a></div></div></div></div></div></div></div> <div class="col-md-9 col-lg-10 content__container" style="display:;"><div class="page__container"><div custom="" class="content__default"><div class="content-block"><div class="content-block__heading"></div> <div class="content-block__body"><div class="content-block__cont"><h1 id="primitives"><a href="#primitives" class="header-anchor">#</a> Primitives</h1></div> <div class="content-block__examples"></div></div></div> <div class="content-block"><div class="content-block__heading"></div> <div class="content-block__body"><div class="content-block__cont"><p>Artillery Core consists of various primitives. We will start with Service Discovery primitives and pave out way to Cluster primitives.</p></div> <div class="content-block__examples"></div></div></div> <div class="content-block"><div class="content-block__heading"></div> <div class="content-block__body"><div class="content-block__cont"><h2 id="service-discovery-primitives"><a href="#service-discovery-primitives" class="header-anchor">#</a> Service Discovery Primitives</h2> <p>For distributed operation we need to have a service discovery to find out who is operating/serving which services and service capabilities.</p> <p>Our design consists of various service discovery techniques.</p></div> <div class="content-block__examples"></div></div></div> <div class="content-block"><div class="content-block__heading"></div> <div class="content-block__body"><div class="content-block__cont"><h2 id="udp-anycast"><a href="#udp-anycast" class="header-anchor">#</a> UDP Anycast</h2> <p>We have UDP anycast which allows the devices in the same network to nag each other continuously with a specific set of service requests to form a cluster initiation.</p> <p><strong>NOTE:</strong> Convergance of the UDP anycast might take longer time than the other zeroconf approaches.</p> <div type="example" class="examples"><div class="language-rust extra-class"><pre class="language-rust"><code><span class="token attribute attr-name">#[derive(Serialize, Deserialize, Debug, Clone, Ord, PartialOrd, PartialEq)]</span>
<span class="token keyword">struct</span> ExampleSDReply <span class="token punctuation">{</span>
ip<span class="token punctuation">:</span> String<span class="token punctuation">,</span>
port<span class="token punctuation">:</span> u16<span class="token punctuation">,</span>
<span class="token punctuation">}</span>
<span class="token keyword">let</span> epidemic_sd_config <span class="token operator">=</span> ExampleSDReply <span class="token punctuation">{</span>
ip<span class="token punctuation">:</span> <span class="token string">&quot;127.0.0.1&quot;</span><span class="token punctuation">.</span><span class="token function">into</span><span class="token punctuation">(</span><span class="token punctuation">)</span><span class="token punctuation">,</span>
port<span class="token punctuation">:</span> <span class="token number">1337</span><span class="token punctuation">,</span> <span class="token comment">// Cluster Formation Port of this instance</span>
<span class="token punctuation">}</span><span class="token punctuation">;</span>
<span class="token keyword">let</span> reply <span class="token operator">=</span> ServiceDiscoveryReply <span class="token punctuation">{</span>
serialized_data<span class="token punctuation">:</span> serde_json<span class="token punctuation">::</span><span class="token function">to_string</span><span class="token punctuation">(</span><span class="token operator">&amp;</span>epidemic_sd_config<span class="token punctuation">)</span><span class="token punctuation">.</span><span class="token function">unwrap</span><span class="token punctuation">(</span><span class="token punctuation">)</span><span class="token punctuation">,</span>
<span class="token punctuation">}</span><span class="token punctuation">;</span>
<span class="token comment">// Initialize receiver channels</span>
<span class="token keyword">let</span> <span class="token punctuation">(</span>tx<span class="token punctuation">,</span> discoveries<span class="token punctuation">)</span> <span class="token operator">=</span> <span class="token function">channel</span><span class="token punctuation">(</span><span class="token punctuation">)</span><span class="token punctuation">;</span>
<span class="token comment">// Register seeker endpoint</span>
sd<span class="token punctuation">.</span><span class="token function">register_seeker</span><span class="token punctuation">(</span>tx<span class="token punctuation">)</span><span class="token punctuation">.</span><span class="token function">unwrap</span><span class="token punctuation">(</span><span class="token punctuation">)</span><span class="token punctuation">;</span>
<span class="token comment">// Sometimes you seek for nodes,</span>
<span class="token comment">// sometimes you need to be a listener to respond them.</span>
<span class="token keyword">if</span> <span class="token keyword">let</span> <span class="token function">Some</span><span class="token punctuation">(</span>_<span class="token punctuation">)</span> <span class="token operator">=</span> seeker <span class="token punctuation">{</span>
sd<span class="token punctuation">.</span><span class="token function">seek_peers</span><span class="token punctuation">(</span><span class="token punctuation">)</span><span class="token punctuation">.</span><span class="token function">unwrap</span><span class="token punctuation">(</span><span class="token punctuation">)</span><span class="token punctuation">;</span>
<span class="token punctuation">}</span> <span class="token keyword">else</span> <span class="token punctuation">{</span>
sd<span class="token punctuation">.</span><span class="token function">set_listen_for_peers</span><span class="token punctuation">(</span><span class="token keyword">true</span><span class="token punctuation">)</span><span class="token punctuation">.</span><span class="token function">unwrap</span><span class="token punctuation">(</span><span class="token punctuation">)</span><span class="token punctuation">;</span>
<span class="token punctuation">}</span>
<span class="token keyword">for</span> discovery <span class="token keyword">in</span> discoveries<span class="token punctuation">.</span><span class="token function">iter</span><span class="token punctuation">(</span><span class="token punctuation">)</span> <span class="token punctuation">{</span>
<span class="token keyword">let</span> discovery<span class="token punctuation">:</span> ExampleSDReply <span class="token operator">=</span>
serde_json<span class="token punctuation">::</span><span class="token function">from_str</span><span class="token punctuation">(</span><span class="token operator">&amp;</span>discovery<span class="token punctuation">.</span>serialized_data<span class="token punctuation">)</span><span class="token punctuation">.</span><span class="token function">unwrap</span><span class="token punctuation">(</span><span class="token punctuation">)</span><span class="token punctuation">;</span>
<span class="token keyword">if</span> discovery<span class="token punctuation">.</span>port <span class="token operator">!=</span> epidemic_sd_config<span class="token punctuation">.</span>port <span class="token punctuation">{</span>
<span class="token function">debug!</span><span class="token punctuation">(</span><span class="token string">&quot;Seed node address came&quot;</span><span class="token punctuation">)</span><span class="token punctuation">;</span>
<span class="token keyword">let</span> seed_node <span class="token operator">=</span> <span class="token function">format!</span><span class="token punctuation">(</span><span class="token string">&quot;{}:{}&quot;</span><span class="token punctuation">,</span> discovery<span class="token punctuation">.</span>ip<span class="token punctuation">,</span> discovery<span class="token punctuation">.</span>port<span class="token punctuation">)</span><span class="token punctuation">;</span>
<span class="token comment">// We have received a discovery request.</span>
<span class="token punctuation">}</span>
<span class="token punctuation">}</span>
</code></pre></div></div></div> <div class="content-block__examples"></div></div></div></div> <div class="content__footer-container"><div class="content__footer"><!----> <!----></div></div></div></div></div></div><div class="global-ui"></div></div>
<script src="/assets/js/app.a6f18760.js" defer></script><script src="/assets/js/3.294f849a.js" defer></script><script src="/assets/js/7.9042a811.js" defer></script>
</body>
</html>