Как может я видеть, какое приложение и что процессы выполняют недавно после входа в систему с помощью терминальной команды.
Следующий сценарий перечисляет все процессы и разбивает их на приложения и другие процессы .
В качестве определения приложения я практикую, что процесс запускается из файла .desktop
(поскольку практически все приложения представлены файлом .desktop
), и что файл .desktop
отображается в Dash (в файле .desktop
нет строки: NoDisplay = true
).
Предстоящая работа:
Скрипт, как он есть, получает имя процесса приложения из (последний раздел -) команды, найденной в файле рабочего стола, а также из информации, найденной в возможных символических ссылках, на которые она может ссылаться (например, в случае LibreOffice
> имя процесса: soffice .bin
). Однако в некоторых случаях приложение запускается из удаленного сценария, вызываемого из файла .desktop
. В таких случаях процесс не будет распознан как приложение.
Сценарий дает следующий результат:
Processes, related to applications:
PID TTY TIME CMD
1933 ? 00:03:55 firefox
18091 ? 00:00:00 dia
18162 ? 00:00:01 soffice.bin
31167 ? 00:00:06 alarm-clock-app
31174 ? 00:00:09 nautilus
31301 ? 00:00:20 dropbox
31998 ? 00:01:35 idle3
Other processes:
PID TTY TIME CMD
1 ? 00:00:01 init
2 ? 00:00:00 kthreadd
3 ? 00:00:02 ksoftirqd/0
5 ? 00:00:00 kworker/0:0H
7 ? 00:00:15 rcu_sched
8 ? 00:00:08 rcuos/0
и т. Д.
Сценарий
#!/usr/bin/env python3
import os
import subprocess
def createlist_appcommands():
dtfile_dir = "/usr/share/applications"
dtfile_list = [item for item in os.listdir(dtfile_dir) if item.endswith(".desktop")]
commands = []
for item in dtfile_list:
try:
with open(dtfile_dir+"/"+item) as data:
searchlines = data.readlines()
command = [line for line in searchlines if line.startswith("Exec=")
and not "NoDisplay=true\n" in searchlines
][0].replace("Exec=", "").replace("\n", "").split("/")[-1].split(" ")[0]
commands.append(command)
except Exception:
pass
return commands + [trace_symlinks(item) for item in commands if not trace_symlinks(item)== None]
def trace_symlinks(command):
target = subprocess.Popen(["which", command], stdout=subprocess.PIPE)
location = (target.communicate()[0].decode("utf-8")).split("\n")[0]
check_filetype = subprocess.Popen(["file", location], stdout=subprocess.PIPE)
filetype = (check_filetype.communicate()[0].decode("utf-8")).split("\n")[0]
if "symbolic link" in filetype:
return filetype.split("/")[-1].replace("' ", "")
else:
pass
def createlist_runningprocs():
processesb = subprocess.Popen(["ps", "-e"], stdout=subprocess.PIPE)
process_listb = (processesb.communicate()[0].decode("utf-8")).split("\n")
linked_commands = [(item, item[24:]) for item in process_listb][1:]
applist = createlist_appcommands()
print("Processes, related to applications:\n PID TTY"+" "*10+"TIME CMD")
matches = []
for item in applist:
for i in range(0, len(linked_commands)):
if item[:15] in linked_commands[i][1] and len(item[:15])/len(linked_commands[i][1]) > 0.5:
matches.append(i)
matches = sorted(matches)
for i in range(0, len(linked_commands)):
if i in matches:
print(linked_commands[i][0])
print("\nOther processes:\n PID TTY"+" "*10+"TIME CMD")
for i in range(0, len(linked_commands)):
if not i in matches:
print(linked_commands[i][0])
createlist_runningprocs()
Как использовать
Скопируйте скрипт в пустой файл, сохраните его как process.py
, запустите его командой:
python3 /path/to/processes.py
Edit: обновил мой ответ, переписал скрипт.
Улучшения:
(намного) лучшая производительность
сценарий теперь отслеживает и распознает приложения, инициированные через символические ссылки (которые могут иметь другое имя процесса). Хотя исключения всегда возможны, сейчас они должны быть редкими.
Обычно это делает команда ps
.
Если вы наберете man ps
, вы получите руководство для этой команды, и там вы сможете проверить, какой флаг вам понадобится. Например, ps -e
выведет список всех запущенных процессов в системе.
Другая команда - top
, которая покажет активный вид всех запущенных процессов.