CentOS에서 iotop 명령 오류


14

새로 설치된 CentOS 7.5의 터미널에서 sudo iotop(최신 버전 0.6-2.el7)을 사용할 때 다음 오류 메시지가 나타납니다.

Traceback (most recent call last):
  File "/sbin/iotop", line 17, in <module>
    main()
  File "/usr/lib/python2.7/site-packages/iotop/ui.py", line 620, in main
    main_loop()
  File "/usr/lib/python2.7/site-packages/iotop/ui.py", line 610, in <lambda>
    main_loop = lambda: run_iotop(options)
  File "/usr/lib/python2.7/site-packages/iotop/ui.py", line 508, in run_iotop
    return curses.wrapper(run_iotop_window, options)
  File "/usr/lib64/python2.7/curses/wrapper.py", line 43, in wrapper
    return func(stdscr, *args, **kwds)
  File "/usr/lib/python2.7/site-packages/iotop/ui.py", line 501, in run_iotop_window
    ui.run()
  File "/usr/lib/python2.7/site-packages/iotop/ui.py", line 155, in run
    self.process_list.duration)
  File "/usr/lib/python2.7/site-packages/iotop/ui.py", line 434, in refresh_display
    lines = self.get_data()
  File "/usr/lib/python2.7/site-packages/iotop/ui.py", line 415, in get_data
    return list(map(format, processes))
  File "/usr/lib/python2.7/site-packages/iotop/ui.py", line 388, in format
    cmdline = p.get_cmdline()
  File "/usr/lib/python2.7/site-packages/iotop/data.py", line 292, in get_cmdline
    proc_status = parse_proc_pid_status(self.pid)
  File "/usr/lib/python2.7/site-packages/iotop/data.py", line 196, in parse_proc_pid_status
    key, value = line.split(':\t', 1)
ValueError: need more than 1 value to unpack

이 문제를 해결하는 방법에 대한 아이디어가 있습니까?


그것은 나를 위해 작동합니다. uname : Linux 4.4.0-127-generic # 153 ~ 14.04.1- 우분투 아이 오토 버전 : iotop 0.6 Phyton 버전 /usr/bin/python2.7
Marko

답변:


32

분명히 최근 커널 버전 /proc/(pid)/status은 iotop이 기대하지 않는 빈 줄을 도입했습니다 .

CapBnd: 0000001fffffffff
CapAmb: 0000000000000000
Seccomp:    0

SpeculationStoreBypass: vulnerable

수정의 0 번째 근사값으로 루트 ( /usr/lib/python2.7/site-packages/iotop/data.pyca )로 편집 하십시오.

def parse_proc_pid_status(pid):
    result_dict = {}
    try:
        for line in open('/proc/%d/status' % pid):
            if not line.strip(): continue
            key, value = line.split(':\t', 1)
            result_dict[key] = value.strip()
    except IOError:
        pass  # No such process

    return result_dict

if not line.strip(): continue새로운 곳 . 파이썬에는 명시적인 괄호가 없으므로이 줄의 들여 쓰기는 그 아래 줄의 들여 쓰기와 일치해야합니다.

이 버그에 대한 다른 수정 사항 은 https://bugs.launchpad.net/pkg-website/+bug/1773383 도 참조 하십시오 .


1
이 문제를 다루는 CentOS 버그에 대한 링크는 다음과 같습니다. bugs.centos.org/view.php?id=14864
doshea

"Pympler"Python 패키지와 동일합니다. 147 행. if not entry.strip(): continue그 문제를 해결하기 위해 추가하십시오 . pythonhosted.org/Pympler
Eduardo Lucio

2

허용 된 답변을 보완하기 위해 (여백 공백을 허용하지 않으므로 주석으로 추가 할 수 없음)

  1. Python 스크립트의 파일 경로를 검색하십시오.
sudo find ./usr/lib | grep iotop/data.py
  1. sed로 교체
sed -i '1n;/key, value = line/i\            if not line.strip(): continue' <script_path>

처음 실행할 때 모든 것을 확인하고 조심하십시오.

내 시스템의 경우 다음과 같습니다.

sudo sed -i '1n;/key, value = line/i\            if not line.strip(): continue' /usr/lib/python2.7/dist-packages/iotop/data.py
당사 사이트를 사용함과 동시에 당사의 쿠키 정책개인정보 보호정책을 읽고 이해하였음을 인정하는 것으로 간주합니다.
Licensed under cc by-sa 3.0 with attribution required.