109人参与 • 2024-08-04 • 设计模式
栏目介绍:“玩转ourbmc”是ourbmc社区开创的知识分享类栏目,主要聚焦于社区和bmc全栈技术相关基础知识的分享,全方位涵盖了从理论原理到实践操作的知识传递。ourbmc社区将通过“玩转ourbmc”栏目,帮助开发者们深入了解到社区文化、理念及特色,增进开发者对bmc全栈技术的理解。
欢迎各位关注“玩转ourbmc”栏目,共同探索ourbmc社区的精彩世界。同时,我们诚挚地邀请各位开发者向“玩转ourbmc”栏目投稿,共同学习进步,将栏目打造成为汇聚智慧、激发创意的知识园地。
网络作为bmc系统中的核心要素之一,其通畅性直接关系到服务器管理人员能否高效地进行远程管理和维护工作。在本期内容中,我们将全面介绍openbmc的网络配置。首先,我们将概述openbmc网络配置的不同方式,随后详细阐述具体的配置方法,旨在为读者提供清晰的指导,帮助他们更好地掌握并应用这些技巧,以提升服务器远程管理的效率。
bmc系统的网络配置涵盖了多个关键要素,包括:ip地址设置、网关与路由配置、静态dns服务器配置、主机名定义以及ntp(network time protocol,网络时间协议)设置等。
网络配置方式根据生效时效可以分为以下两种:
1. 暂时的网络配置:利用ifconfig等命令直接对系统的网络参数进行配置,配置后立即生效。当系统或网络服务被重启后,这些配置将失效,系统恢复到之前的网络配置状态。
2. 永久的网络配置:修改bmc系统内的网络配置文件,不会立即生效,需要重启网络服务或系统后才生效,并且会永久生效。
在bmc网络配置过程中,永久生效的网络配置方法主要涉及三个重要的模块:phosphor-ipmi-host,phosphor-network-manage以及systemd-networkd。下面将分别对这三个模块进行介绍。
phosphor-ipmi-host
phosphor-ipmi-host是bmc固件中的软件包。在bmc中,phosphor-ipmi-host.service在bmc上电后会自动启动,如图 1 所示:
图 1 phosphor-ipmi-host.service
当bmc系统运行后,phosphor-ipmi-host在系统内启动ipmid守护进程,负责响应网络配置相关的ipmi命令。例如:通过transporthandler.cpp 中的getlan() 和setlan()获取和配置网络信息。
lpc(low pin count)是一种用于连接外围设备的接口标准,主要用于服务器bmc与服务器之间进行通信。使用lpc接口,管理人员可在bios/os中通过带内ipmi的方式配置bmc的网络。
通过带外ipmi方式配置bmc网络还涉及phosphor-ipmi-net\@.service,该服务依赖于phosphor-ipmi-host.service。在bmc系统中,phosphor-ipmi-net\@.services启动netipmid守护进程后,通过ipmitool lanplus接口发送的ipmi命令,在bmc端交由netipmid和ipmid处理。需要注意的是每个以太网网络设备都对应各自的服务和套接字,例如,eth0对应的服务名称为phosphor-ipmi-net\@eth0.service,对应的套接字为phosphor-ipmi-net\@eth0.socket。
phosphor-network-manager
phosphor-network-manager是处理bmc网络管理操作的守护进程,当进程启动时,其在系统上创建实现物理链路/虚拟接口的对象。在bmc系统中,该进程由xyz.openbmc_project.network.service启动,后者在bmc上电后会自动启动,如图 2 所示:
图 2 xyz.openbmc_project.network.service
在使用ipmi命令或在bmc web界面上对bmc网络进行配置后,phosphor-network-manager通过ethernet_interface.cpp中的writeconfigurationfile()将对应的配置参数写入网络配置文件,最后自动重启systemd-networkd.service重置网络。因此,这两种方式对bmc的网络进行配置后,配置会立即生效,而且在bmc网络重启或者系统重启后仍然生效。
systemd-networkd
systemd-networkd.service对应的守护进程名为systemd-networkd,守护进程的绝对路径为/lib/systemd/systemd-networkd。配置静态ip,发送dhcp请求等功能均由该进程完成。在bmc中,systemd-networkd.service在bmc上电后会自动启动,如图 3 所示:
图 3 systemd-networkd.service
在bmc系统中,网络设备的配置文件须以 .network 为后缀名,否则将被忽略。以bmc的带外管理网口eth0为例,其配置文件路径为:/etc/systemd/network/00-bmc-eth0.network,具体内容如图 4 所示:
图 4 00-bmc-eth0.network
当人为直接修改网络设备的配置文件后,新的网络配置并不会立即自动生效。为了应用这些更改,需要通过重启systemd-networkd.service服务来重置网络配置,这样修改后的配置文件才会被加载并生效。
在服务器中,利用ipmi命令配置bmc网络,主要有在bios下和在host os下使用ipmi命令进行bmc网络配置两种方式。具体流程如下图 5 所示:
图 5 ipmi命令配置bmc网络
bios下配置bmc网络
该方法需要lpc可用且bios固件支持带内ipmi配置网络。
在无法使用bmc串口且无法获取bmc固件中的默认ip时,如果bmc卡在位且已上电完成,可通过服务器的bios setup界面查看并配置bmc网络。该方法原理是bios与bmc通过ipmi进行通信,需要服务器外接显示器及键鼠进行操作。
以搭载飞腾腾云s5000c的服务器为例,上电后按f2后,选择 “enter setup”,再依次选择 “advanced config”,“bmc information”,“bmc network” 即可配置bmc 网络(eth1普通管理网口)。如图 6 所示:
图 6 bios下配置bmc网络
host os下配置bmc网络
该方法需要lpc可用且host os安装好ipmitool。
在bios下配置bmc网络的方式不需要服务器进入os,如果可进入服务器os,则可以在服务器os下使用ipmitool,通过带内的方式配置bmc网络,省去启动服务器进入bios setup界面寻找网络配置界面的步骤。
常见的带内ipmi配置网络命令如下:
显示bmc的ip地址信息(可使用其它通道号查看设备可使用通道的信息,此处配置通道1,以下命令中的1都是代表配置通道1):
# ipmitool lan print 1
设置bmc的ip地址:
# ipmitool lan set 1 ipaddr 192.168.0.198
设置bmc的子网掩码:
# ipmitool lan set 1 netmask 255.255.255.0
设置 ipmi的网关:
# ipmitool lan set 1 defgw ipaddr 192.168.0.254
按照上述步骤依次执行,最终结果如图 7 所示:
图 7 ipmitool lan print 1
如bmc网络已连通且已知bmc_ip,则可通过带外方式配置网络,在上述命令后加上 “-i lanplus -h bmc_ip -u username -p password -c 17” 即可。带外配置bmc网络的方式不局限于在服务器中使用,其它连通bmc网络且能发送ipmi命令的设备均可使用。
bmcweb配置网络
bmcweb配置网络依赖于phosphor-network-manager和systemd-networkd两个守护进程,本质上使用了d-bus来配置网络。关于d-bus机制,玩转ourbmc第七期有更详细的介绍。
在bmc网络连通的情况下,管理人员可使用bmcweb对网络进行配置。在浏览器输入:https://bmc_ip/#/settings/network,添加静态ipv4地址,如图 8 所示:
图 8 bmcweb添加ipv4地址
在图 8 中点击 “添加” 后,bmc后端会执行如下命令:
busctl call xyz.openbmc_project.network /xyz/openbmc_project/network/eth0 xyz.openbmc_project.network.ip.create ip ssys "xyz.openbmc_project.network.ip.protocol.ipv4" "192.168.20.100" 24 "192.168.20.1"
适用场景
该方法适用于临时配置网络,在bmc重启网络服务或复位后,通过ifconfig配置的网络失效。适用于能够使用bmc的串口的场景。
常见用法
ifconfig 查看active的网卡信息
ifconfig -a 查看所有网卡信息
ifconfig eth_name 查看指定网卡的信息
ifconfig eth_name [up|down] 启用或禁用某个网卡
ifconfig eth_name ip_addr 配置静态ip
openbmc的网络配置对实现高效的服务器远程管理至关重要。通过以上内容,我们可以了解网络配置的基本方式和详细方法,希望可以帮助服务器管理人员建立稳定、可靠的bmc网络,为服务器的远程管理提供有力保障。
欢迎大家关注ourbmc社区,了解更多bmc技术干货。
ourbmc社区官方网站:
https://www.ourbmc.cn/
您想发表意见!!点此发布评论
版权声明:本文内容由互联网用户贡献,该文观点仅代表作者本人。本站仅提供信息存储服务,不拥有所有权,不承担相关法律责任。 如发现本站有涉嫌抄袭侵权/违法违规的内容, 请发送邮件至 2386932994@qq.com 举报,一经查实将立刻删除。
发表评论