奇文共赏,关于ShadowsocksR事件

题注:本文记录的是一项发生在 2015 年 8 月的真实事件。下面原文的全文可以在文末的地址看到。无论读者是出于因为什么原因看到这篇文章,是 Google 搜索的还是听人忽悠来的,请搞明白文章的背景。另外,希望读者能保持一定的理性,不要“精虫上脑”、一听到“妹子”就管不住自己。互联网上一条狗也可以假装是妹子

因为这篇文章引来的麻烦浪费了我太多时间,本文关闭评论并不再更新。想 DDoS 攻击的请便,反正已经用上了 CDN。有些人傻呵呵的以为自己“攻击”了几个小时,其实服务器才用了 1Mbps 的带宽,建议不要浪费绳命,让自己投入到更有意义的事情中。

16.12.25 更新:说好不更新的,结果还是更新了,堕落到跟某些**一样的水平。

看看这智商真捉鸡啊!正常人都能看懂上面一段斜体的因果关系:因为删一些脑残粉的评论太烦,所以关评;因为被人 DDoS,所以上了 CF。分开两句话的内容也能合成出“正义使者攻击反动网站,博主胆小如鼠关闭评论”的大标题,跟官媒学的这一套也是可以的。还真把自己当什么大V,让脑残粉群起攻之,胆小如鼠的博主都真的笑、笑出声了。

最后加一句:原版 Shadowsocks 软件并没有停更,而且也加入了某些反检测、反攻击的新特性。你们教主很多代码也都是直接 merge 过去的,点开 Commits 就能看到了。要用哪个版本是每个人的自由,但是请不要歪曲事实。还是开头那句话,只是记述真实事件,供参考。


个人建议使用原版 Shadowsocks 软件,比较安全。

以下内容,黑色为 ShadowsocksR 作者的原文,蓝色为本博客(微博 @_小噗)的评论。

背景:某作者([email protected])用了[email protected]的shadowsocks-csharp(现在叫shadowsocks-windows)的代码,原始代码是GPL的,然而新作者发布了二进制但不开源,原作者吐槽了一下,新作者发了这么一篇然后撂蹶子走了。

本版本作为此分支最后一个版本,本分支不再进行维护,也删除了升级提示。

说过的开源承诺一定会兑现,不过兑现得有点偏早了,(GPL要求你从发布的时候就要公开源代码,没有早晚之说)本版本预期的目标只实现了小部分,之后的也不再去实现了。两个可公开的预期目标:1.实现让原版TCP协议过渡到更安全的协议;(小弟才疏学浅,比TCP协议更安全的是啥协议?四层除了TCP和UDP,还准备发明个TCPS?)2.实现让原作者与本版本竞速发布,让使用者受惠。(一口源代码喷在了屏幕上)不过黑脸既然当不下去了,就不当了,爱咋整咋整。(小盆友你几岁啦)至于署名问题,你不怕脑残党来查水表但我怕,你以为这是常用网名么,就算倒台了还要考虑脑残粉随便人肉砍人什么的。

另外,如果你发现某个需求是很有必要的,但和作者说了这个需求但作者不做,和你说“NO”,怎么办?(好问题,接着看)正如三个月前我就和作者说过UDP功能很有用,但作者就说PC上用UDP不如路由器上做。结果呢,那就自己做一个,把功能实现出来,(到这为止都说的非常好呀)把其它人的需求也引发出来,进而通过市场压力迫使作者把这个功能做出来就行了。(哈哈哈哈哈,为什么作者一直在说“市场压力”呢,我们继续赏文)但是你说你不会写代码,或者你写的实现不太好?没关系,我也是新手,我读的经济学,(当当当当!揭晓了!)我不是程序猿,开始动手改代码前我的C#才学了一星期,连select模型是啥也不知道,就算现在也不知道epoll是什么玩意儿,写的代码只能让机器能跑。你要是觉得和我联系也没有问题的话,那就发邮件到mmgac001[at]gmail[dot]com (诚心的打码)

现在的功能看起来这么“完善”,估计还是会继续三个月以前的状况了,不过呢,反正用户不是我,我继续去搞外汇套利得了。(替计算机界惋惜,失去了这么一个不可多得的经济学人才)

下面本噗来强调一下文中的亮点:

1. 最大的亮点,你给作者说了需求作者不做,你该怎么办?是的,如果对你很重要,你就自己做一个,这个是完全正确的。下一步,最好的做法——把你的代码PR给上游!如果你很懒,如果你不会(学经济的嘛),你就把它开源到你的GH上,让作者自己来merge!可是这位经济老兄,不但不开源(GPL violation),还要“市场竞争”,要“逼迫”作者更新……简直亮瞎了朕的狗眼,你说腾讯用了ffmpeg然后违反协议被挂在官网,那是因为怕竞对抄袭,您老这软件也不要钱,用您自己的话说,学了一个周csharp,我感觉写出的代码也就那样,有什么值得背负千古骂名闭源的?最大的可能就是,作者根本不懂开源、git、github这一套,就是小孩子心理自己做了一个方案然后挂出来炫耀而已了。(还有幸被某知名SB博客推荐了一下……于是才有了这一套事。)本噗的建议,外行想掺和开源这一套是好的,但是先把基础知识学好,不是随便写个代码发出来就是造福人类的,你只造福了用你软件的那点儿人,但是让上游作者很心痛。

