1
0
mirror of https://github.com/vimagick/dockerfiles.git synced 2025-01-10 04:19:24 +02:00
dockerfiles/obfsproxy/README.md

70 lines
1.5 KiB
Markdown
Raw Normal View History

2015-04-30 12:08:49 +02:00
OpenVPN over Obfsproxy
======================
2015-04-30 12:32:52 +02:00
Obfsproxy is a pluggable transport proxy written in python.
We can transport OpenVPN over Obfsproxy, so that firewall cannot detect it.
2015-04-30 13:39:20 +02:00
Obfsproxy provides several obfuscation method. I consider `scramblesuit` the best.
I will update this image if there's better one.
To use the example bellow, you should run `kylemanna/openvpn` container first.
Don't forget to edit `/etc/openvpn/openvpn.conf` to use `proto tcp`.
2015-04-30 12:32:52 +02:00
2015-04-30 12:08:49 +02:00
## docker-compose.yml
```
2015-04-30 13:39:20 +02:00
data:
image: busybox:latest
volumes:
- /etc/openvpn
server:
image: kylemanna/openvpn:latest
ports:
- "1194:1194/tcp"
volumes_from:
- data
cap_add:
- NET_ADMIN
restart: always
2015-04-30 12:08:49 +02:00
obfsproxy:
image: vimagick/obfsproxy:latest
ports:
- "4911:4911"
links:
2015-04-30 13:39:20 +02:00
- server:openvpn
environment:
- PASSWORD=J23TNHPJPAOQJLTCPLFD4CQYVFY6MEVP
- DEST_HOST=openvpn
- DEST_PORT=1194
- LISTEN_ADDR=0.0.0.0
- LISTEN_PORT=4911
restart: always
```
To link a existing `openvpn` container, please use `external_links` instead of `links`.
2015-04-30 13:46:33 +02:00
```
2015-04-30 13:39:20 +02:00
obfsproxy:
image: vimagick/obfsproxy:latest
ports:
- "4911:4911"
external_links:
2015-04-30 12:08:49 +02:00
- openvpn_server_1:openvpn
environment:
- PASSWORD=J23TNHPJPAOQJLTCPLFD4CQYVFY6MEVP
- DEST_HOST=openvpn
- DEST_PORT=1194
- LISTEN_ADDR=0.0.0.0
- LISTEN_PORT=4911
restart: always
```
2015-04-30 13:39:20 +02:00
The password should be encoded by Base32 with fixed length.
You can generate one via this command:
2015-04-30 13:46:33 +02:00
```
2015-04-30 13:39:20 +02:00
python -c 'import base64, os; print base64.b32encode(os.urandom(20))'
```