To MicroTik or to MikroTik? I can never remember.
A collection of notes on MikroTik configuration & Maintenance.
Upgrade your firmware!
One of my clients had their MikroTik compromised in 2018. MikroTik had published an updated firmware version a few months before that mitigated the "attach vector", but unfortunately the device hadn't been updated in time. The end result? VOIP accounts compromised, about $300 of voice calls charged.
So the lesson learned is: always keep your MikroTik firmware up to date! How? You have two options (using WinFig):
(1) Check for Updates button on the QuickSet page
(2) or System → Packages, "Check for Updates"
data:image/s3,"s3://crabby-images/dba6a/dba6ae1b0ed50d410ca3dffc091d61443f3b680b" alt=""
data:image/s3,"s3://crabby-images/9f557/9f557fe9268ef48754cd28ce51bbf88d42b07461" alt=""
MikroTik Dynamic DNS Service
IP → Cloud, and ✓ to enable!
data:image/s3,"s3://crabby-images/1d527/1d527fdfc5811320dfcbd177ff576680afa51beb" alt=""
Set up L2TP VPN Server
Before you start, update your firmware.
(1) Add firewall rules:
/ip firewall filter
add action=accept chain=input comment="Allow L2PT VPN access" \
dst-port=500,1701,4500 protocol=udp
add action=accept chain=input protocol=ipsec-esp
add action=accept chain=input protocol=ipsec-ah
Move these rules to the top of your input chain.
(2) Set up an L2TP profile (this is a way of setting defaults for several logins, or "secrets"):
Create a pool of addresses for your clients:
IP→Pool→+
data:image/s3,"s3://crabby-images/fe738/fe738e6330a825b5bfb302487d89699a3557b506" alt=""
PPP→Profiles→+
data:image/s3,"s3://crabby-images/37cf9/37cf92165a343d188ed3633933fee9ecba8600cb" alt=""
(3) Add logins, or "secrets":
PPP→Secrets→+
data:image/s3,"s3://crabby-images/adcc9/adcc93e4de200000ecef6602dbcc1188cbc5f5f3" alt=""
(4) Enable L2TP:
PPP→Interface→L2TP Server
data:image/s3,"s3://crabby-images/65ad0/65ad0eb38b90b9e1ebb2f9cfacc39a127e518c33" alt=""
Current RouterOS versions will automatically configure IPSec for you at this point. They will look something like this, you can mess with it but it's easy to mess it up:
IPSec→Proposals
data:image/s3,"s3://crabby-images/c3b47/c3b47e90d3437e8cbbad11e0a9f17cc1592d73ec" alt=""
IPSec→Peers
data:image/s3,"s3://crabby-images/f17b3/f17b307fb0ddaa9b1032f2e3fa7da4b2314e9bdf" alt=""
IPSec→Identities
data:image/s3,"s3://crabby-images/9d54f/9d54f16e66386e940447bd6c300e3d9fa761c5b2" alt=""
IPSec→Profiles
data:image/s3,"s3://crabby-images/15a2b/15a2ba960d819095c82dd79fc046da3110dbc263" alt=""
IPSec→Policies
data:image/s3,"s3://crabby-images/7d60e/7d60e033351824c955a3862e3961abcda2fa97bc" alt=""
data:image/s3,"s3://crabby-images/116e8/116e8e9dad25c41cf82669365fa7210c28784cf6" alt=""
(5) Optionally create an L2TP server binding:
data:image/s3,"s3://crabby-images/5cdec/5cdec42b177ef82a1234f2d079428e7d8954b52e" alt=""
data:image/s3,"s3://crabby-images/09ba3/09ba3297bbe7d819be134854bf71874b624ef920" alt=""
(6) Adjust fasttrack
Fasttrack can mess with your L2TP, slowing down connections. To get around this, do:
/ip firewall mangle add action=mark-connection chain=forward comment="mark ipsec connections to exclude them from fasttrack" ipsec-policy=out,ipsec new-connection-mark=ipsec
/ip firewall mangle add action=mark-connection chain=forward comment="mark ipsec connections to exclude them from fasttrack" ipsec-policy=in,ipsec new-connection-mark=ipsec
Then, in your firewall, find your default fasttrack rule and set connection-mark=!ipsec
:
data:image/s3,"s3://crabby-images/088a6/088a6f59654ae41f2e7e635b65f29a868137801f" alt=""
Sources/reference: