当前位置: 首页 > article >正文

Ubuntu 中配置静态IP(包含解决每次重启后配置文件失效问题)


Hello! 亲爱的小伙伴们,大家好呀(Smile~)!我是Huazzi,欢迎观看本篇博客,接下来让我们一起来学习一下Ubuntu 中如何配置静态IP吧!祝你有所收获!


提前对Linux有所了解的小伙伴应该知道(没了解过的小伙伴也没关系,继续往下看了就能有所了解了):

在 Linux 操作系统中,Linux 文件系统遵循 FHS (Filesystem Hierarchy Standard),每个目录都有特定的用途,而我们今天的主角/etc 目录主要包含 系统配置文件
想要进一步了解Linux系统各个目录的主要用途的小伙伴,欢迎前往另一篇博客:Linux 文件系统目录结构及其简要介绍


文章目录

    • 操作步骤
      • 前期准备
      • 手动配置静态 IP
        • 报错处理

操作步骤

前期准备

Ubuntu 使用的是 netplan 网络管理工具,所以在正式开始配置静态IP的配置文件前,我们先来检查一下我们/etc/netplan目录下都有哪些东西:
操作命令:

ls /etc/netplan

如果有小伙伴发现有一个50-cloud-init.yaml文件:
在这里插入图片描述
那么就要注意啦!(如果没有的小伙伴可以直接跳过这一步)

这是一个配置文件是 cloud-init 用于配置网络的 YAML 文件:

  • 文件是由 数据源(datasource) 自动生成的,任何更改在重启后将丢失。

在配置静态IP之前,需要先禁用 cloud-init 对网络的配置管理

为什么要禁用 cloud-init?

  • cloud-init 会在系统启动时根据云数据源提供的信息自动配置网络。
  • 如果你手动修改了 /etc/netplan/ 下的网络配置文件,但没有禁用 cloud-init,它可能会在下次重启时重置你的配置。
  • 为了让静态 IP 配置永久生效,禁用 cloud-init 是一个必要步骤

禁用 cloud-init的操作步骤:

  1. 先创建一个禁用网络配置的文件:
   sudo vim /etc/cloud/cloud.cfg.d/99-disable-network-config.cfg
  1. 写入:
network: {config: disabled}
  1. 重启系统:
sudo reboot

注意啦,现在开始正式配置静态IP配置文件~

手动配置静态 IP

我们要将网络配置修改为静态 IP(而不是 DHCP 自动获取),我们需要手动编辑 netplan 配置文件。
操作命令:

sudo vim /etc/netplan/01-netcfg.yaml

dhcp4: true 替换为静态 IP 配置,然后根据自己的需要改一下即可:

network:
    ethernets:
        ens33:
            dhcp4: false
            addresses:
              - 192.168.1.100/24    # 静态 IP 和子网掩码
            gateway4: 192.168.1.1   # 默认网关
            nameservers:
                addresses:
                  - 8.8.8.8         		# DNS 服务器 1
                  - 114.114.114.114         # DNS 服务器 2
    version: 2

应用更改:
保存文件后,执行:

sudo netplan apply

此时网络将切换到静态 IP。


报错处理

这时候,小伙伴们可能会遇到报错:
在这里插入图片描述

这是为什么呢?我们一起来看一下
这些警告信息表示两个问题:

  1. 文件权限过于开放/etc/netplan/01-netcfg.yaml 的权限设置不安全。
  2. gateway4 已被弃用:需要使用默认路由的配置方式。

知道了原因不就好解决了嘛
解决方法:

  1. 修复文件权限过于开放的问题
    Netplan 配置文件的权限要求是 600(仅限 root 读写),当前文件权限可能过于开放。

修改文件权限:

想要进一步了解Linux文件权限相关操作的小伙伴欢迎移步Linux文件权限与所有者管理命令

执行以下命令将权限设置为安全值:

sudo chmod 600 /etc/netplan/01-netcfg.yaml

确认文件权限:

ls -l /etc/netplan/01-netcfg.yaml

输出应类似于:

-rw------- 1 root root 123 Jun 20 03:01 /etc/netplan/01-netcfg.yaml

表明已经修改好了


  1. 替换已弃用的 gateway4
    gateway4 已被弃用,需要使用 默认路由 的配置方式。

修改 /etc/netplan/01-netcfg.yaml 文件
找到 gateway4,并将其替换为默认路由配置:

旧配置:

gateway4: 192.168.1.1

新配置:

routes:
  - to: default
    via: 192.168.1.1

  1. 更新 Netplan 配置
    修改完成后,保存文件并执行以下命令:
sudo netplan apply

  1. 验证配置是否生效
  • 查看 IP 地址和路由信息:

    ip addr
    ip route
    
  • 确保默认路由已生效,输出应类似于:

    default via 192.168.1.1 dev ens33 proto static
    

最后,给个完整示例配置

修改后的 /etc/netplan/01-netcfg.yaml 应类似以下内容:

network:
    version: 2
    ethernets:
        ens33:
            dhcp4: false
            addresses:
              - 192.168.1.100/24   # 静态 IP 和子网掩码
            routes:
              - to: default
                via: 192.168.1.1   # 默认路由
            nameservers:
                addresses:
                  - 8.8.8.8         		# DNS 服务器 1
                  - 114.114.114.114         # DNS 服务器 2

完成后,所有警告都将消失,并且静态 IP 配置将正常生效。


到此,我们的任务就完成啦!
如果小伙伴们还遇到其他的什么问题,欢迎在评论区一起讨论!!!
祝小伙伴们收获满满!!


http://www.kler.cn/a/440673.html

相关文章:

  • 【我的 PWN 学习手札】IO_FILE相关几个基本函数的调用链源码
  • YashanDB共享集群产品能力观测:细节足见功底
  • node(2) - npm run 原理
  • Stable Diffusion模型微调LORA及其变种介绍
  • 一文学会“瑞士军刀“-netcat命令使用
  • 搜维尔科技:虚拟现实喷漆训练解决方案
  • 各个数据库优劣势对比
  • [Unity]Unity跨平台开发之Android入门
  • 机器学习探索之旅:开启智能预测的新篇章!!! 笔记 ! ! !)
  • Stable Diffusion Controlnet常用控制类型解析与实战课程 4
  • 如何使用StableDiffusion对图片进行高清、优化、放大
  • UNIAPP框架uView初步集成与开发设计
  • 【docker】docker swarm常用命令以及电商平台构建案例
  • 基于Docker的Minio分布式集群实践
  • 解决 Ubuntu 20.04 上编译 OpenCV 3.2 时的类型不匹配错误
  • kubeadm_k8s_v1.31高可用部署教程
  • 在window环境下安装openssl生成钥私、证书和签名,nodejs利用express实现ssl的https访问和测试
  • 汽车电子元件的可靠性保障:AEC-Q102认证
  • 数据结构—图
  • python IO编程:StringIO和BytesIO