首页 > 运维 > CentOS > 正文

CentOS命令窗口怎么上网_CentOS命令行网络连接方法教程

絕刀狂花
发布: 2025-08-28 14:01:01
原创
252人浏览过
首先通过DHCP自动获取或静态配置IP、子网掩码、网关和DNS来实现CentOS命令行上网,推荐优先使用DHCP;若需固定IP,则手动编辑ifcfg-文件或用nmcli命令配置静态网络参数,并确保ONBOOT=yes或autoconnect=yes以实现持久化;配置后通过ip a、ip route、ping和cat /etc/resolv.conf等命令检查接口状态、路由、连通性与DNS;常见问题包括IP冲突、网关错误、DNS解析失败、接口未激活及防火墙拦截,需逐步排查;最终通过systemctl restart NetworkManager使配置生效,确保重启后网络仍可用。

centos命令窗口怎么上网_centos命令行网络连接方法教程

在CentOS的命令窗口让机器连接到互联网,核心其实就是正确配置好你的网络接口(比如网卡)的IP地址、子网掩码、默认网关以及DNS服务器信息,然后确保这个接口是激活状态。这听起来有点像在黑暗中摸索,但只要思路清晰,几条命令就能搞定。无论是通过DHCP自动获取,还是手动指定静态IP,目的都是让数据包能找到出去的路,也能找到回来的家。

解决方案

让CentOS命令行上网,通常有两种主流思路:动态获取(DHCP)和静态配置。我个人更倾向于先尝试DHCP,因为省心,如果不行再考虑静态。

1. DHCP动态获取(最常用且推荐)

这是最简单的方式,如果你的网络环境有DHCP服务器(比如家用路由器),CentOS会自动分配IP地址。

  • 识别网络接口: 首先,你需要知道你的网卡叫什么。通常是

    eth0
    登录后复制
    ens33
    登录后复制
    enp0s3
    登录后复制
    之类的。

    ip a
    # 或者
    nmcli device show
    登录后复制

    从输出中找到那个状态是

    DISCONNECTED
    登录后复制
    UNAVAILABLE
    登录后复制
    的物理网卡设备名。假设是
    ens33
    登录后复制

  • 激活DHCP配置: NetworkManager是CentOS 7/8/9默认的网络管理工具,用它来操作非常方便。

    nmcli device connect ens33
    # 或者,如果你知道连接的名称(通常是`ens33`或`Wired connection 1`)
    nmcli connection up "ens33"
    登录后复制

    如果你的网络接口已经有配置文件(比如

    /etc/sysconfig/network-scripts/ifcfg-ens33
    登录后复制
    ),并且
    ONBOOT=yes
    登录后复制
    BOOTPROTO=dhcp
    登录后复制
    ,那么重启网络服务也行:

    sudo systemctl restart NetworkManager
    登录后复制

    或者更传统一点,直接使用

    ifup
    登录后复制
    命令(如果
    ifcfg-ens33
    登录后复制
    文件存在并配置了DHCP):

    sudo ifup ens33
    登录后复制
  • 验证连接:

    ip a # 检查IP地址是否已分配
    ping -c 4 baidu.com # 测试是否能解析域名并访问外部网络
    登录后复制

2. 静态IP配置

当DHCP不可用,或者你需要为服务器指定固定IP时,就需要手动配置。这通常涉及到编辑网络接口的配置文件。

  • 编辑网络配置文件: 找到你的网卡配置文件,通常在

    /etc/sysconfig/network-scripts/
    登录后复制
    目录下,文件名为
    ifcfg-你的网卡名
    登录后复制
    ,比如
    ifcfg-ens33
    登录后复制

    sudo vi /etc/sysconfig/network-scripts/ifcfg-ens33
    登录后复制

    文件内容大致会像这样,你需要根据你的网络环境进行修改或添加:

    TYPE="Ethernet"
    PROXY_METHOD="none"
    BROWSER_ONLY="no"
    BOOTPROTO="static" # 改为static或none
    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="ens33"
    UUID="xxxxxxxx-xxxx-xxxx-xxxx-xxxxxxxxxxxx" # 这个UUID不要改
    DEVICE="ens33"
    ONBOOT="yes" # 确保开机自启动
    IPADDR="192.168.1.100" # 你的静态IP地址
    NETMASK="255.255.255.0" # 子网掩码
    GATEWAY="192.168.1.1" # 默认网关
    DNS1="8.8.8.8" # 首选DNS服务器
    DNS2="114.114.114.114" # 备用DNS服务器
    登录后复制

    保存并退出

    vi
    登录后复制
    编辑器(按
    Esc
    登录后复制
    ,然后输入
    :wq
    登录后复制
    回车)。

  • 重启网络服务或激活接口:

    sudo systemctl restart NetworkManager
    # 或者
    sudo ifdown ens33 && sudo ifup ens33
    登录后复制
  • 验证连接: 同样使用

    ip a
    登录后复制
    ping baidu.com
    登录后复制
    进行验证。

