Tinc VPN configuration examples: Difference between revisions
no edit summary
PauliusRug (talk | contribs) No edit summary |
|||
(21 intermediate revisions by one other user not shown) | |||
Line 10: | Line 10: | ||
'''Prerequisites''': | '''Prerequisites''': | ||
* Two RUTxxx routers or TRB gateways of any type | * Two RUTxxx routers or TRB gateways of any type | ||
* At least one router must have a Public Static or Public Dynamic IP address | * At least one router must have a '''Public Static''' or '''Public Dynamic''' IP address | ||
* At least one end device (PC, Laptop, Tablet, Smartphone) to configure the routers | * At least one end device (PC, Laptop, Tablet, Smartphone) to configure the routers | ||
* (Optional) A second end device to configure and test remote LAN access | * (Optional) A second end device to configure and test remote LAN access | ||
Line 16: | Line 16: | ||
There will be two tinc configuration schemes presented. Although the second scheme is only an extension of the first one. Therefore, to configure the second scheme, you will have to configure the first as well. | There will be two tinc configuration schemes presented. Although the second scheme is only an extension of the first one. Therefore, to configure the second scheme, you will have to configure the first as well. | ||
''' | '''Topology 1''': | ||
[[File: | [[File:Tinctopo1.png|center|border|class=tlt-border|800x600px]] | ||
The figure above depicts two RUTxxx routers (RUT1 and RUT2) connected by an tinc tunnel via the Internet. | The figure above depicts two RUTxxx routers (RUT1 and RUT2) connected by an tinc tunnel via the Internet. | ||
---- | ---- | ||
''' | '''Topology 2''': | ||
[[File: | [[File:Tinctopo2.png|center|border|class=tlt-border|800x600px]] | ||
As mentioned earlier, configuration scheme 2 (figure above) is an extension of configuration scheme 1. While configuration scheme 1 only depicts a connection between two tinc instances, you can see that configuration scheme 2 | As mentioned earlier, configuration scheme 2 (figure above) is an extension of configuration scheme 1. While configuration scheme 1 only depicts a connection between two tinc instances, you can see that configuration scheme 2 includes additional two end devices (END1 and END2), each connected to a separate router's LAN. When this topology is set up, not only will the two routers be able to communicate with each other, but the end devices will also be reachable to one another and from each router. | ||
In addition to traffic encryption, tinc VPN also supports automatic full mesh routing - VPN traffic is always (if possible) sent directly to the destination, without going through intermediate hops. | In addition to traffic encryption, tinc VPN also supports automatic full mesh routing - VPN traffic is always (if possible) sent directly to the destination, without going through intermediate hops. | ||
Line 43: | Line 42: | ||
First of, lets configure a simple connection between two tinc instances, i.e., '''RUT1''' and '''RUT2''' as described above in '''configuration scheme 1'''. | First of, lets configure a simple connection between two tinc instances, i.e., '''RUT1''' and '''RUT2''' as described above in '''configuration scheme 1'''. | ||
1. tinc is not installed on our devices, therefore, it has to be installed via the package manager. '''Services -> Package Manager -> Packages''' and search for '''tinc VPN''' and press '''+''' to install. | |||
[[File:TincPackage.png| | [[File:TincPackage.png|border|class=tlt-border|900x700px]] | ||
2. After '''successful''' installation, package status should be changed to '''Installed.''' | |||
[[File: | [[File:Tincinstallation2.png|border|class=tlt-border|900x700px]] | ||
* In '''Network -> Firewall -> General''' you should see a '''new Firewall zone''' “'''<span style="color:khaki">tinc</span>'''” created: | |||
* From | [[File:Tincfwzone2.png|border|class=tlt-border|900x700px]] | ||
* Lastly, in '''Network -> Firewall -> Traffic rules''' a '''new traffic rule added:''' | |||
[[File:Tinctraffic2.png|border|class=tlt-border|900x700px]] | |||
* From this point onwards, all configuration will be made using command line interface. | |||
* Make a folder for your tinc daemon where all your configurations will be kept. This procedure is required if you’re going to run more than one tinc daemon on one PC. However, if you only need one instance, then you can keep all configuration in default directory at “'''<span style=color:limegreen>/etc/tinc/</span>'''” | * Make a folder for your tinc daemon where all your configurations will be kept. This procedure is required if you’re going to run more than one tinc daemon on one PC. However, if you only need one instance, then you can keep all configuration in default directory at “'''<span style=color:limegreen>/etc/tinc/</span>'''” | ||
* Use <span style=color:dodgerblue>'''mkdir'''</span> to create a new folder at '''<span style=color:limegreen>/etc/tinc/</span>''' | * Use <span style=color:dodgerblue>'''mkdir'''</span> to create a new folder at '''<span style=color:limegreen>/etc/tinc/</span>''' | ||
[[File:Tincfolder.png]] | [[File:Tincfolder.png|border|class=tlt-border]] | ||
* Then use your favorite text editor (I’m using vi) and create '''tinc.conf''' (If you skipped making specific folder, then you can create configs as mentioned earlier – in parent folder “'''<span style=color:dodgerblue>vi</span> <span style=color:limegreen>/etc/tinc/tinc.conf</span>'''” | * Then use your favorite text editor (I’m using vi) and create '''tinc.conf''' (If you '''skipped''' making specific folder, then you can create configs as mentioned earlier – in parent folder “'''<span style=color:dodgerblue>vi</span> <span style=color:limegreen>/etc/tinc/tinc.conf</span>'''”, otherwise do it in "'''<span style="color:dodgerblue">vi</span> <span style="color:limegreen">/etc/tinc/example/tinc.conf</span>'''" | ||
[[File:Tincconfigfile.png|border|class=tlt-border]] | |||
[[File:Tincconfigfile.png]] | |||
* And on RUT2 use a different name (ex. <span style=color:limegreen>rut2</span>) and add the line “<span style=color:limegreen>ConnectTo = rut1</span>” | * And on RUT2 use a different name (ex. <span style=color:limegreen>rut2</span>) and add the line “<span style=color:limegreen>ConnectTo = rut1</span>” | ||
Line 113: | Line 118: | ||
'''<span style=color:dodgerblue>tincd -n ''netname'' -K</span>''' , in our scenario: “'''<span style=color:dodgerblue>tincd -n example -K</span>'''” and simply press enter to accept the default. | '''<span style=color:dodgerblue>tincd -n ''netname'' -K</span>''' , in our scenario: “'''<span style=color:dodgerblue>tincd -n example -K</span>'''” and simply press enter to accept the default. | ||
* After keypairs were generated, you need to copy the device’s host file to the other device. Copy RUT1’s <span style=color:limegreen>'''hosts/rut1'''</span> file to RUT2 and place it in the same folder <span style=color:limegreen>'''hosts/'''</span> and do the same with the RUT2 file placing it in the RUT1 hosts folder. | * After keypairs were generated, you need to copy the device’s host file to the other device. Copy RUT1’s <span style=color:limegreen>'''hosts/rut1'''</span> file to RUT2 and place it in the same folder <span style=color:limegreen>'''hosts/'''</span> and do the same with the RUT2 file placing it in the RUT1 hosts folder. | ||
You can do this with '''WinSCP''', or using CLI’s <span style=color:dodgerblue>'''scp'''</span> to transfer files from one device to the other. | You can do this with '''WinSCP''', or using CLI’s <span style=color:dodgerblue>'''scp'''</span> to transfer files from one device to the other. | ||
[[File:Tincscp1.2.png]] | [[File:Tincscp1.2.png|border|class=tlt-border|1100x700px]] | ||
[[File:Tincscp2.2.png]] | [[File:Tincscp2.2.png|border|class=tlt-border|1100x700px]] | ||
Here on CLI, In 1st picture, I used scp to transfer RUT1’s host file directly to my RUT2, because RUT1 has public IP and therefore, I can directly communicate with it, and later, transferred RUT2’s host file to the RUT1 in the 2nd picture. | Here on CLI, In 1st picture, I used scp to transfer RUT1’s host file directly to my RUT2, because RUT1 has public IP and therefore, I can directly communicate with it, and later, transferred RUT2’s host file to the RUT1 in the 2nd picture. | ||
Line 125: | Line 129: | ||
'''RUT1:''' | '''RUT1:''' | ||
[[File:Tinccon1.png]] | |||
[[File:Tinccon1.png|border|class=tlt-border]] | |||
'''RUT2:''' | '''RUT2:''' | ||
[[File:Tinccon2.png]] | |||
[[File:Tinccon2.png|border|class=tlt-border]] | |||
Also, you can ping RUT1’s or 2’s VPN IP, here I ping RUT2 from RUT1, it should work both ways: | Also, you can ping RUT1’s or 2’s VPN IP, here I ping RUT2 from RUT1, it should work both ways: | ||
[[File:Tincping1.png]] | [[File:Tincping1.png|border|class=tlt-border]] | ||
And you can see a new route created on tinc0 interface: | And you can see a new route created on tinc0 interface: | ||
[[File:Tinciface.png]] | [[File:Tinciface.png|border|class=tlt-border]] | ||
===End-client to end-client example=== | ===End-client to end-client example=== | ||
Line 146: | Line 153: | ||
<span style=color:limegreen>'''hosts/rut1'''</span> file: | <span style=color:limegreen>'''hosts/rut1'''</span> file: | ||
[[File:Tinchosts1.png]] | [[File:Tinchosts1.png|border|class=tlt-border]] | ||
<span style=color:limegreen>'''hosts/rut2'''</span> file: | <span style=color:limegreen>'''hosts/rut2'''</span> file: | ||
[[File:Tinchosts2.png]] | [[File:Tinchosts2.png|border|class=tlt-border]] | ||
* Add a route to other’s device LAN network through your tinc interface: | * Add a route to other’s device LAN network through your tinc interface: | ||
Line 157: | Line 164: | ||
on rut1 <span style="color:limegreen">'''example/tinc-up'''</span> | on rut1 <span style="color:limegreen">'''example/tinc-up'''</span> | ||
[[File:Tincup1.png]] | [[File:Tincup1.png|border|class=tlt-border]] | ||
on rut2 <span style=color:limegreen>'''example/tinc-up'''</span> | on rut2 <span style=color:limegreen>'''example/tinc-up'''</span> | ||
[[File:Tincup2.png]] | [[File:Tincup2.png|border|class=tlt-border]] | ||
* However, you’ll only be able to reach each other’s device LAN IP, but not the end devices. Therefore you need to change firewall rules. | * However, you’ll only be able to reach each other’s device LAN IP, but not the end devices. Therefore you need to change firewall rules. | ||
'''FIREWALL''' | '''FIREWALL''' | ||
[[File: | 1. To achieve end-to-end client communication you need to configure the tinc zone '''Network->Firewall->General''', that was created at the installation. Press the edit button to configure it.[[File:Tincfirewall1.png|border|class=tlt-border|1100x700px]] | ||
[[File:Tincfirewall2.png|border|class=tlt-border|900x700px]] | |||
2. Open ''Allow forward to destination zones'' list. | |||
3. Select '''lan''' zone, this will allow us to access LAN network from outside via tinc VPN. | |||
[[File:Tincfirewall3.png|border|class=tlt-border|900x700px]] | |||
4. Open ''Allow forward from source zones'' list. | |||
5. Select '''lan''' zone, so we can access outside networks via tinc VPN too. | |||
6. Press '''Save & Apply''' | |||
We are going to allow all forwards via this interface, including '''lan''' and '''wan networks''' into this zone. This way we can communicate from END1 to RUT2’s lan as well as END2 and vice versa. | We are going to allow all forwards via this interface, including '''lan''' and '''wan networks''' into this zone. This way we can communicate from END1 to RUT2’s lan as well as END2 and vice versa. | ||
In short '''LAN1 <-> WAN1 <-''' through tinc tunnel '''-> WAN2 <-> LAN2''' | In short '''LAN1 <-> WAN1 <-''' through tinc tunnel '''-> WAN2 <-> LAN2''' | ||
[[File:TincTopology3.png]] | [[File:TincTopology3.png|center|border|class=tlt-border|800x600px]] | ||
[[Category:VPN]] |