Giter Club home page Giter Club logo

shadowsocks-py-mu's Introduction

About Shadowsocks-python Manyuser

This is a multi-user version of shadowsocks-python. Requires a mysql database or a panel which supports SS MU API.

Requirement

  1. Python >= 2.5 (python=2.5 need to install extra library: pip install simplejson)
  2. MySQL >= 5 (if using database)
  3. A Panel with MU API, such as SS-Panel V3. (if using MU API)

Install Instructions for Database User

  1. install cymysql library by pip install cymysql
  2. create a database named shadowsocks
  3. import shadowsocks.sql into the shadowsocks database
  4. copy config_example.py to config.py and edit it following the notes inside (but DO NOT delete the example file). You DO NOT need to edit the API section.
  5. TestRun cd shadowsocks && python servers.py (not server.py)

Install Instructions for MU API User

  1. copy config_example.py to config.py and edit it following the notes inside (but DO NOT delete the example file). You DO NOT need to edit the Database section.
  2. TestRun cd shadowsocks && python servers.py (not server.py)

Install Instructions for Docker User

  1. build the docker: docker build -t shadowsocks-mu .

  2. create a config file as above

  3. run the docker (random free ports will be allocated):

    docker run -it \
        -v /PATH/TO/CONFIG/FILE:/shadowsocks/shadowsocks/config.py \
        -v /PATH/TO/LOG/FILE:/shadowsocks/shadowsocks/shadowsocks.log \
        -p PORT_START-PORT_END \
        shadowsocks-mu
    

    If you want to use fixed ports (e.g. port 443 of the host being matched with 443 of the docker), use -p PORT_START-PORT_END:PORT_START-PORT_END instead.

    Note: /PATH/TO/CONFIG/FILE & /PATH/TO/LOG/FILE should be absolute paths

Reminders for Windows User

  1. install pyuv library by pip install pyuv
  2. if git is not configured in your %PATH% environmental variable, you can create a file named .nogit to avoid using git describe

If no exceptions are thrown, the server will startup. By default, logging is enabled. You should be able to see this kind of thing in shadowsocks.log(default log file name)

Jun 24 01:06:08 INFO -----------------------------------------
Jun 24 01:06:08 INFO Multi-User Shadowsocks Server Starting...
Jun 24 01:06:08 INFO Current Server Version: 3.1.0-1-gc2ac618

Jun 24 01:10:11 INFO api downloaded
Jun 24 01:10:13 INFO api skipped port 443
Jun 24 01:10:13 INFO Server Added:   P[XXXXX], M[rc4-md5], E[[email protected]]
Jun 24 01:10:13 INFO Server Added:   P[XXXXX], M[rc4-md5], E[[email protected]]

Explanation of the log output

When adding server:

P[XXX] client port (assigned by database)

M[XXX] client encryption method

E[XXX] client email address

When data connection being established/blocked

U[XXX] client port (assigned by database)

RP[XXX] remote port (the port the client wants to connect)

A[XXX-->XXX] from the client address to the remote address

Database user table column

passwd server pass

port server port

t last connecting time

u no usage for this shadowsocks server (kept unchanged) but essential for some panels

d accumulated upload + download data transfer

method custom encryption method

enable/switch indicating whether the user is enabled

transfer_enable maximum accumulated data transfer allowed - if u + d > transfer_enable, service for this client will be stopped (other clients are not affected)

Compatibility with frontend UIs

It is fully compatible (through MU API) with ss-panel V3 .

Open source license

This program is licensed under Apache License 2.0

shadowsocks-py-mu's People

Contributors

clowwindy avatar fsgmhoward avatar mengskysama avatar zuoruizhi avatar shell909090 avatar nekolab avatar made-by-love avatar fa08c avatar felixonmars avatar v3aqb avatar anthonywong avatar htc550605125 avatar coderfox avatar loggerhead avatar zh-liang-cn avatar humiaozuzu avatar jlund avatar forest2087 avatar everplays avatar est avatar ficapy avatar supermariogo avatar henryhuang avatar lazybios avatar mitnk avatar netroby avatar peterfyj avatar sky-chen avatar smounives avatar sybblow avatar

Watchers

James Cloos avatar

Recommend Projects

  • React photo React

    A declarative, efficient, and flexible JavaScript library for building user interfaces.

  • Vue.js photo Vue.js

    ๐Ÿ–– Vue.js is a progressive, incrementally-adoptable JavaScript framework for building UI on the web.

  • Typescript photo Typescript

    TypeScript is a superset of JavaScript that compiles to clean JavaScript output.

  • TensorFlow photo TensorFlow

    An Open Source Machine Learning Framework for Everyone

  • Django photo Django

    The Web framework for perfectionists with deadlines.

  • D3 photo D3

    Bring data to life with SVG, Canvas and HTML. ๐Ÿ“Š๐Ÿ“ˆ๐ŸŽ‰

Recommend Topics

  • javascript

    JavaScript (JS) is a lightweight interpreted programming language with first-class functions.

  • web

    Some thing interesting about web. New door for the world.

  • server

    A server is a program made to process requests and deliver data to clients.

  • Machine learning

    Machine learning is a way of modeling and interpreting data that allows a piece of software to respond intelligently.

  • Game

    Some thing interesting about game, make everyone happy.

Recommend Org

  • Facebook photo Facebook

    We are working to build community through open source technology. NB: members must have two-factor auth.

  • Microsoft photo Microsoft

    Open source projects and samples from Microsoft.

  • Google photo Google

    Google โค๏ธ Open Source for everyone.

  • D3 photo D3

    Data-Driven Documents codes.