3. 添加/修改DNS服务器

如果IP配置正确但无法访问域名(比如

ping 8.8.8.8
登录后复制
通,
ping baidu.com
登录后复制
不通),那多半是DNS问题。 你可以直接编辑
/etc/resolv.conf
登录后复制
文件,添加或修改
nameserver
登录后复制
行:

sudo vi /etc/resolv.conf
登录后复制

文件内容示例如下:

# Generated by NetworkManager
nameserver 8.8.8.8
nameserver 114.114.114.114
登录后复制

注意:

/etc/resolv.conf
登录后复制
文件可能会被NetworkManager或DHCP客户端自动覆盖。如果需要持久化,最好在
ifcfg-ens33
登录后复制
文件中指定
DNS1
登录后复制
DNS2
登录后复制
,或者通过
nmcli
登录后复制
命令进行配置。

CentOS命令行配置网络有哪些常见问题?

说实话,这块儿经常让人头疼,问题五花八门。我见过最常见的就是IP地址、子网掩码、网关配错,或者干脆是网卡名不对。

  • IP地址冲突或配置错误: 这是最基本的。你设的静态IP是不是已经被其他设备用了?或者,IP地址、子网掩码、网关三者之间是不是逻辑上就不对劲?比如网关不在你的子网范围内。
    ip a
    登录后复制
    命令一跑,如果IP地址是
    169.254.x.x
    登录后复制
    ,那基本就是没拿到IP,或者IP冲突了。
  • 网关配置错误: 网关是你的机器通往外部网络的“门”。如果这个门牌号错了,你的数据包就出不去。
    ip route
    登录后复制
    命令可以查看路由表,看看默认路由(
    default via ...
    登录后复制
    )是不是指向了正确的网关。
  • DNS解析问题: 机器能ping通IP地址(比如
    ping 8.8.8.8
    登录后复制
    ),但ping不通域名(
    ping baidu.com
    登录后复制
    ),那几乎百分之九十是DNS服务器没配对,或者DNS服务本身有问题。
    /etc/resolv.conf
    登录后复制
    文件是关键,或者检查
    ifcfg-
    登录后复制
    文件里的
    DNS1
    登录后复制
    /
    DNS2
    登录后复制
  • 网络接口未激活(ONBOOT=no): 很多时候,即使配置文件写对了,但
    ONBOOT=no
    登录后复制
    ,系统启动时网卡也不会自动激活。手动
    ifup
    登录后复制
    或者
    nmcli connection up
    登录后复制
    可以临时解决,但重启后又会断开。
  • 防火墙阻挡: CentOS自带的
    firewalld
    登录后复制
    有时会默认阻止一些出站连接,尤其是在你尝试访问特定端口或服务时。虽然默认情况下,出站流量通常是允许的,但如果你的防火墙规则被修改过,可能会是个问题。
    sudo firewall-cmd --list-all
    登录后复制
    可以查看当前规则。
  • 网卡驱动问题或虚拟化环境配置:虚拟机里,比如VMware或VirtualBox,如果网络适配器模式选错了(比如选成了“仅主机”或“NAT”但没有配置好),也会导致无法上网。物理机上,偶尔也会遇到网卡驱动没装好或不兼容的情况,不过CentOS对主流硬件支持通常不错。

遇到这些问题,我的经验是先检查最基础的配置,一步步排除。别着急,耐心点总能找到原因。

如何检查CentOS网络连接状态和排查故障?

