1
0
mirror of https://github.com/vimagick/dockerfiles.git synced 2025-01-24 05:16:44 +02:00
dockerfiles/tinc/README.md

148 lines
3.1 KiB
Markdown
Raw Normal View History

2015-06-23 09:00:07 +08:00
tinc
====
2016-04-05 19:33:25 +08:00
[tinc][1] is a Virtual Private Network (VPN) daemon that uses tunnelling and
2015-06-14 11:06:12 +08:00
encryption to create a secure private network between hosts on the Internet.
2016-07-01 02:41:31 +08:00
To use this image, you need to have basic knowledges of tinc. (See this [tutor][2])
2015-06-14 11:06:12 +08:00
2016-07-01 02:41:31 +08:00
## Directory Tree
2015-06-14 11:06:12 +08:00
```
~/fig/tinc/
├── docker-compose.yml
└── tinc/
2015-08-26 22:50:36 +08:00
└── netname/
   ├── hosts/
   │   ├── client
   │   ├── client-down*
   │   ├── client-up*
   │   └── server
   ├── rsa_key.priv
   ├── tinc.conf
   ├── tinc-down*
   └── tinc-up*
2015-06-14 11:06:12 +08:00
```
## docker-compose.yml
2016-02-08 16:47:09 +08:00
```yaml
2015-06-22 21:56:24 +08:00
tinc:
2015-06-14 11:06:12 +08:00
image: vimagick/tinc
ports:
2015-06-14 16:34:55 +08:00
- "655:655/tcp"
- "655:655/udp"
2015-06-14 11:06:12 +08:00
volumes:
2015-08-26 22:50:36 +08:00
- ./tinc:/etc/tinc
2015-06-22 21:56:24 +08:00
environment:
2016-07-01 02:41:31 +08:00
- IP_ADDR=1.2.3.4
2019-06-06 08:36:40 +08:00
- ADDRESS=10.20.30.1
- NETMASK=255.255.255.0
- NETWORK=10.20.30.0/24
- RUNMODE=server
2015-06-14 22:15:54 +08:00
cap_add:
2015-06-14 15:15:04 +08:00
- NET_ADMIN
2015-10-25 23:21:06 +08:00
dns: 8.8.8.8
2015-06-14 11:06:12 +08:00
restart: always
```
2016-07-01 02:41:31 +08:00
## Server Setup
2015-06-14 13:41:39 +08:00
2016-02-08 16:47:09 +08:00
```bash
2015-06-14 16:50:25 +08:00
# run
2015-06-14 18:24:22 +08:00
$ docker-compose up -d
2015-06-14 16:50:25 +08:00
# monitor
2015-06-14 18:24:22 +08:00
$ docker-compose logs
2015-06-14 16:50:25 +08:00
# stats
2016-07-01 02:41:31 +08:00
$ watch docker-compose exec tinc netstat -an
2015-06-14 16:50:25 +08:00
```
2016-07-01 02:41:31 +08:00
## Client Setup
2015-06-14 16:50:25 +08:00
2016-02-08 16:47:09 +08:00
```bash
2015-06-14 16:50:25 +08:00
# start
2015-06-23 15:13:00 +08:00
$ tincd -d -D -n netname --pidfile /tmp/tinc.pid
2015-06-14 16:50:25 +08:00
# stop
$ tincd -k --pidfile /tmp/tinc.pid
2015-06-14 13:41:39 +08:00
```
2016-07-01 02:41:31 +08:00
## Client Setup (openwrt)
2016-02-08 16:47:09 +08:00
```bash
$ opkg install tinc ip
$ cat > /etc/config/tinc
config tinc-net netname
option enabled 1
config tinc-host linkit
option enabled 1
option net netname
config tinc-host server
option enabled 1
option net netname
$ mkdir -p /etc/tinc/netname/hosts
$ cat > /etc/tinc/netname/tinc.conf
Name = linkit
Interface = tun0
ConnectTo = server
$ cat > /etc/tinc/netname/hosts/linkit
2019-06-06 08:36:40 +08:00
Subnet = 10.20.30.125
2016-02-08 16:47:09 +08:00
$ tincd -n netname -K < /dev/null
Generating 2048 bits keys:
......+++ p
.....+++ q
Done.
$ cat > /etc/tinc/netname/tinc-up
#!/bin/sh
ip link set $INTERFACE up
2019-06-06 08:36:40 +08:00
ip addr add 10.20.30.125/24 dev $INTERFACE
2016-02-08 16:47:09 +08:00
$ cat > /etc/tinc/netname/tinc-down
#!/bin/sh
2019-06-06 08:36:40 +08:00
ip addr del 10.20.30.125/24 dev $INTERFACE
2016-02-08 16:47:09 +08:00
ip link set $INTERFACE down
$ cat > /etc/tinc/netname/hosts/server-up
#!/bin/sh
ORIGINAL_GATEWAY=`ip route show | grep ^default | cut -d ' ' -f 2-3`
ip route add $REMOTEADDRESS $ORIGINAL_GATEWAY
ip route add 0.0.0.0/1 dev $INTERFACE
ip route add 128.0.0.0/1 dev $INTERFACE
$ cat > /etc/tinc/netname/hosts/server-down
#!/bin/sh
ORIGINAL_GATEWAY=`ip route show | grep ^default | cut -d ' ' -f 2-3`
ip route del $REMOTEADDRESS $ORIGINAL_GATEWAY
ip route del 0.0.0.0/1 dev $INTERFACE
ip route del 128.0.0.0/1 dev $INTERFACE
$ chmod +x /etc/tinc/netname/tinc-*
$ chmod +x /etc/tinc/netname/hosts/server-*
$ scp /etc/tinc/netname/hosts/linkit root@remote-server:/etc/tinc/netname/hosts/
$ scp root@remote-server:/etc/tinc/netname/hosts/server /etc/tinc/netname/hosts/
$ /etc/init.d/tinc start
$ /etc/init.d/tinc enable
$ ifconfig tun0
$ firefox http://192.168.1.125/cgi-bin/luci/
# Firewall:
# | lan => wan, vpn | ooo | xx |
# | wan => | oox | oo |
# | vpn => wan | ooo | ox |
```
2015-06-14 11:06:12 +08:00
[1]: http://tinc-vpn.org/
[2]: https://www.digitalocean.com/community/tutorials/how-to-install-tinc-and-set-up-a-basic-vpn-on-ubuntu-14-04