Files
dell-fans-controller-docker/start.py
T

90 lines
2.9 KiB
Python
Raw Permalink Normal View History

2024-05-19 22:38:21 +08:00
import os
import time
import traceback
from controller.client import FanController
from controller.logger import logger
# 解析整数环境变量,缺省时使用默认值
def get_int_env(name: str, default: int, min_value: int = 1) -> int:
value = os.getenv(name)
if value is None:
return default
try:
parsed_value = int(value)
except ValueError as exc:
raise RuntimeError(f'{name} 必须是整数') from exc
if parsed_value < min_value:
raise RuntimeError(f'{name} 必须大于等于 {min_value}')
return parsed_value
# 解析布尔环境变量,支持 true/false、1/0、yes/no
def get_bool_env(name: str, default: bool = False) -> bool:
value = os.getenv(name)
if value is None:
return default
normalized_value = value.strip().lower()
if normalized_value in ('1', 'true', 'yes', 'on'):
return True
if normalized_value in ('0', 'false', 'no', 'off'):
return False
raise RuntimeError(f'{name} 必须是布尔值: true/false')
2024-05-19 22:38:21 +08:00
if __name__ == '__main__':
2026-05-06 09:23:26 +08:00
# 从环境变量读取iDRAC连接信息,开源版本不内置任何真实默认凭据
host = os.getenv('HOST')
username = os.getenv('USERNAME')
password = os.getenv('PASSWORD')
2026-05-06 10:04:15 +08:00
# 优先读取新的温控档位变量,并兼容旧别名
fan_speed_steps = os.getenv('FAN_SPEED_STEPS')
if fan_speed_steps is None:
fan_speed_steps = os.getenv('FAN_SPEED_RULES')
control_interval = get_int_env('CONTROL_INTERVAL_SECONDS', 120)
error_interval = get_int_env('ERROR_INTERVAL_SECONDS', control_interval)
ipmi_retry_count = get_int_env('IPMI_RETRY_COUNT', 5)
ipmi_retry_delay = get_int_env('IPMI_RETRY_DELAY_SECONDS', 20)
ipmi_timeout = get_int_env('IPMI_TIMEOUT_SECONDS', 60)
use_raw_fan_duty = get_bool_env('USE_RAW_FAN_DUTY', False)
if not host:
2025-12-02 17:47:51 +08:00
raise RuntimeError('未设置 HOST 环境变量')
2024-05-19 22:38:21 +08:00
if not username:
2025-12-02 17:47:51 +08:00
raise RuntimeError('未设置 USERNAME 环境变量')
2024-05-19 22:38:21 +08:00
if not password:
2025-12-02 17:47:51 +08:00
raise RuntimeError('未设置 PASSWORD 环境变量')
2024-05-19 22:38:21 +08:00
2026-05-06 09:23:26 +08:00
# 复用控制器实例,避免每轮循环丢失上次设置状态
2026-05-06 10:04:15 +08:00
client = FanController(
host=host,
username=username,
password=password,
fan_speed_steps=fan_speed_steps,
ipmi_retry_count=ipmi_retry_count,
ipmi_retry_delay=ipmi_retry_delay,
ipmi_timeout=ipmi_timeout,
use_raw_fan_duty=use_raw_fan_duty,
2026-05-06 10:04:15 +08:00
)
2026-05-06 09:05:53 +08:00
2024-05-19 22:38:21 +08:00
while True:
2025-12-02 17:47:51 +08:00
try:
2026-05-06 09:23:26 +08:00
# 执行一次温度读取和风扇控制周期
2024-05-19 22:38:21 +08:00
client.run()
time.sleep(control_interval)
2024-05-19 22:38:21 +08:00
except Exception as err:
logger.error(
2025-06-08 12:50:52 +08:00
f'运行控制器失败 {err}. {traceback.format_exc()}'
2026-05-06 09:05:53 +08:00
)
2026-05-06 09:23:26 +08:00
# iDRAC会话异常时等待下一轮,避免连续请求压垮IPMI服务
time.sleep(error_interval)