检查网络状态和排查故障,就像医生看病,得有套路。我通常会从宏观到微观,从最可能的地方开始。

  • 查看IP地址和接口状态:

    ip a
    登录后复制

    这个命令能显示所有网络接口的IP地址、MAC地址以及接口状态(

    UP
    登录后复制
    /
    DOWN
    登录后复制
    )。如果你的网卡状态是
    DOWN
    登录后复制
    ,那肯定上不了网。如果IP地址是
    169.254.x.x
    登录后复制
    ,说明它没能从DHCP服务器获取到有效IP。

  • 检查路由表:

    ip route
    登录后复制

    确保有一条

    default via [你的网关IP]
    登录后复制
    的记录。这条记录是告诉你的系统,如果目标IP不在本地子网内,就通过这个网关发出去。如果没有,或者网关IP不对,那网络就不通。

  • 测试网络连通性(ping):

    ping -c 4 8.8.8.8 # 测试到DNS服务器的连通性
    ping -c 4 baidu.com # 测试域名解析和外部连通性
    登录后复制

    如果能ping通

    8.8.8.8
    登录后复制
    (Google的DNS服务器IP),但ping不通
    baidu.com
    登录后复制
    ,那问题很可能出在DNS解析上。反之,如果连
    8.8.8.8
    登录后复制
    都ping不通,那问题可能在IP配置、网关、防火墙或物理连接上。

    虎课网
    虎课网

    虎课网是超过1800万用户信赖的自学平台,拥有海量设计、绘画、摄影、办公软件、职业技能等优质的高清教程视频,用户可以根据行业和兴趣爱好,自主选择学习内容,每天免费学习一个...

    虎课网 62
    查看详情 虎课网
  • 查看DNS配置:

    cat /etc/resolv.conf
    登录后复制

    确认

    nameserver
    登录后复制
    后面列出的IP地址是正确的、可用的DNS服务器。

  • 检查网络服务状态:

    sudo systemctl status NetworkManager # 或者 network
    登录后复制

    确保NetworkManager服务正在运行。如果服务挂了,网络配置自然也就不生效了。

  • 查看防火墙规则:

    sudo firewall-cmd --list-all # 或者 iptables -L -n
    登录后复制

    检查是否有规则阻止了出站连接。一般来说,默认配置不会阻止出站,但如果你自定义过规则,就得留意了。

  • 查看系统日志:

    journalctl -xe | grep -i network
    登录后复制

    系统日志是排查问题的宝库。搜索

    network
    登录后复制
    相关的错误信息,可能会发现网卡驱动加载失败、DHCP客户端获取IP失败等详细原因。

  • 使用

    nmcli
    登录后复制
    工具:
    nmcli
    登录后复制
    是一个非常强大的工具,可以查看设备状态、连接信息、甚至进行配置。

    nmcli device status
    nmcli connection show
    nmcli device show ens33 # 查看特定接口的详细信息
    登录后复制

    这些命令能提供比

    ip a
    登录后复制
    更详细的NetworkManager管理下的网络信息。

排查故障时,一步步来,每一步都验证一下,这样才能快速定位问题。

CentOS命令行如何实现持久化网络配置?

持久化网络配置,就是让你的设置在系统重启后依然有效。没人希望每次开机都重新配一遍网络,那简直是噩梦。在CentOS里,实现持久化主要有两种方式:编辑

ifcfg-
登录后复制
文件或者使用
nmcli
登录后复制
命令。

1. 通过编辑

/etc/sysconfig/network-scripts/ifcfg-
登录后复制
文件

