0

我是 pysnmp 和 nameko 的新手。我一直在分配一项工作,在 nameko 框架中创建一个服务,以使用 pysnmp 库执行 snmp get_request。

以下是我尝试过的代码

from pysnmp.hlapi import *
from nameko.rpc import rpc


class GreetingService(object):
    name = "greeting_service"

    @rpc
    def getFunc(oid):
        errorIndication, errorStatus, errorIndex, varBinds = next(
            getCmd(SnmpEngine(),
                   CommunityData('public', mpModel=0),
                   UdpTransportTarget(('snmp.live.gambitcommunications.com', 161)),
                   ContextData(),
                   ObjectType(ObjectIdentity('SNMPv2-MIB', oid, 0)))
        )

        if errorIndication:
            print(errorIndication)
        elif errorStatus:
            print('%s at %s' % (errorStatus.prettyPrint(),
                                errorIndex and varBinds[int(errorIndex) - 1][0] or '?'))
        else:
            for varBind in varBinds:
                print(' = '.join([x.prettyPrint() for x in varBind]))

    if __name__ == "__main__":
        getFunc('sysName')

当我尝试使用终端使用以下命令启动服务时

$ nameko run helloworld

我收到以下错误消息。


syed@syed-ThinkPad-E480:~/Pysnmp$ nameko run helloworld
Traceback (most recent call last):
  File "/home/syed/.local/bin/nameko", line 11, in <module>
    sys.exit(main())
  File "/home/syed/.local/lib/python3.7/site-packages/nameko/cli/main.py", line 112, in main
    args.main(args)
  File "/home/syed/.local/lib/python3.7/site-packages/nameko/cli/commands.py", line 110, in main
    main(args)
  File "/home/syed/.local/lib/python3.7/site-packages/nameko/cli/run.py", line 181, in main
    import_service(path)
  File "/home/syed/.local/lib/python3.7/site-packages/nameko/cli/run.py", line 71, in import_service
    if inspect.getmembers(potential_service, is_entrypoint):
  File "/usr/lib/python3.7/inspect.py", line 354, in getmembers
    if not predicate or predicate(value):
  File "/home/syed/.local/lib/python3.7/site-packages/nameko/cli/run.py", line 35, in is_entrypoint
    return hasattr(method, ENTRYPOINT_EXTENSIONS_ATTR)
  File "/home/syed/.local/lib/python3.7/site-packages/pyasn1/type/base.py", line 221, in __getattr__
    raise error.PyAsn1Error('Attempted "%s" operation on ASN.1 schema object' % attr)
pyasn1.error.PyAsn1Error: Attempted "nameko_entrypoints" operation on ASN.1 schema object
Error in sys.excepthook:
Traceback (most recent call last):
  File "/usr/lib/python3/dist-packages/apport_python_hook.py", line 63, in apport_excepthook
    from apport.fileutils import likely_packaged, get_recent_crashes
  File "/usr/lib/python3/dist-packages/apport/__init__.py", line 5, in <module>
    from apport.report import Report
  File "/usr/lib/python3/dist-packages/apport/report.py", line 30, in <module>
    import apport.fileutils
  File "/usr/lib/python3/dist-packages/apport/fileutils.py", line 23, in <module>
    from apport.packaging_impl import impl as packaging
  File "/usr/lib/python3/dist-packages/apport/packaging_impl.py", line 24, in <module>
    import apt
  File "/usr/lib/python3/dist-packages/apt/__init__.py", line 23, in <module>
    import apt_pkg
ModuleNotFoundError: No module named 'apt_pkg'

Original exception was:
Traceback (most recent call last):
  File "/home/syed/.local/bin/nameko", line 11, in <module>
    sys.exit(main())
  File "/home/syed/.local/lib/python3.7/site-packages/nameko/cli/main.py", line 112, in main
    args.main(args)
  File "/home/syed/.local/lib/python3.7/site-packages/nameko/cli/commands.py", line 110, in main
    main(args)
  File "/home/syed/.local/lib/python3.7/site-packages/nameko/cli/run.py", line 181, in main
    import_service(path)
  File "/home/syed/.local/lib/python3.7/site-packages/nameko/cli/run.py", line 71, in import_service
    if inspect.getmembers(potential_service, is_entrypoint):
  File "/usr/lib/python3.7/inspect.py", line 354, in getmembers
    if not predicate or predicate(value):
  File "/home/syed/.local/lib/python3.7/site-packages/nameko/cli/run.py", line 35, in is_entrypoint
    return hasattr(method, ENTRYPOINT_EXTENSIONS_ATTR)
  File "/home/syed/.local/lib/python3.7/site-packages/pyasn1/type/base.py", line 221, in __getattr__
    raise error.PyAsn1Error('Attempted "%s" operation on ASN.1 schema object' % attr)
pyasn1.error.PyAsn1Error: Attempted "nameko_entrypoints" operation on ASN.1 schema object

请帮助我了解我尝试过的天气是正确的方法,否则它是错误的。如果是这样,如何纠正错误。

任何帮助都将是可观的。

提前致谢

4

1 回答 1

0

它与 nameko 如何连接您的代码的方式有关......

它似乎尝试nameko_entrypoints在模块中找到的所有对象中查找属性,最终运行到 ASN.1 模式对象(这是神圣的,不应用于蓝图目的以外的任何其他用途)。

我的建议是替换from pysnmp.hlapi import *为您在代码中使用的 pysnmp 类/函数的特定导入。这应该有望将易碎的碎片隐藏在nameko的视线之外。

于 2019-07-25T09:36:24.163 回答