Что может заменить системный мониторинг на верхней панели Gnome в Unity?

Эти файлы не важны, если вы не хотите повторно удалять и переустанавливать пакеты, а не загружать их снова.

Введите

sudo apt-get autoclean

, чтобы избавиться от них. [!d2 ]

1
задан 25 October 2014 в 19:48

9 ответов

Я нашел следующий вопрос и ответ, который решил проблему для меня. Он содержит список замен для старых апплетов, называемых индикаторами приложений. К сожалению, не все из них доступны для natty, но, по крайней мере, у меня есть очень простой монитор системной нагрузки (индикатор-sysmonitor) и работает индикатор погоды (индикатор-погода).

Нажмите кнопку для установки:

Какие индикаторы приложений доступны?
43
ответ дан 25 May 2018 в 22:37

Вот быстрый и грязный системный монитор, который я взломал из python:

Он использует «Индикатор системного монитора» (здесь), чтобы вызвать сценарий, который я написал. Чтобы использовать его:

установите indicator-sysmonitor. Для этого запустите следующую команду:
sudo apt-add-repository ppa:alexeftimie/ppa && sudo apt-get update && sudo apt-get install indicator-sysmonitor
скопируйте сценарий ниже в файл с именем sysmonitor, чтобы исполняемый файл сценария (chmod +x path-to-file) щелкнул по индикатору и выберите «Настройки». выберите «использовать эту команду» и укажите путь к файлу sysmonitor.

вот код:

#!/usr/bin/python

import re
import sys
import time
import psutil





#Functions:_    __    __    __    __    __    __    __    __    __    __    __
#__/  \__/  \__/  \__/  \__/  \__/  \__/  \__/  \__/  \__/  \__/  \__/  \__/  \_



#interface |bytes    packets errs drop fifo frame compressed multicast|bytes    packets errs drop fifo colls carrier compressed
net_re = re.compile(r"\s*\S+:\s+(\d+)\s+\d+\s+\d+\s+\d+\s+\d+\s+\d+\s+\d+\s+\d+\s+(\d+)\s+\d+\s+\d+\s+\d+\s+\d+\s+\d+\s+\d+\s+\d+\s+")

def getInOut():
  """
  Get a readout of bytes in and out from /proc/net/dev.
  """

  netfile = "/proc/net/dev"

  try: f = open(netfile)
  except:
    sys.stderr.write("ERROR: can't open "+netfile+".\n")
    sys.exit(2)

  f.readline()    #Burn the top header line.
  f.readline()    #Burn the second header line.

  inb = 0
  outb = 0
  for line in f:
    m = net_re.match(line)
    inb += int(m.group(1))
    outb += int(m.group(2))
  f.close()

  return (inb,outb)



def sampleNet():
  """
  Get a sample of I/O from the network interfaces.
  """
  return makeSample(getInOut)


def makeSample(function):
  inlist = list()
  outlist = list()

  (inbytes, outbytes) = function()
  inlist.append(inbytes)
  outlist.append(outbytes)
  time.sleep(1)

  (inbytes, outbytes) = function()
  inlist.append(inbytes)
  outlist.append(outbytes)

  return (inlist[1] - inlist[0], outlist[1] - outlist[0])



def diskstatWrapper():
  """
  Wrapper for the diskstats_parse function that returns just the in and out.
  """
  ds = diskstats_parse("sda")
  return (ds["sda"]["writes"], ds["sda"]["reads"])



def sampleDisk():
  """
  Get a sample of I/O from the disk.
  """
  return makeSample(diskstatWrapper)





def diskstats_parse(dev=None):
    """
    I found this on stackoverflow.
    (http://stackoverflow.com/questions/3329165/python-library-for-monitoring-proc-diskstats)
    """
    file_path = '/proc/diskstats'
    result = {}

    # ref: http://lxr.osuosl.org/source/Documentation/iostats.txt
    columns_disk = ['m', 'mm', 'dev', 'reads', 'rd_mrg', 'rd_sectors',
                    'ms_reading', 'writes', 'wr_mrg', 'wr_sectors',
                    'ms_writing', 'cur_ios', 'ms_doing_io', 'ms_weighted']

    columns_partition = ['m', 'mm', 'dev', 'reads', 'rd_sectors', 'writes', 'wr_sectors']

    lines = open(file_path, 'r').readlines()
    for line in lines:
        if line == '': continue
        split = line.split()
        if len(split) != len(columns_disk) and len(split) != len(columns_partition):
            # No match
            continue

        data = dict(zip(columns_disk, split))
        if dev != None and dev != data['dev']:
            continue
        for key in data:
            if key != 'dev':
                data[key] = int(data[key])
        result[data['dev']] = data

    return result





#MAIN:    __    __    __    __    __    __    __    __    __    __    __    __
#__/  \__/  \__/  \__/  \__/  \__/  \__/  \__/  \__/  \__/  \__/  \__/  \__/  \_




