Добавление маршрутов в зависимости от смены сети
Мне на рабочем месте наконец-то дали доступ личному ноуту по Wi-Fi в рабочую сетку. И я столкнулся с проблемой - а как же мне достучаться до кластера кубернетесов, маршрут к которым не прописан на сетевых железках? И выход был найден :).
Для начала надо создать такой вот XML для launchd и положить его в /Library/Preferences/SystemConfiguration/ifup.routes.plist
:
<?xml version="1.0" encoding="UTF-8"?>
<!DOCTYPE plist PUBLIC "-//Apple Computer//DTD PLIST 1.0//EN" \
"http://www.apple.com/DTDs/PropertyList-1.0.dtd">
<plist version="1.0">
<dict>
<key>Label</key>
<string>ifup.routes</string>
<key>LowPriorityIO</key>
<true/>
<key>ProgramArguments</key>
<array>
<string>/Users/pztrn/bin/routes-update.sh</string>
</array>
<key>WatchPaths</key>
<array>
<string>/etc/resolv.conf</string>
<string>/Library/Preferences/SystemConfiguration/com.apple.airport.preferences.plist</string>
</array>
<key>RunAtLoad</key>
<true/>
</dict>
</plist>
Имя файла решающего значения не имеет, назвать можно как угодно.
При подгрузке в launchd эта штука следит за изменениями в resolv.conf и в файле с текущими настройками Wi-Fi и, если один из них или сразу оба изменились, запускает скрипт /Users/pztrn/bin/routes-update.sh
.
Ниже содержимое этого скрипта:
#!/bin/bash
# Check if network connection is up.
areweup=$(networksetup -getairportnetwork en0)
if [ "${areweup/You\ are\ not\ associated//}" != "${areweup}" ]; then
# If we're not up - remove any custom-added routes.
route -n delete -net 192.168.136.0/24 192.168.137.144
fi
echo "Network changed, updating routes..."
# Get Wi-Fi network name.
netname=$(networksetup -getairportnetwork en0 | awk {' print $4 '})
if [ "${netname/office-bc//}" != "${netname}" ]; then
route -n add -net 192.168.136.1/24 192.168.137.144
fi
Основное описано в комментариях. Единственный недостаток этого скрипта - это продолжение выполнения после детекта отключения от сети, но мне его чинить лень.
Не забудьте сделать скрипт исполняемым (chmod +x
) и подгрузить XML для launchd:
sudo launchctl load -w /Library/Preferences/SystemConfiguration/ifup.routes.plist
Все, после подгрузки XML (или ребута мака) у вас все будет работать.