使用nameko为Pysnmp get_request创建服务时出错-尝试对ASN.1模式对象执行“ nameko_entrypoints”操作

时间:2019-07-24 12:12:47

标签: python-3.x pysnmp nameko

我是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

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

任何帮助都是有意义的。

预先感谢

1 个答案:

答案 0 :(得分:0)

这与nameko挂钩代码的方式有关...

似乎尝试在其模块中最终可以运行到ASN.1模式对象(是神圣的,不得用于蓝图用途)中的所有对象上查找nameko_entrypoints属性。 / p>

我的建议是将from pysnmp.hlapi import *替换为您在代码中使用的pysnmp类/函数的特定导入。希望这样可以将易碎物品隐藏在nameko的视线范围之外。