Co może zastąpić monitorowanie systemu w górnym panelu Gnome w Unity?

117

Jestem przyzwyczajony do monitorowania systemu w górnym panelu Gnome: procesor, temperatura, sieć, prędkość wentylatora. (patrz zrzut ekranu poniżej)

zrzut ekranu panelu Gnome 2 pokazujący aplety monitora systemu

W Unity górny panel jest zablokowany dla nazwy okna i menu globalnego, więc nie mogę dodawać apletów panelu. Więc moje pytanie brzmi:

Czy istnieje sposób na zastąpienie tego rodzaju monitorowania systemu (zawsze widocznego, zajmującego niewiele miejsca) w Unity?

Tobi
źródło

Odpowiedzi:

44

Znalazłem następujące pytanie i odpowiedź, które rozwiązały problem. Zawiera listę zamienników starych apletów zwanych wskaźnikami aplikacji. Niestety nie wszystkie są jeszcze dostępne dla natty, ale przynajmniej dostałem bardzo podstawowy monitor obciążenia systemu (wskaźnik-sysmonitor) i wskaźnik pogody (wskaźnik-pogoda).

wprowadź opis zdjęcia tutaj

Kliknij przycisk, aby zainstalować:

Zainstaluj za pośrednictwem centrum oprogramowania

Lew
źródło
20

Oto szybki i brudny monitor systemu, który zhakowałem razem z Pythona: pasek menu

Używa „wskaźnika monitorowania systemu” ( tutaj ), aby wywołać skrypt, który napisałem. Aby go użyć:

  1. zainstaluj indicator-sysmonitor. Aby to zrobić, uruchom następujące polecenie:

    sudo apt-add-repository ppa:alexeftimie/ppa && sudo apt-get update && sudo apt-get install indicator-sysmonitor
    
  2. skopiuj poniższy skrypt do pliku o nazwie sysmonitor

  3. uczynić skrypt wykonywalnym ( chmod +x path-to-file)

  4. kliknij wskaźnik i wybierz „Preferencje”. Przykład pokazujący to

  5. wybierz „użyj tego polecenia” i podaj ścieżkę do pliku sysmonitor.

oto kod:

#!/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

EDYCJA: jeśli chcesz użyć pamięci (jak raport „u góry”), dodaj wiersze

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

Jeśli masz wersję psutil w wersji 2.0, możesz uzyskać użycie pamięci zgłoszone przez Monitor systemu GNOME w następującym wierszu:

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

Jeśli masz mało miejsca i wolisz mieć jednostki dla prędkości netto (b, k, M), możesz również użyć tego

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)
krumpelstiltskin
źródło
dzięki James za formatowanie i brakujący krok (apt-add-repository).
krumpelstiltskin
Czy możesz mi powiedzieć, w jaki sposób mogę uzyskać% pamięci RAM zamiast użycia dysku?
Vijay
2
@neo: utwórz funkcję, która analizuje „/ proc / meminfo” podobnie jak „getInOut ()” (pola w meminfo są objaśniające). Następnie wywołaj nową funkcję za pomocą makeSample (). Jeśli jest na to zapotrzebowanie, napiszę i opublikuję kod.
krumpelstiltskin
1
@neo: dodałem do postu wiersze dotyczące wykorzystania pamięci. jeśli chcesz użyć mem, sugeruję usunięcie wszystkich innych wierszy ze skryptu, aby Python nie musiał ich analizować.
krumpelstiltskin
1
Odkryłem to samo i napisałem krótki skrypt Perla, który monitoruje wykorzystanie sieci.
Nathan Osman,
13

Możesz pobrać i zainstalować pakiet oprogramowania ( .deb ) z

https://launchpad.net/indicator-sysmonitor/+download tutaj. Po zainstalowaniu znajdziesz go w Aplikacje> Akcesoria> Sysyem Monitor Indicator i tak będzie wyglądać w Unity; wprowadź opis zdjęcia tutaj

scouser73
źródło
3

Nie ma go w górnym panelu, ale możesz użyć Conky .

Nie używam Conky, ale istnieją pewne smukłe motywy i myślę, że możesz to zrobić zawsze na wierzchu. (Chociaż nie wiem, którą część ekranu warto pokryć ...)

idbrii
źródło
+1 Właśnie do tego używam Conky (jako zamiennik apletu monitora systemu). Jest niezwykle konfigurowalny i prawdopodobnie zajmie trochę pracy, aby uzyskać pożądany efekt. Dla niektórych dobrze wyglądających i interesujących konfiguracji używam jednej z sugestii na webupd8.org
belacqua
-1

Wypróbowałem kilka aplikacji i odkryłem, że ta w KDE jest dla mnie najlepszym narzędziem do monitorowania systemu: ksysguard.

Znajduje się w standardowych repozytoriach Ubuntu, więc wystarczy zainstalować go w Software Center.

Zobacz porównanie na tym zrzucie ekranu. Ile procesor używa Gnome System Monitor w porównaniu z KDE System Monitor (ksysguard)

Jak widać, ksysguard jest znacznie lepszy.

conualfy
źródło
Czy to pasuje do panelu?
Robert Siemer