Linux下的使用(以ubuntu16.04為例)

huangbangqing12發表於2018-08-27

系統環境: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

配置

sudo vim /etc/shadowsocks.json 
//這裡的json檔案是自己建立的,不是系統自帶

配置檔案的內容大致如下:

{
    "server":"伺服器的ip",
    "server_port":伺服器的埠,
    "local_address":"127.0.0.1",
    "local_port":1080,
    "password":"密碼",
    "timeout":300,
    "method":"aes-256-cfb",
    "fast_open":false
}

啟動ss客戶端

前兩步很簡單,可是有人就納悶了安裝好了不知道怎麼用,其實可以用sslocal -help 來檢視幫助就知道了

sslocal -c /etc/shadowsocks.json

一條命令代理就可以啟動了。 
這裡僅僅是啟動了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

重啟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

看可不可以我們到終端執行命令 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下,就可以了。

相關文章