Skip to main content

飞牛fnOS的Python SDK。

Project description

pyfnos

PyPI GitHub

飞牛fnOS的Python SDK。

注意:这个SDK非官方提供。

项目信息

上手

import asyncio
import argparse

def on_message_handler(message):
    """消息回调处理函数"""
    print(f"收到消息: {message}")


async def main():
    # 解析命令行参数
    parser = argparse.ArgumentParser(description='Fnos客户端')
    parser.add_argument('--user', type=str, required=True, help='用户名')
    parser.add_argument('--password', type=str, required=True, help='密码')
    parser.add_argument('-e', '--endpoint', type=str, default='your-custom-endpoint.com:5666', help='服务器地址 (默认: your-custom-endpoint.com:5666)')
    
    args = parser.parse_args()
    
    client = FnosClient()
    
    # 设置消息回调
    client.on_message(on_message_handler)
    
    # 连接到服务器(必须指定endpoint)
    await client.connect(args.endpoint)

    # 登录
    result = await client.login(args.user, args.password)
    print("登录结果:", result)

    # 发送请求
    await client.request_payload("user.info", {})
    print("已发送请求,等待响应...")
    # 等待一段时间以接收响应
    await asyncio.sleep(5)
    
    # 演示重连功能(手动方式)
    await client.close()  # 先关闭连接
    print("连接已关闭,尝试重连...")
    await client.connect(args.endpoint)  # 重新连接(现在会等待连接完成)
    result = await client.login(args.user, args.password)  # 重新登录
    print("重连登录结果:", result)
    
    # 或者使用内置的重连方法(需要先确保连接已断开)
    # await client.reconnect()  # 使用内置重连方法
    
    # 关闭连接
    await client.close()

# 运行异步主函数
if __name__ == "__main__":
    asyncio.run(main())

参考

类名 方法名 简介
FnosClient __init__ 初始化客户端,支持type参数("main"或"timer",默认为"main")
FnosClient connect 连接到WebSocket服务器(必填参数:endpoint)
FnosClient login 用户登录方法
FnosClient get_decrypted_secret 获取解密后的secret
FnosClient on_message 设置消息回调函数
FnosClient request 发送请求
FnosClient request_payload 以payload为主体发送请求
FnosClient request_payload_with_response 以payload为主体发送请求并返回响应
FnosClient reconnect 重新连接到服务器
FnosClient close 关闭WebSocket连接
Store __init__ 初始化Store类
Store general 请求存储通用信息(需要管理员权限,非管理员访问会返回4352错误)
Store calculate_space 计算存储空间信息(需要管理员权限,非管理员访问会返回4352错误)
Store list_disks 列出磁盘信息(支持no_hot_spare参数,需要管理员权限,非管理员访问会返回4352错误)
Store get_disk_smart 获取磁盘SMART信息(支持disk参数,需要管理员权限,非管理员访问会返回4352错误)
Store get_state 获取存储状态信息(支持name和uuid参数,需要管理员权限,非管理员访问会返回4352错误)
ResourceMonitor __init__ 初始化ResourceMonitor类
ResourceMonitor cpu 请求CPU资源监控信息
ResourceMonitor gpu 请求GPU资源监控信息
ResourceMonitor memory 请求内存资源监控信息
ResourceMonitor disk 请求磁盘资源监控信息
ResourceMonitor net 请求网络资源监控信息
ResourceMonitor general 请求通用资源监控信息(支持指定监控项列表,默认为["storeSpeed","netSpeed","cpuBusy","memPercent"])
SAC __init__ 初始化SAC类
SAC ups_status 请求UPS状态信息
SystemInfo __init__ 初始化SystemInfo类
SystemInfo get_host_name 请求主机名信息
SystemInfo get_trim_version 请求Trim版本信息
SystemInfo get_machine_id 请求机器ID信息
SystemInfo get_hardware_info 请求硬件信息
SystemInfo get_uptime 请求系统运行时间信息
User __init__ 初始化User类
User getInfo 获取用户信息
User listUserGroups 请求用户和组列表信息
User groupUsers 请求用户分组信息
User isAdmin 检查当前用户是否为管理员
Network __init__ 初始化Network类
Network list 列出网络信息(支持type参数,可选值为0和1)
Network detect 检测网络接口(支持ifName参数)

