Ecosyste.ms: Awesome
An open API service indexing awesome lists of open source software.
https://github.com/sorz/ssmanager
A python module managing large amount of running Shadowsocks server instances.
https://github.com/sorz/ssmanager
python shadowsocks
Last synced: about 2 months ago
JSON representation
A python module managing large amount of running Shadowsocks server instances.
- Host: GitHub
- URL: https://github.com/sorz/ssmanager
- Owner: sorz
- License: mit
- Created: 2016-05-02T12:35:00.000Z (over 8 years ago)
- Default Branch: master
- Last Pushed: 2017-12-21T22:16:41.000Z (about 7 years ago)
- Last Synced: 2024-08-03T17:12:21.115Z (5 months ago)
- Topics: python, shadowsocks
- Language: Python
- Homepage:
- Size: 66.4 KB
- Stars: 22
- Watchers: 3
- Forks: 6
- Open Issues: 0
-
Metadata Files:
- Readme: README.md
- License: LICENSE
Awesome Lists containing this project
- awesome-network-stuff - **21**星
README
# ssmanager
A python module interact with manager-mode
[shadowsocks-libev](https://github.com/shadowsocks/shadowsocks-libev)
or [shadowsocks-python](https://github.com/shadowsocks/shadowsocks) server.> Shadowsocks-libev consists of five components. ss-manager(1) is a controller
> for multi-user management and traffic statistics, using UNIX domain socket
> to talk with `ss-server`.This module works like `ss-manager`,
except it provide Python API instead of UNIX domain socket or UDP API.It has own implementation rather than communicate with `ss-manager`, hence
the only dependence is `ss-server`.Since version 0.2.0, it plays happily with not only ss-libev but also the
Python port.## Install
```
$ pip install git+https://github.com/sorz/ssmanager.git
```## Usage
Example:
```python
from ssmanager import Server
from ssmanager.sslibev import Manager
# For Python port, use:
# from ssmanager.sspy import Managermanager = Manager(ss_bin='/usr/bin/ss-server')
# Point to ssserver if using Python port.
manager.start()server = Server(1234, 'password', 'aes-256-cfb',
udp=True, fast_open=True)
manager.add(server)
manager.remove(server) # Or manager.remove(1234)servers = [Server(...), ...]
manager.update(servers)manager.stat()
# Return a dict of { port_number: total_traffic_in_bytes }.manager.stop()
```It's easy to build multiple-user/port Shadowsocks servers with a centrally
server who distributes user configurations using ssmanager. A simple example
is following.Upload a JSON file to, for example, http://example.com/ss-profiles.json.
The JSON contains all profiles of Shadowsocks users:```javascript
[{"port": 8001, "password": "test123", "method": "chacha20"},
{"port": 8002, "password": "123test", "method": "aes-256-cfb"}]
```Following script grab this JSON every 2 minutes and update its configs if
content of the JSON changed. (Exception handling is omited.)```python
import time, requests
from ssmanager import Server
from ssmanager.sspy import Managermanager = Manager()
manager.start()while True:
profiles = requests.get('http://example.com/ss-profiles.json').json()
manager.update([Server(**p) for p in profiles])
time.sleep(120)
```## Related projects
- [ssmanager-nopanel](https://github.com/fzinfz/ssmanager-nopanel):
ssmanager web daemon, supports multi methods & influxdb.
- [yassp-server](https://github.com/sorz/yassp-server):
manage Shadowsocks server instances via HTTP APIs.