Tip
The tikoci/mikropkl project now packages RouterOS CHR as macOS UTM virtual machines for automated install. The new project supports both UTM's Apple Virtualization engine (same as here), and QEMU-based machines.
See tikoci/mikropkl
's Releases for usage instructions. It uses utm://
app URL or .zip
file download, quickly deploy RouterOS in macOS UTM.
Caution
New builds will not be produced in this repo (outside of request). UTM packages for RouterOS versions 7.18.1 and above are in tikoci/mikropkl, which builds the same images as here & more.
Ready-to-use Mikrotik RouterOS CHR for UTM*
If you have an Intel Mac, and UTM is already installed, you can install most release release here automatically. * Only Intel-based macOS with UTM installed is supported, currently no support for Apple Silicon-based macOS.
Note
To instal UTM virtual machine manager... download from either https://mac.getutm.app/ or Mac App Store. Once UTM is installed, then use UTM app URL or download the .zip
from Releases.
Warning
Some browsers may not display the UTM installer link above. Instead, cut-and-paste the UTM "app URL" below for the CHR installer into Safari on Intel macOS - this will launch UTM to add CHR virtual machine:
utm://downloadVM?url=https://github.com/tikoci/chr-utm/releases/latest/download/RouterOS.utm.zip
Option Two: Download the RouterOS.utm.zip
from GitHub Releases, which expands into a runnable UTM virtual machine for CHR
The same image can install multiple times, using a couple of steps:
- Change the MAC address inside the virtual machine settings for "RouterOS". Select "Network" on left, then "Random". UTM will pick a new MAC address that won't config. The issue all downloads will use the same MAC address - and thus same IP address – which is problematic. UTM does not have the ability to automatically re-generate one (like VMWare/etc might do on VMX), but this step is critical.
- By default, the CHR is named "RouterOS", since this also the "file" name. You should rename any existing image from "RouterOS" to something like "CHR1" or whatever you like as long all CHR have a unique name in UTM.
In UTM virtual machine settings for CHR, you have a few networking options. A few imporant things to know:
- You can add more than one interface in UTM, but the is only one "Shared" network - which is a UTM-specific subnet, that is then NAT'ed out a "real" macOS interface. And you should be able to use any many networks adapters with the "Shared" type, they still all be on the same subnet – may not be as useful for testing.
- UTM also supports a "Bridged (advanced)" mode, and you can select either default first interface as that. Or, add a new interface that uses Bridge mode, leaving the first for "Shared" as kinda management port. With Bridge mode, CHR will act more like a router - in that at least it's own MAC address is on same LAN as macOS as an independant device.
- You can also add USB dongles or other network interface, and wire them up as a "Bridged (advanced)" Network interface in RouterOS UTM settings. This could, theoricially, connect CHR to some WAN or other network outside of macOS.
- To isolate a UTM "Bridged" network from macOS usage, you can go to "Network" in System Preferences, and set IPv4 to "No" and set IPv6 to "Manual" on a UTM bridged interface to remove macOS for that bridged adapter.
The RouterOS image is configured to use UTM's serial terminal, by default. This is for a couple reasons:
- To ensure you always have access to a console - even if network config was bad. 2. In testing, UTM emulated Display – which would still just show text – is not comptible with CHR. Since the Display still just show text, it's not that useful & very likely uses way more resources than serial window.
Some tips:
- You can use multiple serial ports, but you'll have to configure them via RouterOS to be used for something.
- Default is a macOS window to show a ANSI terminal in window. But UTM also support sending serial to a /dev/stty port. This means you can use CLI tools like
screen
orcu
to access the terminal. To do this, change Serial (or add new serial port), to "Psuedo-TTY". - Similarly a /dev/ssty can be used to run
expect
scripts to do things like provisioning.
With a a "Psuedo-TTY" port, you can run classic UNIX® tools like expect
, which a TCL-based automation of terminal. Included in this project in an example script, routeros-login.expect that will set a admin password & accept the license agreement. To use it:
- Download
routeros-login.expect
from here - Install
expect
, on macOS with Homebrew itbrew install expect
- but script should work on non macOS platforms with expect installed. - Set RouterOS UTM virtual machine's serial port to use "Psuedo-TTY" within settings. You will have to
/system/shutdown
to change settings. - After starting CHR, with Psuedo-TTY set, the main UTM screen will show a "Serial (TTY)", you'll need to copy the path shown.
- Edit the download
routeros-login.expect
script, changing the "password" to be desired new "admin" password. Do - You can run the script by using
expect -f <expect_file>
, orchmod a+x <expect_file>
then just./routeros-login.expect
. - Script should automatically accept the license agrement and bring you to a command prompt after inital install.
- By default, routeros-login.expect using
screen
and the result of expect script to bring you an interactive prompt. But to exitscreen
you need to use Ctrl-A (attention) followed by Ctrl-D (done) – without the magic commands, it's not easy to leave the terminal.
NOTE The expect script is not fool-proof - more example of approach. Also, while same script can work for a "regular" login, it has to timeout waiting for the license agreemnt. But feel free to use it as a basis for other automation.
expect
and other tool like ssh
or curl
may require a running. UTM offers two solutions, described in their docs (https://docs.getutm.app/scripting/scripting/)
- AppleScript, which you can use macOS's Script Editor to run them. Apple Shortcuts and Automator also supports running an AppleScript as a task. To ensure VM is started, you can use this AppleScript to start it:
tell application "UTM"
set CHR to virtual machine named "RouterOS"
if CHR's status is stopped then start CHR
end tell
See Apple's Automate tasks using AppleScript and Terminal on Mac for command-line usage with
osascript
. Also see UTM's AppleScript documentation
- UTM's
utmctl
tool which is more limited that AppleScript, see UTM docs for details onutmctl
.
The image here has no license, so it runs in "free" mode. This limits speed to There is a "trial" mode that is also free, but you need to register at www.mikrotik.com to get a CHR trial license. Mikrotik's CHR documentation describes fully but to summarize:
Free The free license level allows CHR to run indefinitely. It is limited to 1Mbps upload per interface. All the rest of the features provided by CHR are available without restrictions.
60 Day Trial In addition to the limited Free installation, you can also test the increased speed of P1/P10/PU licenses with a 60 trial. You will have to have an account registered on MikroTik.com. Then you can request the desired license level for trial from your router that will assign your router ID to your account and enable the purchase of the license from your account. All the paid license equivalents are available for trial. A trial period is 60 days from the day of acquisition after this time passes, your license menu will start to show "Limited upgrades", which means that RouterOS can no longer be upgraded.
Paid Licenses
License Speed limit Price Free 1Mbit FREE P1 1Gbit $45 P10 10Gbit $95 PU Unlimited $250
UTM is open source virtual machine host for Apple macOS, which avaialble for download, or via Mac App Store. CHR is a Mikrotik RouterOS disk image for virtual machines, which is full operational, but bandwidth limited. See Mikrotik's CHR page for details on RouterOS limits and licensing details.
While, RouterOS images for ARM should work with UTM on ARM-based macOS, using QEMU mode. Feel free to make a pull request, or issue with
.plist
and other details for ARM support.
Tip
For problems, please report on Mikrotik's forum, or file an issue in GitHub.
-
The package here use "Apple Virtualization" mode in UTM, as more direct path to OS services than QEMU.
-
Turns out UTM virtual machines are just ZIP files. So, "build" here is really a
zip
of the CHR image with associated.plist
(and logo for fun). -
To work under Apple's Virtualization Framework, the Mikrotik's CHR RAW image must be converted to a FAT partition to the required EUFI boot. But this repo re-uses same re-partitioning scripts from tikoci/fat-chr. And instead of posting the raw image files, the Release is a
.zip
which works with UTM's URL monikers to allow for "Click to Install" -
The URL works because UTM implements Apple URL handlers, so
utm://downloadVM?url=
routes to the UTM app, with a URL to a.zip
file.
utm://downloadVM?url=https://example.com/.../vm.utm.zip
And, that's how the "Install via URL" works.
- But... app URL may require a .well-known file per Apple schemes to work from GitHub (thus note about using Safari above)