【linux】配置网口IP|RDMA配置IP|ens、eno、enp网口的区别|ping不通问题排查|DNS设置

目录

linux网口配置IP

1、查看接口信息

2、配置IP

3、重启网络服务确认ip配置结果

一个网卡配置多个IP

Centos配置DNS

配置RDMA网卡

查看哪个网口连线方法

ens、eno、enp网口的区别

错误记录

ping不通排查

相关脚本指令记录

centOS 8 重启网络服务 / 重启网卡 


本文作者:bandaoyu,随时更新,最新内容请到原文地址:http://t.csdn.cn/Vk7gG

linux网口配置IP

1、查看接口信息

#启动网络管理器

[root@localhost ~]# NetworkManager start

#查看连接

[root@localhost ~]# service network resatrt 
[root@localhost ~]# nmcli conn show   

可以看到网口中接线的是ens2f0

网口名就是ens2f0     UUID 就是 ff888acf-86ae-3132-927c-6b47656c58c3

(有时候service network resatrt 执行后需要等一会,不然nmcli connection show检查出的已连线连接不全)

(上面方法并不保险,最保险的是ethtool  ethx 一个一个试,ethtool  ethx之前需要NetworkManager start,conn show 并不显示没有对应ifcfg-xxx文件的端口,所有可以用ip addr 显示所有端口

可以用ethtool 命令确认连线状况:

[root@rdma61 sysconfig]# ethtool ens2f0    
Settings for eth18-0:
        Supported ports: [ Backplane ]
      ……
                               link
        Link detected: yes

Link detected: yes 表示连线

如果NetworkManager 是一次启动,从其打印的内容也可以得知哪个网口连接网线:

2、配置IP

方法1:

输入命令nmtui 使用UI界面进行配置,参考:https://blog.csdn.net/weixin_46560589/article/details/125309320

方法2:

  • 执行下面命令,生成配置文件

[root@localhost ~]# nmcli conn add ifname ens2f0 con-name ens2f0 type ethernet

INAME=ens2f0 &&nmcli conn add ifname ${INAME} con-name ${INAME} type ethernet

ifname:接口名  con-name:连接配置名

以上命令添加配置文件的缺点是有时候不生成HWADDR ,这样的话设备重启,端口名称可能会改变。

 nmcli命令说明见: https://www.cnblogs.com/libertylife/p/10497512.html

  • 修改配置文件

[root@localhost ~]# vim /etc/sysconfig/network-scripts/ifcfg-ens2f0
TYPE=Ethernet
BOOTPROTO=static
DEFROUTE=yes
PEERDNS=yes
PEERROUTES=yes
IPV4_FAILURE_FATAL=no
IPV6INIT=yes
IPV6_AUTOCONF=yes
IPV6_DEFROUTE=yes
IPV6_PEERDNS=yes
IPV6_PEERROUTES=yes
IPV6_FAILURE_FATAL=no
NAME=ens2f0
UUID=5f1fde10-d2a2-4ea5-8213-7cdb53bb59bf
DEVICE=ens2f0
ONBOOT=yes
HWADDR=00:0c:29:4d:bb:5d

IPADDR=192.168.1.101

PREFIX=24                   #=mask 255.255.255.0

GATEWAY=192.168.1.254   #根据需要配置

说明:

BOOTPROTO=static    静态地址

修改设备名

DEVICE=ens2f0  自动生成

添加IP、掩码、网关

IPADDR=192.168.1.101

PREFIX=24                      #=mask 255.255.255.0

GATEWAY=192.168.1.254

原文链接:https://blog.csdn.net/qq_36783142/article/details/75353944

方法3:

直接创建和编辑文件(建设查到的网口名是ens2f0

vim /etc/sysconfig/network-scripts/ifcfg-ens2f0

将下面的内容按网口实际信息修改(注意确认,不要漏改)

改NAME、UUID、DEVICE、IPADDR

TYPE=Ethernet
PROXY_METHOD=none
BROWSER_ONLY=no
BOOTPROTO=static
DEFROUTE=yes
IPV4_FAILURE_FATAL=no
IPV6INIT=yes
IPV6_AUTOCONF=yes
IPV6_DEFROUTE=yes
IPV6_FAILURE_FATAL=no
IPV6_ADDR_GEN_MODE=stable-privacy

NAME=ens2f0
UUID= ff888acf-86ae-3132-927c-6b47656c58c3
DEVICE=ens2f0
ONBOOT=yes         
IPADDR=182.200.31.55
PREFIX=24
GATEWAY=192.168.1.254   #根据需要配置

自动化: 

MYIFNAME=ens7f2;
MYIPADDR=192.168.31.60;
MYGATEWAY=182.200.31.251;
MYHWADDR=$(ifconfig|grep ${MYIFNAME} -A 5|grep ether|awk '{print $2}');

#modify line
sed -i "s/^BOOTPROTO.*\+=.*/BOOTPROTO=static/" /etc/sysconfig/network-scripts/ifcfg-${MYIFNAME};
sed -i "s/^ONBOOT.*\+=.*/ONBOOT=yes/"          /etc/sysconfig/network-scripts/ifcfg-${MYIFNAME};

#delete line
sed -i '/IPADDR/d' /etc/sysconfig/network-scripts/ifcfg-${MYIFNAME};
sed -i '/PREFIX/d' /etc/sysconfig/network-scripts/ifcfg-${MYIFNAME};
sed -i '/GATEWAY/d' /etc/sysconfig/network-scripts/ifcfg-${MYIFNAME};
sed -i '/HWADDR/d' /etc/sysconfig/network-scripts/ifcfg-${MYIFNAME};

#add line
sed -i "/ONBOOT/a\IPADDR=${MYIPADDR}"          /etc/sysconfig/network-scripts/ifcfg-${MYIFNAME};
sed -i "/IPADDR/a\PREFIX=24"                   /etc/sysconfig/network-scripts/ifcfg-${MYIFNAME};
sed -i "/PREFIX/a\GATEWAY=${MYGATEWAY}"        /etc/sysconfig/network-scripts/ifcfg-${MYIFNAME};
sed -i "/GATEWAY/a\HWADDR=${MYHWADDR}"         /etc/sysconfig/network-scripts/ifcfg-${MYIFNAME};
#show
cat /etc/sysconfig/network-scripts/ifcfg-${MYIFNAME};
#end

3、重启网络服务确认ip配置结果

[root@localhost ~]# systemctl restart network

[root@localhost ~]# ifconfig 

[root@localhost ~]# ip -a

一个网卡配置多个IP

在Linux系统下面,第一块网卡就叫eth0,第二块网卡就叫eth1,这里我们给第一块网卡设置多个IP,也即添加多个子网卡,如eth0:0、eth1:1这种网络接口,LINUX最多可以支持255个IP子网卡。


1 切换至 /etc/sysconfig/network-scripts/目录下

cd /etc/sysconfig/network-scripts

2 拷贝/etc/sysconfig/network-scripts目下的ifcfg-eth0到当前目录下,并且改名为eth0:1
cp ifcfg-eth0 ifcfg-eth0:1

3 修改ifcfg-eth0:1文件

DEVICE=eth0:1
IPADDR=192.168.20.9

4 重启网络
systemctl restart network

5 查询ip
ifconfig

原文链接:https://blog.csdn.net/qq_45609914/article/details/124028859

Centos配置DNS

DNS在 /etc/resolv.conf中配置,但由于一旦网卡重启NetworkManager就会重置 /etc/resolv.conf,所以需要配置NetworkManager.conf,让NetworkManager不要重置 /etc/resolv.conf。

修改NetworkManager.conf 配置文件

vi /etc/NetworkManager/NetworkManager.conf

#在[main]中添加
dns=no


修改resolv.conf配置文件


vim /etc/resolv.conf
#添加dns
nameserver 114.114.114.114


重启
systemctl restart NetworkManager


https://blog.csdn.net/weixin_41083358/article/details/124064871

配置RDMA网卡

1、查看device的命令:

# ibv_devices

    device                 node GUID
  ------              ----------------
    rdmap175s0f0        40a6b70b6f300000
    rdmap175s0f1        40a6b70b6f310000
————————————————

2、查看RDMA device和linux网口的对应关系

Mellanox:

 ibdev2netdev

因特尔

ibv_devices|awk '{system("echo "$1"\"-->\"`ls /sys/class/infiniband/"$1"/device/net`")}' |& grep -v '/device/net'

ibv_devices|awk '{system("echo "$1"\"-->\"`ls /sys/class/infiniband/"$1"/device/net`")}'

rocep24s0f3-->ens2f3
rocep24s0f1-->ens2f1
rocep24s0f0-->ens2f0
rocep24s0f2-->ens2f2

3、查看连接线的接口

#启动网络管理器

[root@localhost ~]# NetworkManager start

#查看连接
[root@localhost ~]# nmcli connection show   

找到连线的接口。

使用ethtool 逐个检查上面打出的端口,看到Link detected: yes,就是这个端口是连着网线的,就可以对这个网口配置IP。

ethtool ens2f3

ethtool ens2f1

……

[root@localhost ~]# ethtool ens3f1
Settings for ens3f1:
        Supported ports: [ FIBRE ]
       ……
        Current message level: 0x00000007 (7)
                               drv probe link
        Link detected: yes

配置IP

剩下配置IP的过程同上面的:linux网口配置IP

重启网卡

ifdown  ens2f0

ifup  ens2f0

5、确认RDMA功能

查看官方说明,使用官方的测试工具测试。

查看哪个网口连线方法

方法1:(保险的方法)

1. 查看连接状态:ip link
2.让eth0网口闪烁:ethtool  eth0
把所有的都试一遍就知道了
3.如果能拔网线,拔一下再插上,/var/log/messages日志里能看到

方法2:(适合没有配置过IP的机器)

#启动网络管理器

[root@localhost ~]# NetworkManager start

#查看连接

[root@localhost ~]# service network resatrt 
[root@localhost ~]# nmcli connection show   

ens、eno、enp网口的区别

扩展知识内容:

  • en标识ethernet
  • o:主板板载网卡,集成是的设备索引号
  • p:独立网卡,PCI网卡
  • s:热插拔网卡,USB之类的扩展槽索引号
  • nnn(数字):MAC地址+主板信息计算得出唯一序列

  1. eno1:代表由主板bios内置的网卡

  2. ens1:代表有主板bios内置的PCI-E网卡

  3. enp2s0: PCI-E独立网卡

  4. eth0:如果以上都不使用,则回到默认的网卡名

错误记录

service network restart 失败

systemctl status network.service 查看

1、ens2f0 和ens5f0 中的device 名字冲突,原因是下面的命令 ifname con-name 不一致

nmcli connection add ifname ens2f0 con-name ens5f0 type ethernet

类似错误还有用方法2配置IP时,UUID忘记改,造成冲突

报错:Failed to restart network.service: Unit network.service not found.

1、可以尝试使用以下命令:
service network-manager restart

2、如果是 Kali Linux(Debian),则需要用以下命令:
service networking restart

3、如果是Centos 8,则需要用以下命令:

1.重启网卡之前一定要重新载入一下配置文件,不然不能立即生效

1

nmcli c reload

2.重启网卡(下面的三条命令都可以):

1

2

3

nmcli c up ens160

nmcli d reapply ens160

nmcli d connect ens160

 总结:重启centos8的网卡,先载入新的配置文件,然后在执行重启网卡命令即可。

以上其实是下面的缩写:

nmcli connection reload

启动 nmcli connection down ens33
停止 nmcli connection up ens33

CentOS 8系统网卡启动命令_爱辉弟的博客-CSDN博客_centos8重启网络服务命令

配置没有问题,但是死活ping不通

案例:

用ethtool 查看 ens3f0 和ens3f1 都是Link detected: yes,所以配置了 ens3f0 的IP,但是始终无法和其他主机通信。改配置 ens3f1就好了。

原因暂时不明。

网关设置错误可以导致连接不上

ens7f0

DEVICE=ens7f0
IPADDR=172.17.31.55
PREFIX=24
GATEWAY=182.200.31.251

ethA3d-0 

DEVICE="ethA3d-0"
IPADDR=182.200.31.55
PREFIX=24
GATEWAY=182.200.31.251

IP是172.17.31.55,我给它设置网关:182.200.31.251。 导致SSH 连接不上ethA3d-0 :182.200.31.55

RTNETLINK answers: File exists

网友:

原因1

检查发现起了 NetworkManager:
#chkconfig --list|grep -i manager
NetworkManager  0:off   1:ff   2:on   3:on   4:on   5:on   6:off

关闭NetworkManager即可:
#chkconfig NetworkManager off
#service NetworkManager stop
#service network restart

关闭NetworkManager:之后我的问题仍然没有解决,我直接重启,重启后正常。

ping不通排查

  • ping本机是否畅通

  这个可以看出本机网卡驱动是否正常,协议是否安装完全。本机可以ip,也可以127.0.0.1来ping。若通就表示网卡驱动是正常的。可以不用重装网卡驱动。

  • 接线是否正常

是否接在了对应的口上。用下面的命令查看ethxx口上是否接上了线

NetworkManager start 

ethtool  ethxx
  • 防火墙

  • selinux

输入 getenforce 查看是否是enforce ,如果是,可能会被限制。

  • 是否是存在别的配置网口配置文件用同样的IP

例如:

ifcfg-ens3f1 配置了192.168.31.57 配置全部正确,但是就是不通。

进入cd /etc/sysconfig/network-scripts/,发现ifcfg-ens3f0里面的IP 也是192.168.31.57

输入mii-tool可以查看网线是否连接到网卡
#mii-tool

  1. eth0: negotiated 100baseTx-FD, link ok

有时驱动可能不支持会出错下列错误
#mii-tool

  1. SIOCGMIIPHY on 'eth0' failed: Operation not supported
  2. no MII interfaces found

显示所有网络连接:nmcli con show
显示活动网络连接:nmcli con show -active
显示指定网络连接的详情:nmcli con show eno16777728
显示网络设备连接状态:nmcli dev status
显示所有网络设备的详情:nmcli dev show
显示指定网络设备的详情:nmcli dev show eno16777728
启用网络连接:nmcli con up eno16777728
停用网络连接(可被自动激活):nmcli con down eno33554960
禁用网卡,防止被自动激活:nmcli dev dis eth0
删除网络连接的配置文件:nmcli con del eno33554960
重新加载配置网络配置文件:nmcli con reload
动态获取IP方式的网络连接配置:nmcli con add con-name eno16777728 type ethernet ifname eno16777728
指定静态IP方式的网络连接配置:nmcli con add con-name eno16777728 ifname eno16777728 autoconnect yes type ethernet ip4 10.1.254.254/16 gw4 10.1.0.1
启用/关闭所有的网络连接:nmcli net on/off
禁用网络设备并防止自动激活:nmcli con dis eno33554960
查看添加网络连接配置的帮助:nmcli con add help

作者:陈超同学
链接:https://www.jianshu.com/p/c333e15896f7
来源:简书
著作权归作者所有。商业转载请联系作者获得授权,非商业转载请注明出处。

相关脚本指令记录

脚本配置:


MYIFNAME=ens7f2;
MYIPADDR=192.168.31.55;
MYGATEWAY=182.200.31.251;
MYHWADDR=$(ifconfig|grep ${MYIFNAME} -A 5|grep ether|awk '{print $2}');

#modify line
sed -i "s/^BOOTPROTO.*\+=.*/BOOTPROTO=static/" /etc/sysconfig/network-scripts/ifcfg-${MYIFNAME};
sed -i "s/^ONBOOT.*\+=.*/ONBOOT=yes/"          /etc/sysconfig/network-scripts/ifcfg-${MYIFNAME};

#delete line
sed -i '/IPADDR/d' /etc/sysconfig/network-scripts/ifcfg-${MYIFNAME};
sed -i '/PREFIX/d' /etc/sysconfig/network-scripts/ifcfg-${MYIFNAME};
sed -i '/GATEWAY/d' /etc/sysconfig/network-scripts/ifcfg-${MYIFNAME};
sed -i '/HWADDR/d' /etc/sysconfig/network-scripts/ifcfg-${MYIFNAME};

#add line
sed -i "/ONBOOT/a\IPADDR=${MYIPADDR}"          /etc/sysconfig/network-scripts/ifcfg-${MYIFNAME};
sed -i "/IPADDR/a\PREFIX=24"                   /etc/sysconfig/network-scripts/ifcfg-${MYIFNAME};
sed -i "/PREFIX/a\GATEWAY=${MYGATEWAY}"        /etc/sysconfig/network-scripts/ifcfg-${MYIFNAME};
sed -i "/GATEWAY/a\HWADDR=${MYHWADDR}"         /etc/sysconfig/network-scripts/ifcfg-${MYIFNAME};
#show
cat /etc/sysconfig/network-scripts/ifcfg-${MYIFNAME};

#ip4 to hex ip

#ip4 to hex ip
function ip4_to_hex()
{

tmpifs=${IFS}

IFS="."
ipf1=`echo $1|awk '{print $1}'`
ipf2=`echo $1|awk '{print $2}'`
ipf3=`echo $1|awk '{print $3}'`
ipf4=`echo $1|awk '{print $4}'`

IFS=${tmpifs}

g_hexip=`printf "%x%x:%x%x" ${ipf1} ${ipf2} ${ipf3} ${ipf4}`
 echo "ip:"$1 
 echo "hexip:"$g_hexip 

}

从配置文件获取IP并转换成端口名 

ethip=$(line=`cat $CEPH_CONF |grep -E 'public_addr'`&&echo ${line#*=})
g_nic_name=$(ifconfig | awk -F ":" '/'$ethip'/{print a}{a=$1}')

netmask掩码和cidr掩码位转换

脚本接收见文章末尾。

#!/bin/bash
mask2cdr ()
{
    # Assumes there's no "255." after a non-255 byte in the mask
    local x=${1##*255.}
    set -- 0^^^128^192^224^240^248^252^254^ $(( (${#1} - ${#x})*2 )) ${x%%.*}
    x=${1%%$3*}
    echo $(( $2 + (${#x}/4) ))
}
cdr2mask ()
{
    # Number of args to shift, 255..255, first non-255 byte, zeroes
    set -- $(( 5 - ($1 / 8) )) 255 255 255 255 $(( (255 << (8 - ($1 % 8))) & 255 )) 0 0 0
    [ $1 -gt 1 ] && shift $1 || shift
    echo ${1-0}.${2-0}.${3-0}.${4-0}
}
 # examples:
mask2cdr 255.255.255.0
cdr2mask 24

centOS 8 重启网络服务 / 重启网卡 

centos8 如何重启⽹络服务
1.重启⽹卡之前⼀定要重新载⼊⼀下配置⽂件,不然不能⽴即⽣效

nmcli c reload

2.重启⽹卡(下⾯的三条命令都可以):

nmcli c up ens160
nmcli d reapply ens160
nmcli d connect ens160

总结:重启 centos8 的⽹卡,先载⼊新的配置⽂件,然后在执⾏重启⽹卡命令即可。
 
***** centos 版本区别*****

CentOS 7中支持 network.service 和 NetworkManager.service 2种方式配置网络,而在 CentOS 8 中已经废弃 network.service ,需要通过NetworkManager.service 配置网络。因此通过 systemctl restart network 已经无法使用了。

[root@localhost ~]# cat /etc/redhat-release 
CentOS Linux release 8.4.2105
[root@localhost ~]# systemctl restart network
Failed to restart network.service: Unit network.service not found.
  • 方法一

使用 nmcli 命令,需要两条指令,先加载配置,然后应用

[root@localhost ~]# nmcli c reload
[root@localhost ~]# nmcli c up ens33
Connection successfully activated (D-Bus active path: /org/freedesktop/NetworkManager/ActiveConnection/9)

  • 方法二

使用 ifdown 和 ifup

[root@localhost ~]# ifdown ens33;ifup ens33 
Connection 'ens33' successfully deactivated (D-Bus active path: /org/freedesktop/NetworkManager/ActiveConnection/9)
Connection successfully activated (D-Bus active path: /org/freedesktop/NetworkManager/ActiveConnection/10)

netmask掩码和cidr掩码位转换脚本说明

mask2cdr()

要从像这样的点十进制网络掩码中获取CIDR前缀,请执行以下操作:

255.255.192.0

您首先必须将四个八位位组转换为二进制,然后计算最高有效位(即前导位的数量):

11111111.11111111.11000000.00000000  # 18 ones = /18 in CIDR

此功能相当有创意。首先,我们剥离所有前导255八位位组(即二进制全为八位的八位位组)并将结果存储在变量中x

local x=${1##*255.}

此步骤使用参数扩展,整个脚本非常依赖此参数。如果继续使用示例的网络掩码255.255.192.0,则现在具有以下值:

$1: 255.255.192.0
$x: 192.0

接下来我们设置了三个变量:$1$2,和$3。这些称为位置参数 ; 它们很像普通的命名变量,但是通常在将参数传递给脚本或函数时进行设置。我们可以直接使用来设置值set --,例如:

set -- foo bar  # $1 = foo, $2 = bar

与位置参数相比,我更喜欢使用命名变量,因为它使脚本更易于阅读和调试,但是最终结果是相同的。我们设置$1为:

0^^^128^192^224^240^248^252^254^

这实际上只是一个表,用于将某些十进制值转换为二进制并计算1位数。我们稍后会再讨论。

我们设置$2

$(( (${#1} - ${#x})*2 ))

这称为算术扩展。它看起来很复杂,但实际上只是在计算1我们在第一个命令中剥离的位数。它分解为:

(number of chars in $1 - number of chars in $x) * 2

在我们的情况下可以解决

(13 - 5) * 2 = 16

我们剥离了两个八位位组,得到16。这很有意义。

我们设置$3为:

${x%%.*}

这是$x第一个.剥离后的所有值的值。在我们的情况下,这是192

我们需要将此数字转换为二进制并计算其中的1位数,因此让我们回到“转换表”。我们可以将表格分为相等的块,每个块包含四个字符:

0^^^  128^  192^  224^  240^  248^  252^  254^

以二进制形式,以上数字为:

00000000 10000000 11000000 11100000 11110000 11111000 11111100 11111110
# 0 ones 1 one    2 ones   3 ones   ...

如果我们从左数起,则表中的每个四个字符的块对应1于二进制的一个附加位。我们正在尝试进行转换192,因此让我们先从表的最右边192开始,然后将其存储在x

x=${1%%$3*}

$x现在的值

0^^^128^

其中包含两个四个字符的块或1二进制的两位。

现在,我们只需要将1255八位字节的位(总共16个,存储在variable中$2)和1上一步中的位(总共2个)相加:

echo $(( $2 + (${#x}/4) ))

哪里

${#x}/4

是的字符数$x除以4,即中的四个字符的块数$x

输出:

18

cdr2mask()

让我们继续运行前面的示例,该示例的CIDR前缀为18

我们set --用来设置位置参数$ 1到$ 9:

$1: $(( 5 - ($1 / 8) ))  # 5 - (18 / 8) = 3 [integer math]
$2: 255
$3: 255
$4: 255
$5: 255
$6: $(( (255 << (8 - ($1 % 8))) & 255 ))  # (255 << (8 - (18 % 8))) & 255 = 192
$7: 0
$8: 0
$9: 0

让我们来看看用来设置公式$1$6一点点接近。$1设定为:

$(( 5 - ($1 / 8) ))

网络掩码的CIDR前缀的最大和最小值为32

11111111.11111111.11111111.11111111

子网掩码为0

00000000.00000000.00000000.00000000

上面的公式使用整数除法,因此可能的结果为1到5:

5 - (32 / 8) = 1
5 - ( 0 / 8) = 5

$6 设定为:

$(( (255 << (8 - ($1 % 8))) & 255 ))

让我们针对示例CIDR前缀进行细分18。首先,我们取模数并做一些减法:

8 - (18 % 8) = 6

接下来,我们按此值将255按位移位:

255 << 6

这与将6 0位二进制数推入255的末尾相同:

11111111000000

最后,我们将该值与255按位与:

11111111000000 &
00000011111111  # 255

这使

00000011000000

或简单地

11000000

看起来熟悉?这是二进制格式的网络掩码中的第三个八位位组:

11111111.11111111.11000000.00000000
                  ^------^

以十进制表示的值是192。

接下来,我们根据的值移动位置参数$1

[ $1 -gt 1 ] && shift $1 || shift

在我们的例子中,值$1是3,因此我们将位置参数3向左移动。的先前值$4成为的新值$1,的先前值$5成为的值$2,依此类推:

$1: 255
$2: 255
$3: 192
$4: 0
$5: 0
$6: 0

这些值应该看起来很熟悉:它们是我们的网络掩码中的十进制八位字节(最后加上两个额外的零)。要获得网络掩码,我们只需将前四个点之间的点打印出来即可:

echo ${1-0}.${2-0}.${3-0}.${4-0}

-0每个参数后表示使用0作为默认值,如果参数没有设置。

输出:

255.255.192.0

2020-06-07

 

posted on 2022-10-04 01:23  bdy  阅读(587)  评论(0编辑  收藏  举报

导航