如何检查linux是不是可以连接网络

Posted

tags:

篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了如何检查linux是不是可以连接网络相关的知识,希望对你有一定的参考价值。

参考技术A 看你是要查内网是否连接还是外网是否连接。其实基本方法是类似的。
如果检查内网是否连接:
直接ping网关的IP地址:
如:ping 192.168.100
检查外网是否连接:
1、可以打开浏览器,输入百度等网站的地址,看是否能打开
2、也可以使用ping命令本回答被提问者采纳
参考技术B ping 网关 参考技术C ping 8.8.8.8
看看能不能ping通

Linux/Unix 检查 *** 连接是不是激活/启动

【中文标题】Linux/Unix 检查 *** 连接是不是激活/启动【英文标题】:Linux/Unix check if *** connection is Active/UpLinux/Unix 检查 *** 连接是否激活/启动 【发布时间】:2015-07-15 03:17:46 【问题描述】:

我有一个代码可以检测 Open*** 连接是打开还是关闭:

if echo 'ifconfig tun0' | grep -q "00-00-00-00-00-00-00-00-00-00-00-00-00-00-00-00"
then
echo "*** up"
else
echo "*** down"
fi
exit 0

现在我正在尝试重新编写代码以使用 PPTP 或 IPSEC 连接。我已经尝试过:

if echo 'ifconfig ppp0' | grep -q "00-00-00-00-00-00-00-00-00-00-00-00-00-00-00-00"

或与 ipsec 相同但不起作用。有没有其他方法可以检测 PPTP 或 IPSEC 连接?

【问题讨论】:

echo 的用法很奇怪。这些应该是反引号吗? 这里有完整的代码并不奇怪:if echo 'ifconfig tun0' | grep -q "00-00-00-00-00-00-00-00-00-00-00-00-00-00-00-00" then echo "*** up" else echo 1 > /usr/syno/etc/syno***client/***c_connecting syno***c reconnect --protocol=open*** --name=XXXXXX fi exit 0 所以基本上我需要在 *** 关闭后重新连接...重新连接脚本工作正常,但我正在努力解决“如果” 对于看到这个问题的任何人,if echo 'ifconfig tun0' | grep -q "00-00-00-00-00-00-00-00-00-00-00-00-00-00-00-00" 的意思是:检查字符串“ifconfig tun0”是否包含字符串“00-00-00-00-00-00-00- 00-00-00-00-00-00-00-00-00"。一个正确的例子是if ifconfig tun0 | grep -q "00-00-00-00-00-00-00-00-00-00-00-00-00-00-00-00"(没有回显,没有单引号),这意味着:运行ifconfig tun0,然后从其输出中检查字符串 【参考方案1】:

echo 声明是错误的。正如@unwind 所说,单引号(')应该是反引号(`)。您当前的代码将文字值 ifconfig ppp0 发送到 grep,这没有任何用处。

但您实际上也不需要反引号。您可以将ifconfig 的输出发送到grep 目录;使用echo 不会给你任何东西:

if ifconfig ppp0 | grep -q "00-00-00-00-00-00-00-00-00-00-00-00-00-00-00-00"; then
  echo ppp connection is up
fi

【讨论】:

在您的示例中,当没有 *** 且没有 *** 连接时,我得到“ifconfig: ppp0: error fetching interface information: Device not found”。 在我的情况下是 tun0 而不是 ppp0【参考方案2】:

以下脚本将:

每 5 分钟运行一次 ISPConnectivity.sh 脚本。这意味着 *** 隧道不会关闭超过 5 分钟。 检查tun接口是否关闭,如果是则启动***脚本。 如果 tun0 接口已启动,请检查连接性。它对 2 个公共 IP 进行 ping 测试(如果我从所测试的 1 个 IP 中得到一个响应,我认为这是成功的),并且所有人都必须无法运行 *** 脚本。我在多台主机上运行了 ping 测试,以防止在 1 个 IP 上 ping 测试失败时启动 *** 脚本。 将所有失败输出发送到我的主目录中的一个文件。我不需要查看是否有任何测试成功。

sudo crontab 的内容:

*/5 * * * * /home/userXXX/ISPConnectivity.sh >> /home/userXXX/ISPConnectivity.log 2>&1

ISPConnectivity.sh 脚本的内容:

#!/bin/bash 

# add ip / hostname separated by white space
#HOSTS="1.2.3.4"
HOSTS="8.8.8.8 4.2.2.4"
# no ping request
totalcount=0
COUNT=4

DATE=`date +%Y-%m-%d:%H:%M:%S`

if ! /sbin/ifconfig tun0 | grep -q "00-00-00-00-00-00-00-00-00-00-00-00-00-00-00-00"
then
        echo $DATE      tun0 down
        sudo /home/userXXX/start***.sh start
else

        for myHost in $HOSTS;
        do
                count=`ping -c $COUNT $myHost | grep 'received' | awk -F',' ' print $2 ' | awk ' print $1 '`
                totalcount=$(($totalcount + $count))
        done

        if [ $totalcount -eq 0 ]
        then
                echo $DATE      $totalcount "fail"
                sudo /home/userXXX/start***.sh start
        #else
        #       echo $DATE      $totalcount "pass"
        fi
fi

【讨论】:

start***.sh 脚本中有什么内容?【参考方案3】:

您也可以使用 nmcli 命令检查 *** 是否正在运行。

nmcli c 显示 --active | grep ***

【讨论】:

如果使用 nmcli 很好,尽管我必须使用 grep 搜索 tun(可能是隧道)【参考方案4】:

我实际上正在寻找更灵活的解决方案,例如:

MyIP=$(curl http://api.ipify.org/?format=text)
if [ "$MyIP" != "MYORYGINALIP" ]
then
    echo "IPSEC *** is Running -  " $MyIP
else
    echo "IPSEC *** is Not Running - " $MyIP
fi
exit 0

那怎么办?我可以改进它吗?

【讨论】:

它只有在你有一个静态 IP 地址的情况下才有效,我不会称之为完全灵活的解决方案。【参考方案5】:

ip 路由列表 220 如果显示 IP 地址 -> *** 连接建立,无 -> 无 ***

如果 [ "0" == ifconfig | grep wlan0 | wc -l ];然后回显“NO wlan0 没有 ***”; else echo "YES wlan0 has ***";菲

【讨论】:

以上是关于如何检查linux是不是可以连接网络的主要内容,如果未能解决你的问题,请参考以下文章

linux如何查看网络连接情况?

LINUX系统怎么查网络是不是连接?

如何用C语言检测网络是不是连接上、已连接、已断开状态

Linux 如何判断哪个网卡是不是连接网线

linux中MySQL本地可以连接,远程连接不上问题

如何检查 Linux 中的开放端口列表?