#proxy-server #socks5-proxy #proxy #firewall #shadowsocks #local-server #socks5

shadowsocks-service

shadowsocks is a fast tunnel proxy that helps you bypass firewalls

57 stable releases

1.22.0 Jan 2, 2025
1.21.2 Oct 24, 2024
1.21.0 Sep 22, 2024
1.20.3 Jul 28, 2024
1.10.2 Mar 28, 2021

#1283 in Network programming

Download history 3212/week @ 2024-10-07 4615/week @ 2024-10-14 6466/week @ 2024-10-21 4100/week @ 2024-10-28 3595/week @ 2024-11-04 4862/week @ 2024-11-11 4993/week @ 2024-11-18 5116/week @ 2024-11-25 3202/week @ 2024-12-02 6479/week @ 2024-12-09 7385/week @ 2024-12-16 1576/week @ 2024-12-23 2556/week @ 2024-12-30 3985/week @ 2025-01-06 4248/week @ 2025-01-13 4894/week @ 2025-01-20

15,871 downloads per month
Used in shadowsocks-rust

MIT license

3MB
85K SLoC

shadowsocks-service

License crates.io docs.rs

This is a port of shadowsocks.

shadowsocks is a fast tunnel proxy that helps you bypass firewalls.

Features

  • Local Server

    • SOCKS 5
    • SOCKS 4/4a (local-socks4)
    • HTTP (local-http)
    • Tunnel (local-tunnel)
    • Redir, aka Transparent Proxy (local-redir)
    • DNS (local-dns)
    • Tun (local-tun)
    • FakeDNS (local-fake-dns)
    • SIP008 Online Config (local-online-config)
  • Server

  • Manager


lib.rs:

Shadowsocks Service

https://shadowsocks.org/

shadowsocks is a fast tunnel proxy that helps you bypass firewalls.

Usage

Build shadowsocks and you will get at least 2 binaries: sslocal and ssserver

Write your servers in a configuration file. Format is defined in shadowsocks' documentation

For example:

{
   "server": "my_server_ip",
   "server_port": 8388,
   "local_address": "127.0.0.1",
   "local_port": 1080,
   "password": "mypassword",
   "timeout": 300,
   "method": "aes-256-cfb"
}

Save it in file shadowsocks.json and run local proxy server with

cargo run --bin sslocal -- -c shadowsocks.json

Now you can use SOCKS5 protocol to proxy your requests, for example:

curl --socks5-hostname 127.0.0.1:1080 https://www.google.com

On the server side, you can run the server with

cargo run --bin ssserver -- -c shadowsocks.json

Server should use the same configuration file as local, except the listen addresses for servers must be socket addresses.

Of course, you can also use cargo install to install binaries.

Dependencies

~13–54MB
~1M SLoC