【发布时间】:2016-06-18 17:41:53
【问题描述】:
我有一台工作的计算机,有时我会从家里醒来以访问它,但是当启动并从我们的 DHCP 服务器获取另一个 IP 地址时,我该如何访问它?
情况和我的“工作流程”如下:
- 我从家里的 PC 连接到办公室的 VPN
- ssh 到办公室局域网中的专用服务器(它有一个固定的 IP 地址)
- 在该服务器上,我调用了一个脚本,该脚本使用我办公室 PC 的 MAC 地址广播一个 WoL 数据包
- 我的办公室 PC 启动(确实如此,当然!)
现在理论上,只要我知道它的 IP 地址,我就可以通过 SSH 连接到我的办公室 PC。 有时它会变得相同,有时它会改变。 为了规避这一点,我有以下想法:
- 启动我的办公室 PC 后,通过 SSH 连接到办公室服务器,并将其自己的 IP 地址写入服务器上的某个文本文件中
- 我检查了服务器上的那个文件(我可以连接到它,因为它的 IP 固定),找到我的办公室 PC 的 IP 地址,然后可以从我的家庭 PC SSH 到我的办公室 PC
所有计算机都运行 Linux;家里的 Ubuntu 14.04,办公室服务器上的 SLES,我办公室 PC 上的 OpenSUSE 13.1。这都不是问题。
为了使这一切正常工作,我只需要在我的办公室 PC 上运行一个脚本,该脚本在启动时运行当网络启动并运行时。
我的脚本(publish_ip.sh)如下:
# get own IP address:
ip=$(ip addr show | awk '$1=="inet" && $2 !~ /127\.0\.0\.1/ { split($2, a, "/"); print a[1]}');
# SSH to the office server (10.64.5.84) and write own IP address to a file there:
ssh -x -e none 10.64.5.84 "echo $(date) $ip >> office_pc_address.txt"
为了在启动时运行此脚本,我为我的办公室 PC 创建了一个 systemd 服务文件 publish-ip.service:
[Unit]
Description=publishes own IP address
Wants=network.target
After=network.target
[Service]
Type=oneshot
ExecStartPre=/usr/bin/sleep 30
ExecStart=/home/perldog/bin/publish_ip.sh
User=perldog
[Install]
WantedBy=multi-user.target
但这是我在办公室电脑上经常看到的:
linux-tz7m:/usr/lib/systemd/system # systemctl status publish-ip.service
publish-ip.service - publishes own IP address
Loaded: loaded (/usr/lib/systemd/system/publish-ip.service; enabled)
Active: failed (Result: exit-code) since Mon 2016-02-29 12:17:34 CET; 4 days ago
Process: 1688 ExecStart=/home/perldog/bin/publish_ip.sh (code=exited, status=255)
Process: 1016 ExecStartPre=/usr/bin/sleep 30 (code=exited, status=0/SUCCESS)
Main PID: 1688 (code=exited, status=255)
Feb 29 12:17:34 linux-tz7m publish_ip.sh[1688]: ssh: connect to host 10.64.5.84 port 22: Network is unreachable
显然我的服务启动并调用了我的脚本,但该脚本中的 SSH 命令失败并显示Network is unreachable。
我尝试了我的服务文件中的所有内容,以便它仅在网络启动后运行,但我不明白。我试过Wants=network.target,
After=network.target、WantedBy=multi-user.target,甚至插入了ExecStartPre=/usr/bin/sleep 30。没有任何效果。
当我的脚本被调用并尝试通过 SSH 连接到办公室服务器时,我总是得到 Network is unreachable。
问题:我的服务文件需要哪些设置才能使其仅在可以通过 SSH 访问办公室服务器后运行?
注意:当我在办公室并且我的办公室电脑启动并运行时,我的脚本和服务都可以正常运行,即systemctl start publish-ip.service
工作没有任何错误。
【问题讨论】:
-
一个相关的解决方案,stackoverflow.com/a/43192575/1451311。将
network.target更改为network-online.target已为我解决。
标签: linux networking ssh systemd