(indiff, outdiff) = sampleNet()
outstr = ""
outstr += "cpu: "+str(int(psutil.cpu_percent()))+"%\t"
outstr += "net: "+str(indiff/1000)+"|"+str(outdiff/1000)+" K/s\t"

(diskin, diskout) = sampleDisk()
outstr += "disk: "
if(diskin):
  outstr += "+"
else:
  outstr += "o"
outstr += "|"
if(diskout):
  outstr += "+"
else:
  outstr += "o"

print outstr

EDIT: если вы хотите использовать память (в качестве отчета «сверху»), добавьте строки

memperc = int(100*float(psutil.used_phymem())/float(psutil.TOTAL_PHYMEM))
outstr += "mem: "+str(memperc)+"%\t"

If у вас есть версия 2.0 psutil, тогда вы можете получить использование памяти, как сообщается системным монитором GNOME, со следующей строкой:

memperc = int(100*float(psutil.used_phymem()-psutil.cached_phymem())/float(psutil.TOTAL_PHYMEM))

Если у вас мало места, и вы предпочитаете иметь единицы для сети (b, k, M) вы также можете использовать

def withUnit(v):
    if v<1024:
      return "%03d" % v+"b";
    if v<1024**2:
      s= ("%f" % (float(v)/1024))[:3];
      if s[-1]=='.':
         s=s[:-1]
      return s +"k";

    return ("%f" % (float(v)/(1024**2)))[:3] +"M";


(indiff, outdiff) = sampleNet()
outstr = ""
outstr += "c"+ "%02d" % int(psutil.cpu_percent())+" "
outstr += "m"+ "%02d" % int((100*float(psutil.used_phymem())/float(psutil.TOTAL_PHYMEM)))+" "

outstr += "d"+withUnit(indiff)+" u"+withUnit(outdiff)
20
ответ дан 25 May 2018 в 22:37
  • 1
    спасибо Джеймсу за форматирование и отсутствующий шаг (apt-add-repository). – krumpelstiltskin 28 April 2011 в 23:09
  • 2
    Не могли бы вы рассказать мне, как я могу получить RAM% вместо использования диска? – Vijay 3 May 2011 в 21:13
  • 3
    @neo: создать функцию, которая анализирует " / proc / meminfo " подобно тому, как это называется «getInOut ()» (поля в meminfo являются самообучающимися). Затем вызовите новую функцию с помощью makeSample (). Если есть спрос на это, я напишу и отправлю код. – krumpelstiltskin 5 May 2011 в 02:21
  • 4
    @neo: я добавил строки для использования памяти в сообщении. если использование mem - это все, что вам нужно, я предлагаю вам удалить все остальные строки из скрипта, чтобы python не разбирался в них. – krumpelstiltskin 7 May 2011 в 01:19
  • 5
    Я обнаружил то же самое и написал короткий скрипт Perl, который отслеживает использование сети. – Nathan Osman 28 September 2011 в 11:59

Вы можете скачать и установить программный пакет (.deb) из

https://launchpad.net/indicator-sysmonitor/+download здесь. После установки вы найдете его под .deb , и он будет выглядеть так в Unity;

13
ответ дан 25 May 2018 в 22:37

Моя проблема: https://gist.github.com/982939

Снимок экрана:

5
ответ дан 25 May 2018 в 22:37

Есть кто-то, кто работает с аппаратными датчиками для индикатор-апплета. См. Есть ли индикатор температуры оборудования?

4
ответ дан 25 May 2018 в 22:37

Вы можете установить порт монитора системы gnome: https://launchpad.net/~indicator-multiload/+archive/stable-daily

4
ответ дан 25 May 2018 в 22:37

Это не в верхней панели, но вы можете использовать Conky.

Я не использую Conky, но там есть тонкие темы, и я думаю, вы можете сделать это всегда сверху. (Хотя я не знаю, какая часть экрана будет хороша для покрытия ...)

3
ответ дан 25 May 2018 в 22:37
  • 1
    +1 Я использую Conky для этого точно (в качестве замены апплета системного монитора). Он чрезвычайно настраивается, и вполне вероятно, что для получения желаемого результата потребуется определенная работа. Для некоторых красивейших и интересных конфигураций я использовал один из предложенных на webupd8.org – belacqua 15 April 2011 в 08:27

Я думаю, что на этот раз это будет самое близкое. Монитор Cpu

2
ответ дан 25 May 2018 в 22:37

Я попробовал несколько приложений, и я обнаружил, что один из KDE для меня лучший инструмент для системного монитора: ksysguard.

Он находится в стандартных хранилищах Ubuntu, поэтому вы просто установите его в Software Center .

См. сравнение на этом снимке экрана.

Как вы можете видеть, ksysguard намного лучше.

-1
ответ дан 25 May 2018 в 22:37

Другие вопросы по тегам:

Похожие вопросы: