系統環境:Ubuntu 16.04
安裝
Linux不同的發行版執行的命令如下(最好在root下運行以下命令,原因我下面會說明):
Debian / Ubuntu:
apt-get install python-pip
pip install shadowsocks
CentOS:
yum install python-setuptools && easy_install pip
pip install shadowsocks
- 1
- 2
- 3
- 4
- 5
- 6
- 7
配置
cd /etc
mkdir ss
cd ss
sudo vim /etc/ss.json (退出vim:Esc退出插入模式+shift+zz)
//這裏的json文件是自己創建的,不是系統自帶
配置文件的內容大致如下:
{
"server":"服務器的ip",
"server_port":"服務器的端口",//自己買
"local_address":"127.0.0.1",
"local_port":1080,
"password":"密碼",
"timeout":300,
"method":"aes-256-cfb",
"fast_open":false
}
- 1
- 2
- 3
- 4
- 5
- 6
- 7
- 8
- 9
- 10
啓動ss客戶端
前兩步很簡單,可是有人就納悶了安裝好了不知道怎麼用,其實可以用sslocal -help 來查看幫助就知道了
sslocal -c /etc/ss.json
或
ssserver -c ss.json -d start
一條命令代理就可以啓動了。
這裏僅僅是啓動了shadowsocks還是不行的,我們還需要設置相關的代理。
轉換HTTP代理
Shadowsocks默認是用Socks5協議的,對於Terminal的get,wget等走Http協議的地方是無能爲力的,所以需要轉換成Http代理,加強通用性,這裏使用的轉換方法是基於Polipo的。
輸入命令安裝Polipo:
sudo apt-get install polipo
修改配置文件:
sudo gedit /etc/polipo/config
將下面的內容整個替換到文件中並保存:
# This file only needs to list configuration variables that deviate
# from the default values. See /usr/share/doc/polipo/examples/config.sample
# and "polipo -v" for variables you can tweak and further information.
logSyslog = false
logFile = "/var/log/polipo/polipo.log"
socksParentProxy = "127.0.0.1:1080"
socksProxyType = socks5
chunkHighMark = 50331648
objectHighMark = 16384
serverMaxSlots = 64
serverSlots = 16
serverSlots1 = 32
proxyAddress = "0.0.0.0"
proxyPort = 8123
- 1
- 2
- 3
- 4
- 5
- 6
- 7
- 8
- 9
- 10
- 11
- 12
- 13
- 14
- 15
- 16
- 17
- 18
重啓Polipo:
/etc/init.d/polipo restart
驗證代理是否正常工作:
export http_proxy=”http://127.0.0.1:8123/”
curl www.google.com
如果正常,就會返回抓取到的Google網頁內容。
另外,在瀏覽器中輸入http://127.0.0.1:8123/便可以進入到Polipo的使用說明和配置界面。
配置瀏覽器
在firefox中
preference->advanced->network->connection->settings中選擇手動設置代理,並將http代理設置爲127.0.0.1 端口8123 (就是之前第二步配置的port)
做到這步應該就能通過shadowsocks訪問了,但我遇到的電腦還是不行,後來將http代理下面的“Use this proxy server for all protocols(將代理應用到所有協議)”這個也鉤上纔可以了。
PS.如果跳過第二步,直接在第三部中配置http代理設置爲127.0.0.1 端口1080,有些文章中是這樣配置的,但是本人親測這樣無法連接上網。
Ubuntu開機後自動運行
現在可以科學上網了,可是每次開機都要手動打開終端輸入一條命令,雖然這條命令並不長,但是每次都去手動輸入,顯得自己很low,而且關掉終端代理就關閉了。
寫個腳本
我們可以在比如/home下新建個文件叫做shadow.sh,在裏面寫上我們啓動ss客戶端需要的命令,然後保存即可。
#!/bin/bash
#shadow.sh
sslocal -c /etc/shadowsocks.json
- 1
- 2
- 3
看可不可以我們到終端執行命令 sh /home/shadow.sh,如果成功的話會有信息輸出的。你也可以到瀏覽器去試試。這個時候你雖然輸入的少了,可是關了終端還是會掉的,我們可以讓他在後臺運行,nohup sh /home/shadow.sh &。
加入開機運行
這裏我們需要在/etc下編輯一個叫rc,local的文件,需要root權限,在終端先su獲取root權限。
這裏問題來了,因爲我們要開機啓動,要使用root權限來執行前面寫好的腳本,但如果你的shawdocks不是在root下裝的話,執行腳本是就會報錯:
“Traceback (most recent call last):
File “/home/gaoxw/.local/bin/sslocal”, line 7, in
from shadowsocks.local import main”
使用sudo安裝還是會報上面這個錯誤。
如果你有root帳號的話,然後vim /etc/rc.local編輯,在exit之前輸入nohup bash /home/shadow.sh>/home/d.txt & 保存。
這個時候你可以reboot重啓了,測試下看看能不能後臺自動運行,重啓你可以先去看下我們要他輸出d.txt,你竟然發現是 /home/shadow.sh line 3 :sslocal: command not found,打開瀏覽器果然是無法鏈接代理服務器。
經過一番搜索我們發現遠離linux是找不到sslocal這條命令?需要添加路徑,我們發現sslocal和ssserver這兩個命令是被存在 /usr/local/bin下面的,其實不用去profile添加了,直接把這兩個文件移動到/bin下,就可以了。