命令行参数

示例程序支持以下命令行参数:

  • --user: 用户名(必填)
  • --password: 密码(必填)
  • -e, --endpoint: 服务器地址(可选,默认为 your-custom-endpoint.com:5666)

运行示例

可以使用 uv 工具来运行 examples 目录下的示例程序:

# 基本语法
uv run examples/<示例文件名>.py --user <用户名> --password <密码> [-e <服务器地址>]

# 示例:运行user.py示例
uv run examples/user.py --user myuser --password mypassword -e my-server.com:5666

示例程序说明

下表列出了 examples 目录中各个示例程序的功能说明:

文件名 功能说明
not_connected.py 演示如何捕获和处理NotConnectedError异常来判断是否需要重连
reconnect.py 演示如何使用FnosClient的自动重连功能
resource_monitor.py 演示如何获取系统资源监控信息(CPU、GPU、内存、磁盘、网络)
resource_monitor_general.py 演示如何获取通用资源监控信息(支持指定监控项列表)
sac.py 演示如何获取UPS状态信息
store.py 演示如何获取存储相关信息
system_info.py 演示如何获取系统信息(主机名、版本、硬件等)
user.py 演示User模块的各种功能(获取用户信息、用户组等)
network.py 演示如何获取网络信息(支持type参数,可选值为0和1)和检测网络接口(支持ifName参数)

Project details


Download files

Download the file for your platform. If you're not sure which to choose, learn more about installing packages.

Source Distribution

fnos-0.9.0.tar.gz (17.0 kB view details)

Uploaded Source

Built Distribution

If you're not sure about the file name format, learn more about wheel file names.

fnos-0.9.0-py3-none-any.whl (21.3 kB view details)

Uploaded Python 3

File details

Details for the file fnos-0.9.0.tar.gz.

File metadata

  • Download URL: fnos-0.9.0.tar.gz
  • Upload date:
  • Size: 17.0 kB
  • Tags: Source
  • Uploaded using Trusted Publishing? No
  • Uploaded via: twine/6.2.0 CPython/3.13.2

File hashes

Hashes for fnos-0.9.0.tar.gz
Algorithm Hash digest
SHA256 3976a7170e797a952c851b4012ed5b3b752c42dcfbdb60344e1129d9f15c0f04
MD5 89ee124426fa34ed8e90e756a33ff60d
BLAKE2b-256 7ec9b815b56cf0802ca354815b496b3ea6c1ccef3e74231e6995de1c2d2177d7

See more details on using hashes here.

File details

Details for the file fnos-0.9.0-py3-none-any.whl.

File metadata

  • Download URL: fnos-0.9.0-py3-none-any.whl
  • Upload date:
  • Size: 21.3 kB
  • Tags: Python 3
  • Uploaded using Trusted Publishing? No
  • Uploaded via: twine/6.2.0 CPython/3.13.2

File hashes

Hashes for fnos-0.9.0-py3-none-any.whl
Algorithm Hash digest
SHA256 14b5c7527e31c3309ca740f93d0297c04342de8ff9473eb9b3ee3eb10607853e
MD5 a9bda429c955efa431262f70c102a728
BLAKE2b-256 6b24585b8865fda8abfa62d11c1309a4ee8ebf519f3e46dab761c5ffa4fdc73a

See more details on using hashes here.

Supported by

AWS Cloud computing and Security Sponsor Datadog Monitoring Depot Continuous Integration Fastly CDN Google Download Analytics Pingdom Monitoring Sentry Error logging StatusPage Status page