Ubuntu16.04搭建並使用shadowsocks

系統環境: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下,就可以了。



發表評論
所有評論
還沒有人評論,想成為第一個評論的人麼? 請在上方評論欄輸入並且點擊發布.
相關文章