Python port of ShadowsocksR
You can not select more than 25 topics Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.

132 lines
3.4 KiB

13 years ago
shadowsocks
13 years ago
===========
11 years ago
Current version: 1.4.0 [![Build Status](https://travis-ci.org/clowwindy/shadowsocks.png?branch=master)](https://travis-ci.org/clowwindy/shadowsocks)
12 years ago
shadowsocks is a lightweight tunnel proxy which can help you get through firewalls.
13 years ago
Other ports and clients can be found [here](https://github.com/clowwindy/shadowsocks/wiki/Ports-and-Clients).
11 years ago
[中文说明](https://github.com/clowwindy/shadowsocks/wiki/Shadowsocks-%E4%BD%BF%E7%94%A8%E8%AF%B4%E6%98%8E)
11 years ago
11 years ago
Usage
13 years ago
-----------
First, make sure you have Python 2.6 or 2.7.
$ python --version
Python 2.6.8
11 years ago
Install Shadowsocks.
11 years ago
pip install shadowsocks
Create a file named `config.json`, with the following content.
12 years ago
11 years ago
{
"server":"my_server_ip",
"server_port":8388,
"local_port":1080,
"password":"barfoo!",
"timeout":600,
11 years ago
"method":"table"
11 years ago
}
13 years ago
Explanation of the fields:
11 years ago
server your server IP (IPv4/IPv6), notice that your server will listen to this IP
server_port server port
local_port local port
password a password used to encrypt transfer
11 years ago
timeout in seconds
11 years ago
method encryption method, "bf-cfb", "aes-256-cfb", "des-cfb", "rc4", etc. Default is table, which is not secure. "aes-256-cfb" is recommended
11 years ago
fast_open use TCP_FASTOPEN, true/false
12 years ago
11 years ago
`cd` into the directory of `config.json`. Run `ssserver` on your server. To run it in the background, run
`nohup ssserver > log &`.
12 years ago
11 years ago
On your client machine, run `sslocal`.
13 years ago
Change the proxy settings in your browser to
13 years ago
12 years ago
protocol: socks5
hostname: 127.0.0.1
port: your local_port
**Notice: If you want to use encryption methods other than "table", please install M2Crypto (See Encryption Section).**
11 years ago
11 years ago
It's recommended to use shadowsocks with AutoProxy or Proxy SwitchySharp.
11 years ago
Command line args
------------------
You can use args to override settings from `config.json`.
sslocal -s server_name -p server_port -l local_port -k password -m bf-cfb
ssserver -p server_port -k password -m bf-cfb
ssserver -c /etc/shadowsocks/config.json
11 years ago
Encryption
12 years ago
------------
11 years ago
Default encryption method table, which is not secure, is not recommended. Please use "aes-256-cfb" or "bf-cfb". "rc4" is not secure, either, please don't use it.
List of all encryption methods:
- aes-128-cfb
- aes-192-cfb
- aes-256-cfb
- bf-cfb
- camellia-128-cfb
- camellia-192-cfb
- camellia-256-cfb
- cast5-cfb
- des-cfb
- idea-cfb
- rc2-cfb
- rc4
- seed-cfb
- table
11 years ago
**If you want to use encryption method other than "table", please install [M2Crypto](http://chandlerproject.org/Projects/MeTooCrypto).**
11 years ago
Ubuntu:
11 years ago
apt-get install python-m2crypto
11 years ago
Others:
11 years ago
apt-get install openssl-dev swig
11 years ago
pip install M2Crypto
11 years ago
Please notice that some encryption methods are not available on some environments.
11 years ago
Performance
------------
12 years ago
You may want to install gevent for better performance.
12 years ago
$ sudo apt-get install python-gevent
12 years ago
Or:
12 years ago
$ sudo apt-get install libevent-dev python-pip
$ sudo pip install gevent
12 years ago
11 years ago
If both of your server and client are deployed on Linux 3.7+, you can turn on
fast_open for lower latency.
echo 3 > /proc/sys/net/ipv4/tcp_fastopen
11 years ago
License
-------
MIT
Bugs and Issues
----------------
Please visit [issue tracker](https://github.com/clowwindy/shadowsocks/issues?state=open)
11 years ago
Mailing list: http://groups.google.com/group/shadowsocks
11 years ago
Also see [troubleshooting](https://github.com/clowwindy/shadowsocks/wiki/Troubleshooting)