如何使用NetworKit对大型网络进行安全分析
<p><img title="如何使用NetworKit对大型网络进行安全分析" alt="如何使用NetworKit对大型网络进行安全分析" border="0" src="https://zhuji.jb51.net/uploads/img/202305/4b7140c59beeecf8fd4b1b28c5214259.jpg"></p>
<h3>
关于NetworKit</h3>
<p>
NetworKit是一款针对高性能网络安全分析的开源工具,该工具旨在帮助广大安全研究人员分析具备数千到数十亿条边界的大型网络。为了实现这个目标,该工具实现了非常高效的图形算法,其中许多算法是并行的,以利用多核架构来计算网络分析的标准度量。NetworKit专注于功能方面的可扩展性和全面性,而NetworKit也是一种算法工程的试验平台,其中包含了很多最新发表的处于研究中的新算法。</p>
<p>
NetworKit本质上是一个 Python模块,其中的高性能算法是基于C++开发的,并通过Cython工具链开放给Python。而Python反过来会为我们提供交互工作的能力,以及用于数据分析和科学计算的丰富工具环境。除此之外,如果需要的话,我们还可以构建NetworKit的核心并将其以本地库的形式使用。</p>
<h3>
工具要求</h3>
<p>
我们需要下列软件来将NetworKit安装为Python包:</p>
<ul>
<li>
一个现代C++编译器,例如g++(>= 6.1)、clang++(>= 3.9)或MSVC(>= 14.13);</li>
<li>
OpenMP(为实现并行性,通常随编译器提供);</li>
<li>
Python 3(6或更高版本);</li>
<li>
pip;</li>
<li>
CMake(6或更高版本,安装命令:“pip3 install cmake”);</li>
<li>
构建系统:Make或Ninja;</li>
<li>
Cython(29或更高版本,安装命令:“pip3 install cython”);</li>
</ul>
<h3>
工具安装</h3>
<p>
为了使用NetworKit,我们可以通过包管理器来安装,或从源码构建Python模块。</p>
<p>
通过包管理器安装:</p>
<p>
我们可以通过包管理器来安装最新版本的NetworKit。</p>
<p>
Pip安装:</p>
<ol class="dp-xml">
<li class="alt">
<span><span>pip3 install [--user] networkit </span></span>
</li>
</ol>
<p>
Conda安装:</p>
<ol class="dp-xml">
<li class="alt">
<span><span>conda config --add channels conda-forge </span></span>
</li>
<li>
</li>
<li class="alt">
<span>conda install networkit [-c conda-forge] </span>
</li>
</ol>
<p>
Brew安装:</p>
<ol class="dp-xml">
<li class="alt">
<span><span>brew install networkit </span></span>
</li>
</ol>
<p>
Spack安装:</p>
<ol class="dp-xml">
<li class="alt">
<span><span>spack install py-networkit </span></span>
</li>
</ol>
<p>
从源码构建Python模块</p>
<ol class="dp-xml">
<li class="alt">
<span><span>git clone https://github.com/networkit/networkit networkit </span></span>
</li>
<li>
</li>
<li class="alt">
<span>cd networkit </span>
</li>
<li>
</li>
<li class="alt">
<span>python3 setup.py build_ext [-jX] </span>
</li>
<li>
</li>
<li class="alt">
<span>pip3 install -e . </span>
</li>
</ol>
<h3>
工具使用样例</h3>
<p>
在下面的工具演示样例中,我们将生成一个具有十万个节点的随机双曲线图,并使用PLM方法计算其网络(社区):</p>
<ol class="dp-xml">
<li class="alt">
<span><span class="tag">></span><span class="tag">></span><span class="tag">></span><span> import networkit as nk </span></span>
</li>
<li>
</li>
<li class="alt">
<span><span class="tag">></span><span class="tag">></span><span class="tag">></span><span> </span><span class="attribute">g</span><span> = </span><span class="attribute-value">nk</span><span>.generators.HyperbolicGenerator(1e5).generate() </span></span>
</li>
<li>
</li>
<li class="alt">
<span><span class="tag">></span><span class="tag">></span><span class="tag">></span><span> </span><span class="attribute">communities</span><span> = </span><span class="attribute-value">nk</span><span>.community.detectCommunities(g, </span><span class="attribute">inspect</span><span>=</span><span class="attribute-value">True</span><span>) </span></span>
</li>
<li>
</li>
<li class="alt">
<span>PLM(balanced,pc,turbo) detected communities in 0.14577102661132812 </span>
</li>
<li>
</li>
<li class="alt">
<span>solution properties: </span>
</li>
<li>
</li>
<li class="alt">
<span>------------------- ----------- </span>
</li>
<li>
</li>
<li class="alt">
<span># communities 4536 </span>
</li>
<li>
</li>
<li class="alt">
<span>min community size 1 </span>
</li>
<li>
</li>
<li class="alt">
<span>max community size 2790 </span>
</li>
<li>
</li>
<li class="alt">
<span>avg. community size 22.0459 </span>
</li>
<li>
</li>
<li class="alt">
<span>modularity 0.987243 </span>
</li>
<li>
</li>
<li class="alt">
<span>------------------- ----------- </span>
</li>
</ol>
<h3>
将NetworKit以代码库的形式使用</h3>
<p>
除了直接使用NetworKit之外,我们还可以将NetworKit以代码库的形式使用。在下面的示例中,我们将在/usr/local中编译和安装NetworKit:</p>
<ol class="dp-xml">
<li class="alt">
<span><span>cmake .. </span></span>
</li>
<li>
</li>
<li class="alt">
<span>make -jX install </span>
</li>
</ol>
<p>
安装好NetworKit之后,我们就可以在C++应用程序中通过下列方法来使用include指令了:</p>
<ol class="dp-xml">
<li class="alt">
<span><span>#include </span><span class="tag"><</span><span class="tag-name">networkit</span><span>/graph/Graph.hpp</span><span class="tag">></span><span> </span></span>
</li>
</ol>
<p>
我们还可以通过以下方法编译我们的源码:</p>
<ol class="dp-xml">
<li class="alt">
<span><span>g++ my_file.cpp -lnetworkit </span></span>
</li>
</ol>
<h3>
许可证协议</h3>
<p>
本项目的开发与发布遵循MIT开源许可证协议。</p>
<h3>
项目地址</h3>
<p>
NetworKit:【GitHub传送门】</p>
<p>
原文地址:https://www.freebuf.com/articles/network/305667.html</p>
頁:
[1]