<?xml version="1.0" encoding="utf-8" standalone="yes"?><rss version="2.0" xmlns:atom="http://www.w3.org/2005/Atom"><channel><title>Ipmi on Backend Engineering Strategy Tools</title><link>https://backend-engineering-strategy-tools.github.io/site/tags/ipmi/</link><description>Recent content in Ipmi on Backend Engineering Strategy Tools</description><generator>Hugo -- gohugo.io</generator><language>en-us</language><lastBuildDate>Fri, 22 May 2026 00:00:00 +0000</lastBuildDate><atom:link href="https://backend-engineering-strategy-tools.github.io/site/tags/ipmi/index.xml" rel="self" type="application/rss+xml"/><item><title>IPMI</title><link>https://backend-engineering-strategy-tools.github.io/site/public-notes/hardware/out-of-band/ipmi/</link><pubDate>Fri, 22 May 2026 00:00:00 +0000</pubDate><guid>https://backend-engineering-strategy-tools.github.io/site/public-notes/hardware/out-of-band/ipmi/</guid><description>&lt;p&gt;IPMI (Intelligent Platform Management Interface) is a hardware-level management standard built into most server-class hardware. It runs on a dedicated processor on the motherboard — the &lt;strong&gt;BMC (Baseboard Management Controller)&lt;/strong&gt; — independently of the host OS. The BMC has its own NIC, its own firmware, and its own IP address. You can power a server on or off, read sensor data, and access a serial console even if the host is completely dead.&lt;/p&gt;
&lt;p&gt;Current version is IPMI 2.0, which added encryption and stronger authentication over 1.5.&lt;/p&gt;
&lt;hr&gt;
&lt;h2 id="bmc-implementations-by-vendor"&gt;BMC implementations by vendor
&lt;/h2&gt;&lt;p&gt;IPMI is the standard; each vendor ships their own BMC firmware on top of it:&lt;/p&gt;
&lt;table&gt;
 &lt;thead&gt;
 &lt;tr&gt;
 &lt;th&gt;Vendor&lt;/th&gt;
 &lt;th&gt;BMC / OOB product&lt;/th&gt;
 &lt;th&gt;Notes&lt;/th&gt;
 &lt;/tr&gt;
 &lt;/thead&gt;
 &lt;tbody&gt;
 &lt;tr&gt;
 &lt;td&gt;Dell&lt;/td&gt;
 &lt;td&gt;iDRAC (Integrated Dell Remote Access Controller)&lt;/td&gt;
 &lt;td&gt;iDRAC 6/7/8/9; newer versions add Redfish&lt;/td&gt;
 &lt;/tr&gt;
 &lt;tr&gt;
 &lt;td&gt;HP / HPE&lt;/td&gt;
 &lt;td&gt;iLO (Integrated Lights-Out)&lt;/td&gt;
 &lt;td&gt;iLO 2/3/4/5; iLO 4+ adds Redfish&lt;/td&gt;
 &lt;/tr&gt;
 &lt;tr&gt;
 &lt;td&gt;Sun / Oracle&lt;/td&gt;
 &lt;td&gt;ILOM (Integrated Lights-Out Manager)&lt;/td&gt;
 &lt;td&gt;Sun Fire series (X4150, X4450, etc.)&lt;/td&gt;
 &lt;/tr&gt;
 &lt;tr&gt;
 &lt;td&gt;Supermicro&lt;/td&gt;
 &lt;td&gt;IPMI / BMC&lt;/td&gt;
 &lt;td&gt;Web UI + IPMI; newer boards also Redfish&lt;/td&gt;
 &lt;/tr&gt;
 &lt;tr&gt;
 &lt;td&gt;Lenovo / IBM&lt;/td&gt;
 &lt;td&gt;XClarity / IMM&lt;/td&gt;
 &lt;td&gt;IMM2 on older systems&lt;/td&gt;
 &lt;/tr&gt;
 &lt;tr&gt;
 &lt;td&gt;HP BladeSystem&lt;/td&gt;
 &lt;td&gt;Onboard Administrator (OA)&lt;/td&gt;
 &lt;td&gt;Enclosure-level management (C7000, C3000) — separate from individual blade iLO&lt;/td&gt;
 &lt;/tr&gt;
 &lt;/tbody&gt;
