0

今日、Raspberry Pi に Arch Linux をインストールし、fhem のセットアップを開始しました。yaourt を使用して fhem をインストールした後、fhem 構成をカスタマイズし、systemd *.service ファイルを作成し、以下を使用してサービスを開始しました。

sudo systemctl start fhem
sudo systemctl enable fhem

次に、 systemctl status fhemを使用してサーバーのステータスを確認したところ、次の結果が得られました。

fhem.service - FHEM Perl Server
   Loaded: loaded (/etc/systemd/system/fhem.service; enabled)
   Active: inactive (dead) since Thu 2013-10-17 15:20:42 CEST; 11min ago
  Process: 480 ExecStart=/usr/bin/perl fhem.pl fhem.cfg (code=exited, status=0/SUCCESS)
 Main PID: 480 (code=exited, status=0/SUCCESS)

Oct 17 15:20:41 alarmpi systemd[1]: Started FHEM Perl Server.

サーバーが動作しているように見えるので、デスクトップ PC に切り替えて、firefox を192.168.1.77:8083に向けて fhem Web インターフェイスにアクセスしようとしました。

Firefox can't establish a connection to the server at 192.168.1.77:8083 

それで、Raspberry Piにsshしようとしましたが、うまくいきました。fhem の Web インターフェイスに接続できなかった理由を知っている人はいますか? 以下の私の設定ファイルを見つけてください。

/etc/fhem/fhem.cfg

attr global logfile ./log/fhem-%Y-%m.log
attr global modpath .                  # where our FHEM directory is
attr global statefile ./log/fhem.save  # where to save the state of the devices
attr global verbose 3                  # "normal" verbosity (min 1, max 5)

define telnetPort telnet 7072 global   # our TCP/IP port

define WEB FHEMWEB 8083 global

define WEBphone FHEMWEB 8084 global
attr WEBphone stylesheetPrefix smallscreen

define WEBtablet FHEMWEB 8085 global
attr WEBtablet stylesheetPrefix touchpad

# Fake FileLog entry, to access the fhem log from FHEMWEB 
define Logfile FileLog ./log/fhem-%Y-%m.log fakelog

define autocreate autocreate
attr autocreate autosave
attr autocreate device_room %TYPE
attr autocreate filelog ./log/%NAME-%Y.log
attr autocreate weblink
attr autocreate weblink_room Plots

# Disable this to avoid looking for new USB devices on startup
define initialUsbCheck notify global:INITIALIZED usb create 

/etc/systemd/system/fhem.service

[Unit]
Description=FHEM Perl Server
After=syslog.target network.target

[Service]
User=fhem
WorkingDirectory=/opt/fhem
ExecStart=/usr/bin/perl fhem.pl fhem.cfg
Type=simple 

[Install]
WantedBy=multi-user.target

/etc/iptables/iptables.rules

*filter
:INPUT ACCEPT [0:0]
:FORWARD ACCEPT [0:0]
:OUTPUT ACCEPT [0:0]
-A INPUT -p udp -m udp --dport 123 -j ACCEPT
-A INPUT -i lo -j ACCEPT
-A INPUT -m state --state RELATED,ESTABLISHED -j ACCEPT
-A INPUT -p tcp -m tcp --dport 22 -j ACCEPT
-A INPUT -p tcp -m state --state NEW -m tcp --dport 80 -j ACCEPT
-A OUTPUT -p udp -m udp --sport 123 -j ACCEPT
COMMIT
4

1 に答える 1

1

次のsystemdサービスファイルを使用して、あなたが達成しようとしていることができました(主な変更は「Type = forking」です):

[Unit]                                                                                                 
Description=FHEM Perl Server                                                                           
After=syslog.target network.target                                                                     

[Service]                                                                                              
Type=forking                                                                                                           
User=fhem                                                                                              
WorkingDirectory=/opt/fhem                                                                             
ExecStart=/usr/bin/perl fhem.pl fhem.cfg

また、「fhem」ユーザーを使用しているように見えるため、このユーザーが必要なファイルに対して十分な権限を持っていることを確認してください (少なくともログディレクトリへの書き込みアクセスを許可する必要がありました)。

参考までに、AUR には fhem 用のパッケージがありますが、このサービス ファイルはありません。

于 2013-10-22T13:53:44.373 に答える