Не удается найти Pyro Nameserver при использовании Pyro-nsd
Я использую Pyro4 с Python 2.7 на Raspberry Pi под управлением Wheezy
Когда я запускаю Pyro Nameserver с
pyro4-ns &
или же
python -m Pyro4.naming &
Мой код работает, как и ожидалось, без каких-либо ошибок. Однако, когда я запускаю демон сервера имен Pyro с помощью следующей команды
/etc/init.d/pyro-nsd start
когда я запускаю lamp_daemon.py в качестве фонового процесса
/home/pi/Wakeup-Lamp/lamp_daemon.py &
Я получаю следующую ошибку
Файл "/home/pi/Wakeup-Lamp/lamp_daemon.py", строка 27, в
nameServer = Pyro4.locateNS()
Файл "/usr/local/lib/python2.7/dist-packages/Pyro4/naming.py", строка 358, в locateNS
поднять е
Pyro4.errors.NamingError: не удалось найти сервер имен
Код lamp_daemon.py
#!/usr/bin/python
from current_lamp_state import CurrentLampState
from lamp_state import LampState
from pwm import Pwm
import Pyro4
import Pyro.core
import Pyro.naming
class LampSwitch(Pyro.core.ObjBase):
__currentLampState = CurrentLampState()
__pwm = Pwm()
def get_lamp_state(self):
return self.__currentLampState.get()
def set_lamp_state(self, new_lamp_state):
self.__currentLampState.set(new_lamp_state)
self.__pwm.update()
lampSwitch = LampSwitch()
daemon = Pyro4.Daemon()
nameServer = Pyro4.locateNS()
uri = daemon.register(lampSwitch)
nameServer.register("lamp.daemon", uri)
daemon.requestLoop()
Я немного погуглил, но не могу решить проблему. Кто-нибудь знает, что я делаю не так?
2 ответа
Если пиро версия на сервере отличается от версии на клиенте, то не удается найти сервер имен, вот способ проверить версию пиро:
python -c "импортировать Pyro4.constants как c; print(c.PROTOCOL_VERSION)"
Если это не то же самое, тогда, пожалуйста, удалите пиро-модуль и переустановите его.
Я столкнулся с подобной проблемой, которая была исправлена, когда я следовал за вышеупомянутыми шагами.
Я не уверен, что это полностью решит вашу проблему, но вот что я узнал, пытаясь получить pyro-nsd
работа с python2.7. Я использовал Ubuntu 14.04 в этом случае. Это может отличаться на версии Wheezy.
- Я установил с помощью
sudo apt-get install pyro4
посколькуpyro4-nsd
не устанавливается через pip. - Первое, что я заметил, это то, что
pyro4-nsc list
не был признан. - Итак, я использую pyro4
sudo pip install pyro4
, - Сейчас
pyro4-nsc list
работает, но я получаюFailed to locate the nameserver
ошибка.
Итак, я взглянул на конфигурацию для /etc/init.d/pyro4-nsd
и нашел несколько интересных вещей.
1.
Скрипт проверяет, установлен ли python3. Если это так, он будет использовать Python3 версию Pyro4, которая устанавливается как зависимость от sudo apt-get install pyro4
,
Здесь я просто использую это python2.7
,
Сейчас pyro4-nsc list
на самом деле работает, но я получаю эту ошибку: Error: CommunicationError - cannot connect: hmac key config not symmetric
, что приводит к № 2
2.
Следующее, что я заметил, это export PYRO_HMAC_KEY=12345
линия в pyro4-nsd
,
в Pyro4/configuration.py
Похоже, что файл используется только для python3: ( https://github.com/delmic/Pyro4/blob/ccea9c2870a1280010bcc56f4146bc1617ec6e8d/src/Pyro4/configuration.py). Смотрите этот фрагмент здесь:
if self.HMAC_KEY and sys.version_info>=(3,0):
if type(self.HMAC_KEY) is not bytes:
self.HMAC_KEY=bytes(self.HMAC_KEY, "utf-8") # convert to bytes
Итак, я просто удалил PYRO_HMAC_KEY
экспортная линия.
3.
Незначительная вещь, но делает sudo service pyro4-nsd restart
, запускает и затем останавливает службу, когда она должна остановить службу, а затем запустить ее.
Вот модифицированный файл pyro4-nsd:
#!/bin/sh
### BEGIN INIT INFO
# Provides: pyro4-nsd
# Required-Start: $time $local_fs $remote_fs $network
# Required-Stop: $time $local_fs $remote_fs $network
# Default-Start: 2 3 4 5
# Default-Stop: 0 1 6
# Short-Description: Pyro4 name server daemon
# Description: Debian init script for pyro4-nsd (Pyro4 name server daemon)
### END INIT INFO
# -------------------------------------------------------------------------
# <Pyro4 NameServer Daemon Script>
# Copyright (C) <2011> <Pierre PACORY> - ppacory@gmail.com
# Licensed under the "MIT Software License" for inclusion in Pyro4.
# -------------------------------------------------------------------------
LISTEN_ADDRESS=0.0.0.0
LISTEN_PORT=9999
MESSAGEDIR=/var/log/Pyro4
MESSAGELOG=/var/log/Pyro4/NameServer.log
PID=/var/run/Pyro4-NameServer.pid
# Defaults - don't touch, edit /etc/default/pyro-nsd
ENABLED=0
if [ -f /etc/default/pyro4-nsd ] ; then
. /etc/default/pyro4-nsd
fi
if [ "$ENABLED" = "0" ]; then
echo "pyro4-nsd: disabled, see /etc/default/pyro4-nsd"
exit 0
fi
# Add Pyro Config
# here you can add others ...
# NOTE: Comment out PYRO_HMAC_KEY since it appears to be used only for Python3
#export PYRO_HMAC_KEY=12345
export PYRO_LOGFILE="$MESSAGELOG"
export PYRO_LOGLEVEL=DEBUG
. /lib/lsb/init-functions
# Check the script is being run by root user
if [ "$(id -u)" != "0" ]; then
echo 1>&2 "ERROR: The $0 script must be run as root"
exit 1
fi
# Create the PID File
touch $PID
# Detect if Python 2.x or Python 3.y is installed
# NOTE: For the use of python2.7 here
PYTHON=python2.7
[ -x /usr/bin/$PYTHON ] || PYTHON=python
case "$1" in
start)
# create the log directory if not exist
[ ! -d "$MESSAGEDIR" ] && mkdir -p "$MESSAGEDIR"
echo "Starting Pyro4 Name Server"
# test if not already running
if [ ! -f "/proc/$(cat $PID)/exe" ]; then
$PYTHON -m Pyro4.naming -n "$LISTEN_ADDRESS" -p "$LISTEN_PORT" >/dev/null 2>&1 &
echo $!>"$PID"
else
echo "Pyro4 Name Server already running"
fi
;;
stop)
echo "Stopping Pyro4 Name Server"
# test if running
if [ -f "/proc/$(cat $PID)/exe" ]; then
kill -9 "$(cat $PID)"
rm -rf "$PID"
else
echo "Pyro4 Name Server already stopped"
fi
;;
restart)
# Stop, then Start
$0 stop
$0 start
;;
force-reload)
# Stop, then Start
$0 stop
$0 start
;;
*)
echo "usage: $0 {start|stop|restart|force-reload}"
esac
exit 0