1.3d稀疏卷积——spconv源码剖析(三)
2.新手提问:我们安装windows系统的时候,是不是把windows的源代码复制到本机硬盘下的C盘中了?
3.解析LinuxSS源码探索一探究竟linuxss源码
3d稀疏卷积——spconv源码剖析(三)
构建Rulebook
下面看ops.get_indice_pairs,位于:spconv/ops.py
构建Rulebook由ops.get_indice_pairs接口完成
get_indice_pairs函数具体实现:
主要就是完成了一些参数的校验和预处理。首先,对于3d普通稀疏卷积,根据输入shape大小,isa系统源码kernel size,stride等参数计算出输出输出shape,子流行稀疏卷积就不必计算了,输出shape和输入shape一样大小
准备好参数之后就进入最核心的get_indice_pairs函数。因为spconv通过torch.ops.load_library加载.so文件注册,所以这里通torch.ops.spconv.get_indice_pairs这种方式来调用该函数。
算子注册:在src/spconv/all.cc文件中通过Pytorch提供的OP Register(算子注册的方式)对底层c++ api进行了注册,可以python接口形式调用c++算子
同C++ extension方式一样,OP Register也是Pytorch提供的一种底层扩展算子注册的方式。注册的算子可以通过 torch.xxx或者 tensor.xxx的方式进行调用,该方式同样与pytorch源码解耦,增加和修改算子不需要重新编译pytorch源码。用该方式注册一个新的算子,流程非常简单:先编写C++相关的算子实现,然后通过pytorch底层的注册接口(torch::RegisterOperators),将该算子注册即可。
构建Rulebook实际通过python接口get_indice_pairs调用src/spconv/spconv_ops.cc文件种的getIndicePairs函数
代码位于:src/spconv/spconv_ops.cc
分析getIndicePairs直接将重心锁定在GPU逻辑部分,并且子流行3d稀疏卷积和正常3d稀疏卷积分开讨论,优先子流行3d稀疏卷积。
代码中最重要的3个变量分别为:indicePairs,indiceNum和gridOut,其建立过程如下:
indicePairs代表了稀疏卷积输入输出的映射规则,即Input Hash Table 和 Output Hash Table。这里分配理论最大的内存,它的shape为{ 2,kernelVolume,numAct},2表示输入和输出两个方向,kernelVolume为卷积核的volume size。例如一个3x3x3的卷积核,其volume size就是(3*3*3)。numAct表示输入有效(active)特征的数量。indiceNum用于保存卷积核每一个位置上的总的计算的次数,indiceNum对应中的count
代码中关于gpu建立rulebook调用create_submconv_indice_pair_cuda函数来完成,下面具体分析下create_submconv_indice_pair_cuda函数
子流线稀疏卷积
子流线稀疏卷积是调用create_submconv_indice_pair_cuda函数来构建rulebook
在create_submconv_indice_pair_cuda大可不必深究以下动态分发机制的运行原理。
直接将重心锁定在核函数:
prepareSubMGridKernel核函数中grid_size和block_size实则都是用的整形变量。其中block_size为tv::cuda::CUDA_NUM_THREADS,在include/tensorview/cuda_utils.h文件中定义,大小为。而grid_size大小通过tv::cuda::getBlocks(numActIn)计算得到,其中numActIn表示有效(active)输入数据的数量。
prepareSubMGridKernel作用:建立输出张量坐标(通过index表示)到输出序号之间的一张哈希表
见:include/spconv/indice.cu.h
这里计算index换了一种模板加递归的写法,看起来比较复杂而已。令:new_indicesIn = indicesIn.data(),可以推导得出index为:
ArrayIndexRowMajor位于include/tensorview/tensorview.h,其递归调用写法如下:
接着看核函数getSubMIndicePairsKernel3:
位于:include/spconv/indice.cu.h
看:
上述写法类似我们函数中常见的资金博奕指标源码循环的写法,具体可以查看include/tensorview/kernel_utils.h
NumILP按默认值等于1的话,其stride也是gridDim.x*blockDim.x。索引最大值要小于该线程块的线程上限索引blockDim.x * gridDim.x,功能与下面代码类似:
参考: blog.csdn.net/ChuiGeDaQ...
新手提问:我们安装windows系统的时候,是不是把windows的源代码复制到本机硬盘下的C盘中了?
t;安装和版本问题
1) eMule对Windows有什么要求?
eMule能在Windows 版本以上的Windows操作系统下运行。
1个好的P2P软件需要好的拨号网络的支持,所以Windows 和Windows ME的比较差网络运行情况可能会影响eMule的发挥;相对来说Windows 和Windows XP更适合使用eMule。
2) 弹出错误信息说oleacc.dll文件找不到?
使用Windows 的用户在启动eMule的时候可能会出现此错误信息。这个缺损的dll文件可以从Microsoft的 Windows System Update 处获得。
3) Installer和Binary的区别?
Installer文件用于第一次安装eMule,它包含了所有必须文件和帮助文档等。执行exe文件通过弹出的指示即可以安装eMule。
Binary是一个压缩档案文件,你需要把他解压缩(覆盖)到你想要安装的目录,通常用来做升级安装用。
4) 当我升级eMule版本时候怎样才能保留我的设置和下载到一半的文件信息?
你只需要安装(或解压)新版本的eMule到你原来版本的安装目录,eMule会自动更新eMule.exe文件,用户设置文件和其他一些用户信息文件都不会被覆盖,原来的设置等都将保留。
注意请关闭eMule之后才可以安全执行升级新版本,否则可能会导致不可知错误。
5) 如果从eDonkey/Overnet升级到eMule并保留原来的下载信息?
这取决于你原来使用的eDonkey/Overnet的版本。
0.版本以前的eDonkey使用和eMule部分兼用的系统,但是0.以后的eDonkey版本把下载的temp文件分成了很多独立的小文件,使eMule无法再使用。
老版本的eDonkey升级到eMule,你只需要把eMule的临时文件目录指向原来eDonkey的临时文件目录即可。
新版本的eDonkey升级到eMule,你可以先使用 OldPart 这个程序把未完成的eDonkey临时文件转化,再用 MetFile Regenerator 程序把它们还原成eMule可用的临时文件。不过,我强烈建议你在升级到eMule先完成原来的下载文件。
<二>服务器、连接和ID问题
1) 从哪里可以取得服务器列表?
– 官方eMule服务器列表更新网址
2) 哪个服务器是最快最好的?
没有绝对的最快或者最好的服务器。服务器是用来连接其他eMule用户、搜索文件和搜索源用的。当用户使用全局服务器搜索时,eMule会向列表里的每个服务器询问搜索结果并返回用户。
同样,下载文件的时候,eMule会在服务器内搜索速度最快的源。
3) 我需要多长时间更新一次服务器列表?
如果你正在使用或者经常使用eMule,那么就没有必要刻意去更新服务器列表。eMule的默认设置会在使用过程中不断更新服务器。
4) 为什么我的eMule连接不上服务器?
在连接到服务器以前会有短暂的等待时间,也有可能服务器当机或没有响应。亮度增强的源码如果eMule完全不连接,请确认你的服务器列表是最近更新的;也或者可能是Firewall和Router设置不当造成eMule的连接不畅通。
还有一点,你必须检查eMule中的 选项 -> 服务器 -> 仅自动连接到静态服务器 ,如果这个选项被选中的话,而同时尼列表中没有可用的静态服务器,eMule同样不会连接。
5) 为什么我得到的是low ID?
eMule近当以下端口打开的时候才会完全工作正常(取得high ID)
• TCP
• UDP
• TCP
当你使用代理服务器、或局域网上网的时候,你无法打开公网IP地址机器的以上端口,所以你会获得low ID。
6) Low ID何High ID有什么区别?
High ID就是拥有独立公网IP并且能提供端口给eMule工作的用户;此类用户可以和任何eMule兼容客户端连接与下载。
Low ID一般都是没有公网IP的内网用户,两个Low ID用户之间是无法直接连接的,所以Low ID的用户下载源会相对少一点(无法从其它Low ID用户那里下载)。
7) 为什么eMule总是从服务器掉线?
可能有以下原因导致eMule掉线:
• 下载列表中文件太多(低于v.a会有此问题)
• 过多的共享文件(低于v.a会有此问题)
• 服务器端的问题
• 普通的网络连接问题
通常情况下eMule会自动重新连接断开的服务器。这一情况并不影响下载。
<三>速度问题
1) 有哪些影响下载速度的因素?
以下这些实际问题可能会影响下载速度:
• eMule的设置;
• High ID (防火墙和路由的设置);
• eMule下载的时间长短;
• 一个下载文件所获得的源的多少;
• 临时文件的有效性;
• 下载文件的流行程度。
eMule设置中的不当(不恰当的限制、过多的连接数);Low ID(上一章中已介绍)以及过短的运行时间都会减缓下载的速度。还未普及的文件(例如新发布的资源)或者源很少的文件、或者临时文件(part)有损坏都会影响下载速度。
2) 怎么设置最好呢?
没有最完美的设置来实现速度最大化,因为下载速度的主要因素还是取决于每个人的Internet连接速度和所使用的操作系统。建议你使用eMule的设置向导来选择正确的设置,其中最重要的是你选对了你的Internet连接速度和操作系统。
举个例子,比较适用ADSL K带宽的设置如下:
Windows XP :-
下载能力: (= / 8)
上传能力: (= / 8)
下载限速:
上传限速: (= x 0,)
硬性限制:
最大连接数:
最大新建连接数/ 5 sec:
同时下载6-个文件比较合适。
Windows / ME :-
下载能力: (= / 8)
上传能力: (= / 8)
下载限速:
上传限速: (= x 0,)
硬性限制:
最大连接数:
最大新建连接数/ 5 sec:
同时下载不要超过个文件比较合适。
你无须太谨慎地限速,太苛刻的限速会阻塞eMule的连接,直接导致下载效果下降。上传限速基本上差不多应该在最大上传能力的%。
3) 怎样才能提高我的下载速度?
除了正确的设置以外,能决定速度的还有你所下载的文件本身。为了得到令人满意的速度速度,你尽可能做到以下方面:
• eMule尽量开的时间维持的长些,越长越好;
• 尽量避免只下载1个文件;
• 有选择余地的情况下,尽可能选择源多的文件下载(文件名后面数字表示源的数量);
• 新发布的文件(全新的文件)不可能速度快;
• 尽可能多的上传以获得比较高的积分;
4) 我可能会获得怎样的速度?
如果一切设置正常,并且在开始一段时间以后,你获得了 kB/s – kB/s的速度,那么可能在短时间内依然会很慢,但有时你却可能获得超过稳定速度2-3倍的速度。
5) 等待状态会维持多长时间?
等待状态中你可以从源那里看到QR:[x],这个数字x就是你的Queue Ranking,也就是上海菜单源码你在等待队伍中排在第几位,当然这个值越小越好。QR的存在显示了积分系统的意义,相对于源来说越高的积分就是越短地等待。如果你的QR值很高,并不表示你就无法从那个源那里下载到东西,eMule里存在很多公平的修正以减短等待时间。
<四>积分问题
1) 积分是什么?为什么我要增加积分?
积分是奖励那些上传的用户的,上传量越大积分越高。积分不是所有服务器之间通用的,它们仅仅通用于那些承认这些积分的服务器和客户(比如我在chinese edonkey server NO.1上的上传量很大,相对于那些连在No.1上的用户来说我的积分就很高) 。
积分是影响QR的主要因素,你积分越高,排队时间就会缩减的越短。
2) 从什么地方我可以看出我的积分多少?
为了防止使用作弊的方法篡改积分,所以你的积分不是储存在你的硬盘中,而是存在其他客户的硬盘中。要在本机上查询自己的积分是不可能的。
3) 我丢失/删除了我的clients.met文件,是不是我的积分就没了?
根据上个问题,丢失了这个文件,你自己的积分是不会消失的,而存在你机器上的相对你而言的他人的积分就没了。eMule建立并保存了备份文件以防止这种事情发生,名称是clients.met.BAK,你只需要把它重命名回clients.met即可。
4) 积分是否安全可靠?
eMule使用了一种加密方法key handshake以确保某个积分正确地属于某个人。只有在这种方法得到eMule的验证之后,这一积分才被授权给特定的某个人,否则eMule将不会承认对方的积分。
5) 什么情况下我的积分会得不到承认?
根据上一个问题所述,积分是经过加密并授权的。授权的验证密钥储存在preferences.dat和cryptkey.dat两个文件中。如果其中一个文件损坏或者丢失,你将不能得到对方的积分验证,eMule将不会承认原本应该属于你的积分。
如果你丢失了cryptkey.dat,eMule会强制删除preferences.dat。
<五>下载和共享问题
1) 为什么我下载的文件从列表中消失了?
可能是因为死机、或者升级到新版本造成的。
• 在 选项 -> 目录 里检查一下临时文件目录是不是正确。
• 把.part.met文件用它们的自动备份文件.part.met.BAK代替。
• 看看能否在帮助文件的Troubleshooting这一章节找到答案。
2) 传输状态的进度条表示的是什么意思?
不同的颜色表示了不同进度的活动性。
黑色
表示这部分文件你已经获得了。
红色
表示这部分文件没有源,源码小程序复制处于未知状态。
不同程度的蓝色,代表了这部分文件处于有源并活动的状态,蓝色越深表明源越多、活动性越强。
**
表示这部分文件正在被下载。
顶端的绿色条表示下载的进度。
完整的一条绿色状态表示整个文件已经下载完成。
一条深红色表示这个文件处于暂停或者停止状态。
如果你双击展开一个下载中的文件,其中的颜色有不一样的说法:
黑色说明你已经获得的部分。
蓝色部分是你仍需下载的部分。
灰色说明了这个源也缺损这部分文件。
绿色表示了当前正在下载的部分。
**表示未决的部分(已请求)。
在上传栏目中,同样有类似的颜色状态条:
黑色表示这名用户已经获得的部分。
灰色表示用户缺损的部分。
绿色表示你正在上传给这名用户的部分。
**表示未决的部分(已请求)。
共享文件的颜色状态条:
红色表示在已知的源中找不到的部分(未传播开)。
不同程度的蓝色告诉你这个文件的传播程度,颜色越深传播的越广。
3) 那些在来源一栏中的数字 xx / yy +aa (zz) 表是什么?
这些数字表示在下载中找到的源。
• xx - 可用的源的数目。
• yy - 总共找到的源的数目。
• + aa - 已请求另一个文件的源的数目(仅当你在高级控制中选择使用eMule才会显示这个数字)。
• zz - 现在正在和你传输的源的数目。
4) 为什么有些源显示“已请求另一个文件”?
eMule在对方源的队伍中只会占有一个位置。如果对方源内有你需要下载的2个以上文件,eMule只会为其中一个文件排队。当这个文件下载完成,eMule会自动切换到另一个文件并排队,以此类推。所以对方源就会对你现在无法进行排队的文件显示“已请求另一个文件”。这一功能称作A4AF(Ask for Another File)功能。
5) 过多连接数表示什么意思?
这表示找到的源的数目超过的你设定的最大连接数。这通常因为列表里有太多下载中的文件,或者用户的硬性限制太过苛刻所造成。
6) 我可以更改下载文件的文件名吗?
你可以任意更改下载的文件名,因为eMule不是凭文件名来判断一个文件,而是看每个文件不同的hash值来确定唯一的文件。右键点击一个下载名,选择 显示文件详情 --> 文件名,就可以更改文件名。建议先暂停或停止下载的状态下再改名。
7) 下载文件前面的红色和绿色的惊叹号表示什么?
惊叹号表示了对这一下载的等级的评定。
•
= 积极的等级(文件被网友评定为优等的、高质量的)
•
= 负面的等级(例如文件有病毒、文件是损毁的、或者文件是冒牌的)
8) 我怎么对某个文件进行评定或添加等级?
在共享文件中,对某个文件点右键,然后选择 更改这个文件的注释... 就可以修改这个文件的评论和评分。
希望大家对文件有公平公正的评价!
9) 我怎样才能知道一个文件是冒牌的呢?
你可以从找到的文件名判断。右键点击任意一个下载文件 -> 显示文件详情 -> 文件名。在这里你可以看到所有这个文件的其他文件名,如果其他文件名和这个文件相矛盾或者差很多,就可以判断可能是冒牌的(往往可以判断出是否是真的DVDRip或者枪版)。
) 我的下载为什么完成不了?
如果一个文件长时间没有下载完成,可能有以下2个方面的原因:
• 没有完整的源:-
如果状态条始终是红色的,从来未变成过蓝色;或者你找到的源都是和你缺损同一个部分的。那就说明这个文件的源缺损了,我们称这个文件死了。可能造成的原因是这个文件还没有全部传播出去(比如仅仅开头%曾经被人下载过),发布者就不共享这个文件了。
• 文件损毁:-
在eMule的服务器按钮下的Log窗口中,显示A corrupted part has been received。 如果你经常收到的是同一个文件的某个特定部分的损毁报告,那可能着整个文件都已经损毁了(这个情况非常罕见)。
) 下载完成了不过显示Errorious?
这个错误信息经常出现在以下情况:临时文件的存放目录和下载完成的目录不在同一个硬盘,或不在同一个硬盘分区上。eMule不能完成下载的可能性是因为下载完成的目录的那块硬盘分区没有足够的空间了。
) 我下载完成了,但是下载目录中却没有文件?
如果eMule显示一个下载已经完成,但文件却没有转移到下载完成目录,你可以手动调整。
首先,点击显示文件详情,比较文件的大小以确保它真的已经下载完成。同时记下.part文件的数字,并copy文件名到剪贴板。打开Windows资源管理器,在eMule临时文件目录中找到相应的.part文件,把它移动到你想要放置的目录,把它重命名成你剪贴板里复制过得你想要得文件名(注意扩展名已经不需要.part.met了)即可。
) 临时文件目录太占容量,我能否删除它?
这个文件夹内包含了所有你还未下载完成的文件,删除它就等于删除了你正在下载的文件!eMule在下载完成一个文件之前已经在临时文件目录建立了和源文件大小一样的临时文件,这点类似FlashGet,以确保不会下载到一半产生空间不够的问题。
) 我怎样做才能不共享文件呢?
eMule会自动共享以下文件:
• 正在下载中的文件;
• 存放在下载完成目录中的文件,和你手动指定的共享目录中的文件。
从以上2个目录中把文件移走就可以不共享这些文件(或者把共享目录的勾去掉),但是不共享文件的动作不会影响正在上传的文件传输。
<六>使用eMule的问题
) Tips
eMule中的绝大多数功能是很容易通过菜单理解并掌握的。右键单击很多东西,例如下载的文件等都可以弹出不同的操作菜单。ALT + x更可以打开一个快捷菜单,非常有用。
2) 怎样才能添加好友?
好友可以在消息窗口管理。右键点击好友列表,选择 添加好友,你必须有以下信息才能添加:
• IP地址 – 这是必须的,询问你要添加的人,向他获取IP;
• 端口 – 通常情况下是,同样这是必须的;
• 名字 – 可以输入任何名字,不是必须的。
另一种添加好友的方法是在传输窗口右键点击任何你获得的源,选择 添加为好友。这样eMule会自动获取所需要的信息。
3) 怎样分配好友的上传通道?
右键点击好友,选择“建立好友通道”,当你的好友排到能下载的位置时这个通道会马上激活。
4) 怎么样才能清空我的搜索历史纪录?
点击搜索栏,按CTRL(或ALT)然后按DEL。
5) eMule中的那些图标表示什么意思?
- 正在从此用户处下载或获取hash值。
- 在此用户处排队,或正在查询此用户。
- 正在连接到此用户。
- 此用户没有我需要的文件部分、或者已请求另一个文件,或者因为Low ID的关系无法连接。
- 用户的状态未知。
- 新进的消息。
- 普通的eDonkey和eMule用户。
- 兼容eMule协议的用户。
- 拥有高级分的用户。
- 有高级分的和兼容eMule协议的用户。
- 使用mlDonkey的用户。
- mlDonkey用户并拥有高积分。
- 使用eDonkey-Overnet-Hybrid用户。
-用户并拥有高积分。
- 使用Shareaza的用户。
- Shareaza的用户并拥有高积分。
- High ID的用户。
- Low ID的用户。
- 未连接到服务器。
- eMule系统栏图标(High ID)。
- eMule系统栏图标(Low ID)。
- eMule系统栏图标(未连接到服务器)。
- 积极的等级(文件被网友评定为优等的、高质量的)。
- 负面的等级(例如文件有病毒、文件是损毁的、或者文件是冒牌的)。
6) 我能踢除或阻止特定的用户么?
不行。这个功能将永远不会在eMule中出现,因为它和eMule的原本的共享理念相矛盾。
7) 为什么我搜索到的结果只有个?
搜索会大量增加服务器的负担,为了限制并减轻服务器的负担,eMule设定为返回用户的搜索结果最多只有个。如果你想要更多的无限制的搜索结果,请使用web based search Jigle(在eMule同时也可使用)。
8) 我需要把我的共享文件的优先权都设置成“高”或者“发布”吗?
不需要。优先权是照顾某些特定的文件的,这种优先的等级是相对的。如果你把所有文件都设置成“高”,和把所有文件都设置成“低”没有任何区别。
优先权在上传过程中会特别优待那些“高”和“发布”的文件,也就是说用户从你这里下载“发布”文件的可能性大于优先权“低”的那些文件,排队时间也是前者大大短于后者。
<七>其他问题
1) eMule运行的时候为什么许多应用程序会变慢?
这取决于eMule的设定,eMule可能会打开很多连接并占用很多的带宽。这会减慢其他的Internet应用程序,例如IE。尤其是不恰当的设置或太高的连接数会引起严重的整体效果的下降。
2) Mod 是什么?
eMule的源代码是开放的,其中有些人基于源代码开发了修正的版本,称之为Mod,例如eMule Plus。这些版本不被官方的eMule小队所支持。
3) Mods是否更快活更好呢?
通常情况下不是。官方的版本是经过长期的编译和测试所得,而modders往往不能在短时间内改变eMule的内核工作原理。所以Mod要取得速度上的突破往往是不太可能的。
Mods可能会带来一些新特性,同时一些新bugs,可能有些特性你很喜欢。不过有些mod可能带有负面特性,甚至损害整个网络的正常运作。这些制作粗劣的mod根本不能使用,官方的eMule正在努力减少这些mod存在的可能性,并在安全性方面争取杜绝这类mod的产生。
4) 我收到消息说我的eMule版本不能再继续使用。
官方版本eMule版本不会产生任何此类的消息,只可能是Mod版本的eMule才会有。如果你是用官方的版本,你可以安全的过滤掉这类消息。
5) 我从什么地方能得到更多的帮助?
如果阅读完FAQ你仍然有问题,你可以试试看以下几个方法:
• 到官方论坛发问(请在论坛内使用搜索功能已确定你要问的问题是否曾经出现过)。
• 到VeryCD的eMule问题求助区发问,发问前先确定你的问题是否被问过,谢谢!
• IRC - 在eMule中的IRC主窗口点击 连接 ,进入英语eMule帮助频道,键入 /join #emule。也有其他语言的聊天室, 例如 #emule-french, #emule-spanish 或 #emule-dutch。
6) eMule是匿名的吗?
P2P网络传输建立在两个客户的Internet连接之间,为了实现这个传输,双方的IP地址都是公开的。这个IP可使用户被识别和跟踪。
现阶段,让P2P软件匿名使用的条件是不成熟的(使用匿名代理服务器等方法具有众多的缺点)。
7) 为什么我关闭了eMule,而我的防火墙却持续报警说有连接端口?
相对于其他用户,你得eMule是被当作一个源存在的。你所连接过的服务器也会因为你共享过的文件而把你作为一个源传播给其他用户。当你关闭eMule以后,这一信息不会马上消除,所以别的eMule用户仍会尝试连接到你这个源。过一段时间,这样的连接就会消失(因为你的这个源已经失效)。
8) 什么是IP过滤器?
IP过滤器是用来阻挡某些特定的对网络有损害的IP地址的。最常用的就是 Lussnig's IP Filter。从他的网站下载一个名为ip.prefix的文件,重命名为ipfilter.dat然后复制到eMule的 ../config目录。然后到eMule里的 选项 -> 安全 -> IP过滤,然后按“刷新”按钮。
9) 使用eMule下载下来的AVI文件为什么不能播放?
这其实不是eMule的问题。建议你使用Windows Media Player来播放此类文件。具体需要安装的插件,请看播放DVDRip必备的软件。
) 怎样才能获得与AVI相应的字幕文件?
承接上一个问题,eMule中找到的源往往不是国内的机器上的,所以下载的DVDRip(AVI文件)通常没有配套的字幕,你可以去射手网寻找相应的字幕文件。下载下来之后只需要解压缩到和AVI文件一起,然后把字幕文件重命名和AVI文件同样的文件名即可(注意请保留srt sub等字幕文件的后缀名)。
解析LinuxSS源码探索一探究竟linuxss源码
被誉为“全球最复杂开源项目”的Linux SS(Secure Socket)是一款轻量级的网络代理工具,它在Linux系统上非常受欢迎,也成为了大多数网络应用的首选。Linux SS的源码的代码量相当庞大,也备受广大开发者的关注,潜心钻研Linux SS源码对于网络研究者和黑客们来说是非常有必要的。
我们以Linux 3. 内核的SS源码为例来分析,Linux SS的源码目录位于linux/net/ipv4/netfilter/目录下,在该目录下包含了Linux SS的主要代码,我们可以先查看其中的主要头文件,比如说:
include/linux/netfilter/ipset/ip_set.h
include/linux/netfilter_ipv4/ip_tables.h
include/linux/netfilter/x_tables.h
这三个头文件是Linux SS系统的核心结构之一。
接下来,我们还要解析两个核心函数:iptables_init函数和iptables_register_table函数,这两个函数的主要作用是初始化网络过滤框架和注册网络过滤表。iptables_init函数主要用于初始化网络过滤框架,主要完成如下功能:
1. 调用xtables_init函数,初始化Xtables模型;
2. 调用ip_tables_init函数,初始化IPTables模型;
3. 调用nftables_init函数,初始化Nftables模型;
4. 调用ipset_init函数,初始化IPset模型。
而iptables_register_table函数主要用于注册网络过滤表,主要完成如下功能:
1. 根据提供的参数检查表的有效性;
2. 创建一个新的数据结构xt_table;
3. 将该表注册到ipt_tables数据结构中;
4. 将表名及对应的表结构存放到xt_tableshash数据结构中;
5. 更新表的索引号。
到这里,我们就大致可以了解Linux SS的源码,但Learning Linux SS源码只是静态分析,细节的分析还需要真正的运行环境,观察每个函数的实际执行,而真正运行起来的Linux SS,是与系统内核非常紧密结合的,比如:
1. 调用内核函数IPv6_build_route_tables_sockopt,构建SS的路由表;
2. 调用内核内存管理系统,比如kmalloc、vmalloc等,分配SS所需的内存;
3. 初始化Linux SS的配置参数;
4. 调用内核模块管理机制,加载Linux SS相关的内核模块;
5. 调用内核功能接口,比如netfilter, nf_conntrack, nf_hook等,通过它们来执行对应的网络功能。
通过上述深入了解Linux SS源码,我们可以迅速把握Linux SS的构架和实现,也能熟悉Linux SS的具体运行流程。Linux SS的深层原理揭示出它未来的发展趋势,我们也可以根据Linux SS的现有架构改善Linux的网络安全机制,进一步开发出与Linux SS和系统内核更加融合的高级网络功能。