&lt;/table&gt;
&lt;p&gt;Most also expose a web UI and some form of virtual KVM (keyboard/video/mouse over network) in addition to IPMI over LAN.&lt;/p&gt;
&lt;hr&gt;
&lt;h2 id="network-setup"&gt;Network setup
&lt;/h2&gt;&lt;p&gt;The BMC NIC is usually shared with a host NIC (shared/failover mode) or dedicated (preferred for management). Configure via BIOS/UEFI or the vendor&amp;rsquo;s setup utility before the OS boots.&lt;/p&gt;
&lt;p&gt;Assign a static IP — a BMC on DHCP is workable but inconvenient. Keep BMCs on a dedicated management VLAN if possible; they have historically had security issues and shouldn&amp;rsquo;t be exposed to general traffic.&lt;/p&gt;
&lt;hr&gt;
&lt;h2 id="ipmitool"&gt;ipmitool
&lt;/h2&gt;&lt;p&gt;The standard CLI for IPMI over LAN. Available in most Linux package repos.&lt;/p&gt;
&lt;div class="highlight"&gt;&lt;pre tabindex="0" style="color:#f8f8f2;background-color:#272822;-moz-tab-size:4;-o-tab-size:4;tab-size:4;-webkit-text-size-adjust:none;"&gt;&lt;code class="language-bash" data-lang="bash"&gt;&lt;span style="display:flex;"&gt;&lt;span&gt;&lt;span style="color:#75715e"&gt;# Power control&lt;/span&gt;
&lt;/span&gt;&lt;/span&gt;&lt;span style="display:flex;"&gt;&lt;span&gt;ipmitool -I lanplus -H &amp;lt;bmc-ip&amp;gt; -U &amp;lt;user&amp;gt; -P &amp;lt;pass&amp;gt; power status
&lt;/span&gt;&lt;/span&gt;&lt;span style="display:flex;"&gt;&lt;span&gt;ipmitool -I lanplus -H &amp;lt;bmc-ip&amp;gt; -U &amp;lt;user&amp;gt; -P &amp;lt;pass&amp;gt; power on
&lt;/span&gt;&lt;/span&gt;&lt;span style="display:flex;"&gt;&lt;span&gt;ipmitool -I lanplus -H &amp;lt;bmc-ip&amp;gt; -U &amp;lt;user&amp;gt; -P &amp;lt;pass&amp;gt; power off
&lt;/span&gt;&lt;/span&gt;&lt;span style="display:flex;"&gt;&lt;span&gt;ipmitool -I lanplus -H &amp;lt;bmc-ip&amp;gt; -U &amp;lt;user&amp;gt; -P &amp;lt;pass&amp;gt; power cycle
&lt;/span&gt;&lt;/span&gt;&lt;span style="display:flex;"&gt;&lt;span&gt;ipmitool -I lanplus -H &amp;lt;bmc-ip&amp;gt; -U &amp;lt;user&amp;gt; -P &amp;lt;pass&amp;gt; power reset
&lt;/span&gt;&lt;/span&gt;&lt;span style="display:flex;"&gt;&lt;span&gt;
&lt;/span&gt;&lt;/span&gt;&lt;span style="display:flex;"&gt;&lt;span&gt;&lt;span style="color:#75715e"&gt;# Sensor readings (temperatures, voltages, fan speeds)&lt;/span&gt;
&lt;/span&gt;&lt;/span&gt;&lt;span style="display:flex;"&gt;&lt;span&gt;ipmitool -I lanplus -H &amp;lt;bmc-ip&amp;gt; -U &amp;lt;user&amp;gt; -P &amp;lt;pass&amp;gt; sensor list
&lt;/span&gt;&lt;/span&gt;&lt;span style="display:flex;"&gt;&lt;span&gt;
&lt;/span&gt;&lt;/span&gt;&lt;span style="display:flex;"&gt;&lt;span&gt;&lt;span style="color:#75715e"&gt;# System Event Log&lt;/span&gt;
&lt;/span&gt;&lt;/span&gt;&lt;span style="display:flex;"&gt;&lt;span&gt;ipmitool -I lanplus -H &amp;lt;bmc-ip&amp;gt; -U &amp;lt;user&amp;gt; -P &amp;lt;pass&amp;gt; sel list
&lt;/span&gt;&lt;/span&gt;&lt;span style="display:flex;"&gt;&lt;span&gt;ipmitool -I lanplus -H &amp;lt;bmc-ip&amp;gt; -U &amp;lt;user&amp;gt; -P &amp;lt;pass&amp;gt; sel clear
&lt;/span&gt;&lt;/span&gt;&lt;span style="display:flex;"&gt;&lt;span&gt;
&lt;/span&gt;&lt;/span&gt;&lt;span style="display:flex;"&gt;&lt;span&gt;&lt;span style="color:#75715e"&gt;# Serial over LAN (SoL) — console access without KVM&lt;/span&gt;
&lt;/span&gt;&lt;/span&gt;&lt;span style="display:flex;"&gt;&lt;span&gt;ipmitool -I lanplus -H &amp;lt;bmc-ip&amp;gt; -U &amp;lt;user&amp;gt; -P &amp;lt;pass&amp;gt; sol activate
&lt;/span&gt;&lt;/span&gt;&lt;span style="display:flex;"&gt;&lt;span&gt;&lt;span style="color:#75715e"&gt;# Exit SoL: ~.&lt;/span&gt;
&lt;/span&gt;&lt;/span&gt;&lt;/code&gt;&lt;/pre&gt;&lt;/div&gt;&lt;p&gt;Use &lt;code&gt;-I lanplus&lt;/code&gt; (IPMI 2.0 with encryption) rather than &lt;code&gt;-I lan&lt;/code&gt; (IPMI 1.5, unencrypted) where supported.&lt;/p&gt;
&lt;hr&gt;
&lt;h2 id="serial-over-lan-sol"&gt;Serial over LAN (SoL)
&lt;/h2&gt;&lt;p&gt;SoL forwards the server&amp;rsquo;s serial port over the IPMI connection — giving you a text console to the host without a KVM or physical access. Requires the host OS to have serial console enabled:&lt;/p&gt;
&lt;div class="highlight"&gt;&lt;pre tabindex="0" style="color:#f8f8f2;background-color:#272822;-moz-tab-size:4;-o-tab-size:4;tab-size:4;-webkit-text-size-adjust:none;"&gt;&lt;code class="language-bash" data-lang="bash"&gt;&lt;span style="display:flex;"&gt;&lt;span&gt;&lt;span style="color:#75715e"&gt;# Add to GRUB_CMDLINE_LINUX in /etc/default/grub&lt;/span&gt;
&lt;/span&gt;&lt;/span&gt;&lt;span style="display:flex;"&gt;&lt;span&gt;console&lt;span style="color:#f92672"&gt;=&lt;/span&gt;tty0 console&lt;span style="color:#f92672"&gt;=&lt;/span&gt;ttyS1,115200n8
&lt;/span&gt;&lt;/span&gt;&lt;span style="display:flex;"&gt;&lt;span&gt;
&lt;/span&gt;&lt;/span&gt;&lt;span style="display:flex;"&gt;&lt;span&gt;&lt;span style="color:#75715e"&gt;# Enable serial getty&lt;/span&gt;
&lt;/span&gt;&lt;/span&gt;&lt;span style="display:flex;"&gt;&lt;span&gt;systemctl enable serial-getty@ttyS1.service
&lt;/span&gt;&lt;/span&gt;&lt;/code&gt;&lt;/pre&gt;&lt;/div&gt;&lt;p&gt;Baud rate must match what&amp;rsquo;s configured in the BIOS/BMC (typically 115200).&lt;/p&gt;
&lt;hr&gt;
&lt;h2 id="security"&gt;Security
&lt;/h2&gt;&lt;p&gt;IPMI has a poor security history:&lt;/p&gt;
&lt;ul&gt;
&lt;li&gt;IPMI 1.5 sends credentials in cleartext&lt;/li&gt;
&lt;li&gt;IPMI 2.0 has had multiple authentication bypass vulnerabilities (RAKP, cipher 0)&lt;/li&gt;
&lt;li&gt;The BMC itself runs independent firmware that may have unpatched CVEs&lt;/li&gt;
&lt;li&gt;Default credentials (&lt;code&gt;admin&lt;/code&gt;/&lt;code&gt;admin&lt;/code&gt;, &lt;code&gt;ADMIN&lt;/code&gt;/&lt;code&gt;ADMIN&lt;/code&gt;) are common and widely known&lt;/li&gt;
&lt;/ul&gt;
&lt;p&gt;Minimum steps:&lt;/p&gt;
&lt;ul&gt;
&lt;li&gt;Change default credentials immediately&lt;/li&gt;
&lt;li&gt;Use IPMI 2.0 (&lt;code&gt;lanplus&lt;/code&gt;) only&lt;/li&gt;
&lt;li&gt;Disable cipher suite 0: &lt;code&gt;ipmitool -I lanplus ... lan set 1 cipher_privs XxxxxxxxxxxxxxxX&lt;/code&gt;&lt;/li&gt;
&lt;li&gt;Isolate BMC network from internet and untrusted hosts — management VLAN with no external exposure&lt;/li&gt;
&lt;li&gt;Keep BMC firmware updated&lt;/li&gt;
&lt;/ul&gt;
&lt;hr&gt;
&lt;h2 id="related"&gt;Related
&lt;/h2&gt;&lt;ul&gt;
&lt;li&gt;&lt;a class="link" href="redfish/" &gt;Redfish&lt;/a&gt; — the modern REST API replacement for IPMI&lt;/li&gt;
&lt;li&gt;&lt;a class="link" href="./" &gt;Out-of-band management overview&lt;/a&gt;&lt;/li&gt;
&lt;li&gt;&lt;a class="link" href="https://backend-engineering-strategy-tools.github.io/site/public-notes/hardware/hardware-provisioning/" &gt;Hardware provisioning&lt;/a&gt; — PXE boot and bare-metal provisioning&lt;/li&gt;
&lt;/ul&gt;</description></item><item><title>Out-of-Band Management</title><link>https://backend-engineering-strategy-tools.github.io/site/public-notes/hardware/out-of-band/</link><pubDate>Fri, 22 May 2026 00:00:00 +0000</pubDate><guid>https://backend-engineering-strategy-tools.github.io/site/public-notes/hardware/out-of-band/</guid><description>&lt;p&gt;Out-of-band (OOB) management means controlling a server independently of its operating system — via a dedicated processor on the motherboard called the &lt;strong&gt;BMC (Baseboard Management Controller)&lt;/strong&gt;. The BMC has its own NIC, its own firmware, and its own IP. You can power a server on, read temperatures, and access a console whether or not the host OS is running, hung, or even installed.&lt;/p&gt;
&lt;p&gt;Used for: bare-metal provisioning, remote recovery, hardware monitoring, firmware updates, automated power management.&lt;/p&gt;
&lt;hr&gt;
&lt;h2 id="standards"&gt;Standards
&lt;/h2&gt;&lt;p&gt;Two main protocols, one old and one new:&lt;/p&gt;
&lt;table&gt;
 &lt;thead&gt;
 &lt;tr&gt;
 &lt;th&gt;&lt;/th&gt;
 &lt;th&gt;IPMI&lt;/th&gt;
 &lt;th&gt;Redfish&lt;/th&gt;
 &lt;/tr&gt;
 &lt;/thead&gt;
 &lt;tbody&gt;
 &lt;tr&gt;
 &lt;td&gt;Protocol&lt;/td&gt;
 &lt;td&gt;Binary, UDP 623&lt;/td&gt;
 &lt;td&gt;HTTPS / JSON (REST)&lt;/td&gt;
 &lt;/tr&gt;
 &lt;tr&gt;
 &lt;td&gt;Era&lt;/td&gt;
 &lt;td&gt;1998–&lt;/td&gt;
 &lt;td&gt;2015–&lt;/td&gt;
 &lt;/tr&gt;
 &lt;tr&gt;
 &lt;td&gt;Scripting&lt;/td&gt;
 &lt;td&gt;ipmitool&lt;/td&gt;
 &lt;td&gt;curl, Python, any HTTP client&lt;/td&gt;
 &lt;/tr&gt;
 &lt;tr&gt;
 &lt;td&gt;Security&lt;/td&gt;
 &lt;td&gt;Weak (known CVEs)&lt;/td&gt;
 &lt;td&gt;TLS + token auth&lt;/td&gt;
 &lt;/tr&gt;
 &lt;tr&gt;
 &lt;td&gt;Availability&lt;/td&gt;
 &lt;td&gt;Universal&lt;/td&gt;
 &lt;td&gt;Modern hardware (roughly post-2015)&lt;/td&gt;
 &lt;/tr&gt;
 &lt;/tbody&gt;
