内容简介:之前公众号上有人说,我回大陆了会有一波科学上网的教程,今天的推文算一个吧。真的是被你们言中了!做为Bioconductor包作者,而代理其实也挺恼火的,因为各种协议啊,你要各种设置啊,
之前公众号上有人说,我回大陆了会有一波科学上网的教程,今天的推文算一个吧。真的是被你们言中了!
做为Bioconductor包作者,而 git push
传代码到Bioconductor上是被封的。这很是恼火,随着10月份将迎来新一版本的Bioconductor发布,不能够push代码是多么惨的一件事。
代理其实也挺恼火的,因为各种协议啊,你要各种设置啊, http/https/ssh/git
都是各种配置,其实我只要有一个 socks5
的代理,然后你们所有需要走代理的程序都通过它就好了。
谁特么有空天天在琢磨怎么配置各种不同协议的代理!只要我们想得到的,一般都有人做了。
于是万能的github上找到了 proxychains
, https://github.com/haad/proxychains
。
A hook preloader that allows to redirect TCP traffic of existing dynamically linked programs through one or more SOCKS or HTTP proxies
它强制给定程序发起的TCP连接通过事先配置的代理。可以涵盖所有需要代理的情景。就以git为例,没有proxychains的话,就必须为每个协议( https
, git
, ssh
)按照git文档的要求分别设置代理,过程复杂且不稳定。有了 proxychains
,这些完全可以不用管,当然应用场景不限于 git
,任何一个需要代理的命令行程序都是一样在运行的指令前面加 proxychains
完事。
Arch安装很容易:
yay -S proxychains-ng
安装之后,打开 /etc/proxychains.conf
,注释掉下面这行(disable远程DNS解析,有DNS污染风险)。 proxy_dns
最后添加如下行: socks5 127.0.0.1 32997
上面这个代理是我自己机器上跑了某著名软件,用于每日科学上网。
我平时是同时 push
到Bioconductor和github上的,所以我不会跑完一个 git push
再跑一个,而是写在 Makefile
里,自动化这个过程,我只需要 make push
指令就OK。
所以此处我用的指令是:
proxychains make push
这样就加了代理。
$ proxychains make push #### #### 实际的指令,有两条,分别push到两个服务器 #### [proxychains] config file found: /etc/proxychains.conf [proxychains] preloading /usr/lib/libproxychains4.so [proxychains] DLL init: proxychains-ng 4.13 [proxychains] DLL init: proxychains-ng 4.13 [proxychains] DLL init: proxychains-ng 4.13 [proxychains] DLL init: proxychains-ng 4.13 [proxychains] DLL init: proxychains-ng 4.13 [proxychains] DLL init: proxychains-ng 4.13 [proxychains] DLL init: proxychains-ng 4.13 git push upstream master;\ git push origin master #### #### 第一条指令,push到Bioconductor #### [proxychains] DLL init: proxychains-ng 4.13 [proxychains] DLL init: proxychains-ng 4.13 [proxychains] DLL init: proxychains-ng 4.13 [proxychains] Strict chain ... 127.0.0.1:32997 ... 34.192.48.227:22 ... OK [proxychains] DLL init: proxychains-ng 4.13 Enumerating objects: 56, done. Counting objects: 100% (56/56), done. Delta compression using up to 4 threads Compressing objects: 100% (34/34), done. Writing objects: 100% (41/41), 4.87 KiB | 4.87 MiB/s, done. Total 41 (delta 32), reused 11 (delta 7) To git.bioconductor.org:packages/ggtree.git c372741..e84c1f7 master -> master #### #### 第二条指令,push到github #### [proxychains] DLL init: proxychains-ng 4.13 [proxychains] DLL init: proxychains-ng 4.13 [proxychains] Strict chain ... 127.0.0.1:32997 ... 192.30.253.112:22 ... OK [proxychains] DLL init: proxychains-ng 4.13 Enumerating objects: 11, done. Counting objects: 100% (11/11), done. Delta compression using up to 4 threads Compressing objects: 100% (6/6), done. Writing objects: 100% (6/6), 843 bytes | 843.00 KiB/s, done. Total 6 (delta 5), reused 0 (delta 0) remote: Resolving deltas: 100% (5/5), completed with 5 local objects. To github.com:GuangchuangYu/ggtree.git 92847e8..e84c1f7 master -> master
整个世界清静了,没法 push
到 Bioconductor
困扰我多时。而且经过了这个事件,以后打命令,只要需要代理的,都可以直接加 proxychains
搞定了,没有各种配置的烦恼。
以上所述就是小编给大家介绍的《一次解决所有代理问题》,希望对大家有所帮助,如果大家有任何疑问请给我留言,小编会及时回复大家的。在此也非常感谢大家对 码农网 的支持!
猜你喜欢:- 一键同步vscode所有扩展,解决多个设备!
- 容器编排无法解决微服务的所有问题,你还需要服务网格
- Rust语言恰巧是一门解决了Go语言所有问题的语言
- 如何监视 WPF 中的所有窗口,在所有窗口中订阅事件或者附加 UI
- 将所有类定义为Scala中的情况,只是让所有参数自动生成属性是否正确?
- Python捕获所有异常
本站部分资源来源于网络,本站转载出于传递更多信息之目的,版权归原作者或者来源机构所有,如转载稿涉及版权问题,请联系我们。
网络多人游戏架构与编程
格雷泽 (Joshua Glazer)、马达夫 (Sanjay Madhav) / 王晓慧、张国鑫 / 人民邮电出版社 / 2017-10-1 / CNY 109.00
本书是一本深入探讨关于网络多人游戏编程的图书。 全书分为13章,从网络游戏的基本概念、互联网、伯克利套接字、对象序列化、对象复制、网络拓扑和游戏案例、延迟、抖动和可靠性、改进的延迟处理、可扩展性、安全性、真实世界的引擎、玩家服务、云托管专用服务器等方面深入介绍了网络多人游戏开发的知识,既全面又详尽地剖析了众多核心概念。 本书的多数示例基于C++编写,适合对C++有一定了解的读者阅读。本......一起来看看 《网络多人游戏架构与编程》 这本书的介绍吧!