这是CentOS及RHEL系Linux发行版最经典、最直接的持久化方式。

  • 找到正确的配置文件:

    ls /etc/sysconfig/network-scripts/ifcfg-*
    登录后复制

    找到你想要配置的网卡对应的文件,比如

    ifcfg-ens33
    登录后复制

  • 编辑文件内容:

    sudo vi /etc/sysconfig/network-scripts/ifcfg-ens33
    登录后复制

    确保以下几个关键参数设置正确:

    • ONBOOT="yes"
      登录后复制
      :这是最重要的,它告诉系统在启动时激活这个网络接口。如果设为
      no
      登录后复制
      ,那配置再对也没用。
    • BOOTPROTO="dhcp"
      登录后复制
      BOOTPROTO="static"
      登录后复制
      :根据你的需求选择。
      • DHCP: 只需要
        BOOTPROTO="dhcp"
        登录后复制
      • Static: 需要
        BOOTPROTO="static"
        登录后复制
        ,并添加
        IPADDR="你的IP"
        登录后复制
        ,
        NETMASK="你的子网掩码"
        登录后复制
        ,
        GATEWAY="你的网关IP"
        登录后复制
        ,
        DNS1="首选DNS"
        登录后复制
        ,
        DNS2="备用DNS"
        登录后复制
    • DEVICE="ens33"
      登录后复制
      NAME="ens33"
      登录后复制
      :确保这些与你的实际网卡名称匹配。
    • IPV6INIT="yes"
      登录后复制
      :如果你需要IPv6,也确保这个是
      yes
      登录后复制
  • 保存并重启网络服务: 保存文件后,需要重启NetworkManager服务才能让新的配置生效。

    sudo systemctl restart NetworkManager
    登录后复制

    或者如果你想更“暴力”一点,直接重启系统也行,但通常没必要。

2. 使用

nmcli
登录后复制
命令进行持久化配置

NetworkManager是CentOS 7/8/9默认的网络管理工具,

nmcli
登录后复制
是它的命令行接口。通过
nmcli
登录后复制
进行的配置是会被NetworkManager持久保存的。

  • 对于DHCP配置: 如果你的网卡已经有一个连接,你可以修改它为DHCP。

    nmcli connection modify ens33 ipv4.method auto
    nmcli connection modify ens33 ipv6.method auto # 如果需要IPv6
    nmcli connection up ens33 # 激活连接
    登录后复制

    如果还没有连接,可以创建一个:

    nmcli connection add type ethernet ifname ens33 con-name "My_DHCP_Connection" ipv4.method auto
    nmcli connection up "My_DHCP_Connection"
    登录后复制
  • 对于静态IP配置: 同样,可以修改现有连接或创建新连接。

    # 修改现有连接
    nmcli connection modify ens33 ipv4.method manual \
        ipv4.addresses 192.168.1.100/24 \
        ipv4.gateway 192.168.1.1 \
        ipv4.dns "8.8.8.8 114.114.114.114"
    nmcli connection up ens33
    
    # 或者创建新连接
    nmcli connection add type ethernet ifname ens33 con-name "My_Static_Connection" \
        ipv4.method manual \
        ipv4.addresses 192.168.1.100/24 \
        ipv4.gateway 192.168.1.1 \
        ipv4.dns "8.8.8.8 114.114.114.114" \
        autoconnect yes # 设置开机自动连接
    nmcli connection up "My_Static_Connection"
    登录后复制

    autoconnect yes
    登录后复制
    参数在这里非常重要,它确保了连接在系统启动时自动激活,实现了持久化。

我个人觉得,对于新系统或者需要快速配置的场景,

nmcli
登录后复制
显得更现代化和灵活,因为它直接操作NetworkManager的配置,而不需要手动去编辑那些晦涩的配置文件。但了解
ifcfg-
登录后复制
文件依然很有价值,因为很多老旧的教程或特定的部署场景可能还在使用它。选择哪种方式,最终还是看个人习惯和具体需求。

以上就是CentOS命令窗口怎么上网_CentOS命令行网络连接方法教程的详细内容,更多请关注php中文网其它相关文章!

最佳 Windows 性能的顶级免费优化软件
最佳 Windows 性能的顶级免费优化软件

每个人都需要一台速度更快、更稳定的 PC。随着时间的推移,垃圾文件、旧注册表数据和不必要的后台进程会占用资源并降低性能。幸运的是,许多工具可以让 Windows 保持平稳运行。

下载
来源:php中文网
本文内容由网友自发贡献,版权归原作者所有,本站不承担相应法律责任。如您发现有涉嫌抄袭侵权的内容,请联系admin@php.cn
最新问题
开源免费商场系统广告
热门教程
更多>
最新下载
更多>
网站特效
网站源码
网站素材
前端模板
关于我们 免责申明 意见反馈 讲师合作 广告合作 最新更新 English
php中文网:公益在线php培训,帮助PHP学习者快速成长!
关注服务号 技术交流群
PHP中文网订阅号
每天精选资源文章推送
PHP中文网APP
随时随地碎片化学习

Copyright 2014-2025 https://www.php.cn/ All Rights Reserved | php.cn | 湘ICP备2023035733号