// edit: Desculpe, eu não vi a parte do windows quando postei isso. O seguinte é sobre o linux.
Eu tive esse problema há algum tempo com o openvpn e um cliente Linux. Mas o resolvconf me deu um tempo extra para escrever as opções dhcp diretamente para o arquivo local resolv.conf e não havia como restaurar o servidor de nomes antigo depois de desconectar da vpn. Então eu desisti e fiz dois pequenos scripts bash que lidam com o meu arquivo resolv.conf em vpn connect / disconnect. (Claro, esses scripts têm que ser instalados em todos os clientes, então não há solução geral.)
O backup do script faz backup de suas definições regulares de servidor de nomes para um local seguro antes de sobrescrevê-las com aquelas na opção dhcp recebida. O script para baixo simplesmente move seu arquivo regular de volta ao lugar.
acrescentar à sua conexão vpn conf
script-security 2
up /etc/openvpn/dns.up.sh
down /etc/openvpn/dns.down.sh
dns.up.h
#!/bin/bash
mv /etc/resolv.conf /etc/resolv.conf.novpn
for optionname in ${!foreign_option_*} ; do
option="${!optionname}"
echo $option
part1=$(echo "$option" | cut -d " " -f 1)
if [ "$part1" == "dhcp-option" ] ; then
part2=$(echo "$option" | cut -d " " -f 2)
part3=$(echo "$option" | cut -d " " -f 3)
if [ "$part2" == "DNS" ] ; then
IF_DNS_NAMESERVERS="$IF_DNS_NAMESERVERS $part3"
fi
if [ "$part2" == "DOMAIN" ] ; then
IF_DNS_SEARCH="$IF_DNS_SEARCH $part3"
fi
fi
done
R=""
for SS in $IF_DNS_SEARCH ; do
R="${R}search $SS
"
done
for NS in $IF_DNS_NAMESERVERS ; do
R="${R}nameserver $NS
"
done
echo -n "$R" > /etc/resolv.conf
dns.down.sh
#!/bin/sh
mv /etc/resolv.conf.novpn /etc/resolv.conf