2. 作者在文中说要切换到“比TCP更安全的协议”,在issue#28里说发现了ss协议的漏洞。虽然我没认真的看过ss协议,但是基本就是对IP层和TCP/UDP层的简单包装。作者可能不是科班出身,不知道现在国际上用的上网协议就这两种……TCP/UDP over IP……接下来,还是那句老话,发现了漏洞为什么不提出来呢?为什么非要在自己的闭源软件里实现呢?今天可以闭源发布客户端,明天就可以在里面加个病毒“造福”你的用户呀,这就是市场嘛。

总之,本噗还是那句话,外行人来自学计算机、写代码,大家都是欢迎的,但是千万不要做这种让内行外行都唾弃的事。GPL就是其它行业中所谓的“合同”,你在下载软件或源代码的时候就等于签订了合同,违反合同无论在哪一行都是不能接受的。

更新:有人给我指出,四层还有个“SCTP”……只想说,grow up吧孩子……任何人只要乐意,都可以在四层自己发明一个协议,你甚至可以在三层发明个IP协议的替代品,然后自己搭个全球互联网……然而操作系统不支持有个卵用啊…… http://stackoverflow.com/questions/2153700/what-kind-of-sctp-support-is-there-on-various-windows-versions

原文:https://github.com/breakwa11/shadowsocks-rss/blob/6623ad7806839562055bf7894320e8e628e88f94/readme.md

 

改造笔记本,使用光驱位托架安装第二块硬盘

这是我在11年底进行的一次改装,今天又改回去了,把整个过程及需要的部件记录一下。

更新:(2013年2月7日)文章末尾添加了这种改造方法的一些评价和感受。

首先上图介绍一下我在改装过程中用到的硬件:(手机晚上拍的,效果不好请见谅)

我的笔记本是华硕的 K42 型号(或者是 A42 X42 都是同一个系列),图中的 (1) 是笔记本右下方光驱插槽的位置。(2) 是在附近科技市场买的外置光驱盒,包括外壳、一个平挡板、两条线。

图中 (3) 是我从淘宝买的光驱托架,包含托架本身、(4) 硬盘挡板和 (6) 四颗防震螺丝钉,以及一些小螺丝刀等。(5) 是我从淘宝买的一块 OCZ Agility 3 60G SSD(固态硬盘),支持 SATA-3 6Gb/s 的传输规格,其他参数略。

图中 (7) 是笔记本自带的光驱,DVD-RW 刻录、擦写功能。(8) 是光驱本身的挡板,(9) 是光驱自带的一个固定板。

以上就是需要用到的或者购买的硬件。在笔记本原装的结构为:(7) 光驱–(8) 挡板–(9) 固定板,安装在接口 (1) 内,并用两颗螺丝钉固定。下面说一下改装的步骤:

「注:不同型号的笔记本电脑,在光驱 (7)、固定架 (9) 及其他一些小地方会不同,但是大概方法是相通的!」

1. 将固定光驱 (7) 的两颗螺丝钉(在笔记本 D 面,孔周围有“光盘”标志)拆下,轻抽出光驱。将 (7) 与 (9) 连接的四颗螺丝钉拆下分离,将 (7) 与 (8) 连接的卡子也轻拆分离。

2. 将托架自带的减震钉 (6) 拧到硬盘 (5) 的两侧四个孔里,将硬盘放到托架 (3) 中,插到 SATA 插口里并安好挡板 (4)。

3. 将刚才拆下的挡板 (8) 和固定板 (9) 都重新安装到新的托架 (3) 上,并将整个托架再推回 (1) 口中,上紧螺丝。

4. 将拆下的光驱 (7) 安装到外置光驱盒 (2) 中,即可使用外置 USB 光驱。

(更新内容)以下是这样改造之后的一些感受和评价,因为我已经这样使用了一年多,最近又换回去原配的光驱。

1. 这种改造方法,如果使用的新硬盘是 SSD,一定注意光驱位的接口通常速度较低,或者甚至整个主板的 SATA 接口都是 SATA-2 3Gb/s 的接口。如果是前一种情况,可以考虑将 SSD 装在原硬盘位(但是不一定好装);后一种就是我的情况,只能凑合用咯。

2. 双硬盘(即使不是 SSD)都会有性能上的飞跃,因为系统和用户文件的隔离,可以在开机时间、并行处理、大文件读写等方面发现系统性能不下降或明显上升。

3. 这样装好的硬盘,在 BIOS 引导时需要进行配置,这里我不细讲,懂的自然懂。

4. 如果是 SSD + HDD 的配置,建议 SSD 上只放系统和应用程序,并且将写入较大的数据文件夹移动到其他分区,以避免对 SSD 寿命造成影响。在我的博客里有 Windows 系统的教程,Linux 用户也可以自己做类似的迁移。