LINUX.ORG.RU
решено ФорумAdmin

openvpn не добавляются nameserver'ы

 


0

1

Добрый день.

Есть конфиг от админа и arch linux. При запуске openvpn (пробовал различные способы) - всегда получаю одно и тоже сообщение:

Sun Apr 16 22:15:18 2017 /etc/openvpn/update-resolv-conf tun0 1500 1570 172.18.240.227 255.255.254.0 init which: no resolvconf in ((null)) dhcp-option DNS 192.168.100.143 dhcp-option DNS 192.168.100.145 dhcp-option DOMAIN protei /etc/openvpn/update-resolv-conf: line 56: -x: command not found

но пакет resolvconf у меня установлен, и конфиг точно правильный

Подскажите, пожалуйста что я делаю неправильно, либо как это можно диагностировать?

/etc/openvpn/update-resolv-conf: line 56: -x: command not found

Так, и что тут тебе непонятно?

Английская языка не знать, да?

zgen ★★★★★
()
Ответ на: комментарий от zgen

Ну мне это ниочём не говорит, я смотрел тот скрипт и 56 строчку. Я понимаю что он не может найти команду, но какую, я без понятия, т.к. там идёт не явный вызов, а используется переменная.

penetrator3000
() автор топика
Ответ на: комментарий от zgen

Вот:

#!/bin/bash
#
# Parses DHCP options from openvpn to update resolv.conf
# To use set as 'up' and 'down' script in your openvpn *.conf:
# up /etc/openvpn/update-resolv-conf
# down /etc/openvpn/update-resolv-conf
#
# Used snippets of resolvconf script by Thomas Hood <jdthood@yahoo.co.uk>
# and Chris Hanson
# Licensed under the GNU GPL.  See /usr/share/common-licenses/GPL.
# 07/2013 colin@daedrum.net Fixed intet name
# 05/2006 chlauber@bnc.ch
#
# Example envs set from openvpn:
# foreign_option_1='dhcp-option DNS 193.43.27.132'
# foreign_option_2='dhcp-option DNS 193.43.27.133'
# foreign_option_3='dhcp-option DOMAIN be.bnc.ch'
# foreign_option_4='dhcp-option DOMAIN-SEARCH bnc.local'

## You might need to set the path manually here, i.e.
RESOLVCONF=$(which resolvconf)

case $script_type in

up)
  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" || "$part2" == "DOMAIN-SEARCH" ]] ; then
        IF_DNS_SEARCH="$IF_DNS_SEARCH $part3"
      fi
    fi
  done
  R=""
  if [ "$IF_DNS_SEARCH" ]; then
    R="search "
    for DS in $IF_DNS_SEARCH ; do
      R="${R} $DS"
    done
  R="${R}
"
  fi

  for NS in $IF_DNS_NAMESERVERS ; do
    R="${R}nameserver $NS
"
  done
  #echo -n "$R" | $RESOLVCONF -x -p -a "${dev}"
  echo -n "$R" | $RESOLVCONF -x -a "${dev}.inet"
  ;;
down)
  $RESOLVCONF -d "${dev}.inet"
  ;;
esac

# Workaround / jm@epiclabs.io 
# force exit with no errors. Due to an apparent conflict with the Network Manager
# $RESOLVCONF sometimes exits with error code 6 even though it has performed the
# action correctly and OpenVPN shuts down.
exit 0

56 строка:

echo -n "$R" | $RESOLVCONF -x -a "${dev}.inet"

penetrator3000
() автор топика
Ответ на: комментарий от penetrator3000

у тебя переменная $RESOLVCONF пустая.

RESOLVCONF=$(which resolvconf)

что это вообще? which ищет исполняемые файлы.
Может, locate? Или всё же лучше указать явно путь к нему.

annerleen ★★★★☆
()
Ответ на: комментарий от annerleen

RESOLVCONF=$(which resolvconf)

что это вообще?

Ищет указанный бинарь по переменной $PATH и выводит полный путь до бинарника resolvconf, присваевая его переменной.

zgen ★★★★★
()
Ответ на: комментарий от penetrator3000


Но смысл верный, which resolvconf возвращает нулевой результат.
Так что определитесь, где у вас бинарь resolvconf и пропишите полный путь вместо $RESOLVCONF в скрипте

zgen ★★★★★
()
Ответ на: комментарий от zgen

Всё заработало после того как прописал вручную путь до resolvconf.

Но интересно, почему возникает ошибка в скрипте. Если я отдельно пишу команду в терминале:

[andrey@arch]: ~>$ which resolvconf 
/usr/bin/resolvconf

То получаю ровно такой же путь, который я указал вручную.

Большое спасибо за ответы!

penetrator3000
() автор топика
Ответ на: комментарий от penetrator3000

Переменная PATH, причем пара вариантов, может не найти как which, так и which не может найти resolvconf. А вообще «всю жизнь твердили миру» абсолютные пути.

anc ★★★★★
()
Ответ на: комментарий от zgen

я просто деревня и не знаю, что есть такой бинарник resolvconf, думал, что ОП пытается найти конфиг :)

annerleen ★★★★☆
()
Вы не можете добавлять комментарии в эту тему. Тема перемещена в архив.