&lt;/table&gt;
&lt;ul&gt;
&lt;li&gt;&lt;a class="link" href="ipmi/" &gt;IPMI&lt;/a&gt; — the established standard; ipmitool, SoL, sensor readings, security considerations&lt;/li&gt;
&lt;li&gt;&lt;a class="link" href="redfish/" &gt;Redfish&lt;/a&gt; — the modern replacement; REST API, curl and Python examples, firmware updates&lt;/li&gt;
&lt;/ul&gt;
&lt;hr&gt;
&lt;h2 id="vendor-implementations"&gt;Vendor implementations
&lt;/h2&gt;&lt;p&gt;Most vendors ship their own BMC firmware on top of these standards:&lt;/p&gt;
&lt;table&gt;
 &lt;thead&gt;
 &lt;tr&gt;
 &lt;th&gt;Vendor&lt;/th&gt;
 &lt;th&gt;Product&lt;/th&gt;
 &lt;th&gt;Supports&lt;/th&gt;
 &lt;/tr&gt;
 &lt;/thead&gt;
 &lt;tbody&gt;
 &lt;tr&gt;
 &lt;td&gt;Dell&lt;/td&gt;
 &lt;td&gt;iDRAC&lt;/td&gt;
 &lt;td&gt;IPMI + Redfish (iDRAC 8+)&lt;/td&gt;
 &lt;/tr&gt;
 &lt;tr&gt;
 &lt;td&gt;HP / HPE&lt;/td&gt;
 &lt;td&gt;iLO&lt;/td&gt;
 &lt;td&gt;IPMI + Redfish (iLO 4+)&lt;/td&gt;
 &lt;/tr&gt;
 &lt;tr&gt;
 &lt;td&gt;Sun / Oracle&lt;/td&gt;
 &lt;td&gt;ILOM&lt;/td&gt;
 &lt;td&gt;IPMI 2.0, web UI&lt;/td&gt;
 &lt;/tr&gt;
 &lt;tr&gt;
 &lt;td&gt;Supermicro&lt;/td&gt;
 &lt;td&gt;BMC&lt;/td&gt;
 &lt;td&gt;IPMI + Redfish (X11+)&lt;/td&gt;
 &lt;/tr&gt;
 &lt;tr&gt;
 &lt;td&gt;Lenovo&lt;/td&gt;
 &lt;td&gt;XClarity / IMM&lt;/td&gt;
 &lt;td&gt;IPMI + Redfish&lt;/td&gt;
 &lt;/tr&gt;
 &lt;tr&gt;
 &lt;td&gt;HP BladeSystem&lt;/td&gt;
 &lt;td&gt;Onboard Administrator&lt;/td&gt;
 &lt;td&gt;Enclosure-level; individual blades use iLO&lt;/td&gt;
 &lt;/tr&gt;
 &lt;/tbody&gt;
&lt;/table&gt;
&lt;hr&gt;
&lt;h2 id="related"&gt;Related
&lt;/h2&gt;&lt;ul&gt;
&lt;li&gt;&lt;a class="link" href="https://backend-engineering-strategy-tools.github.io/site/public-notes/hardware/hardware-provisioning/" &gt;Hardware provisioning&lt;/a&gt; — PXE boot, bare-metal provisioning tools&lt;/li&gt;
&lt;/ul&gt;</description></item></channel></rss>