• 15 апреля стартует «Курс «SQL-injection Master» ©» от команды The Codeby

    За 3 месяца вы пройдете путь от начальных навыков работы с SQL-запросами к базам данных до продвинутых техник. Научитесь находить уязвимости связанные с базами данных, и внедрять произвольный SQL-код в уязвимые приложения.

    На последнюю неделю приходится экзамен, где нужно будет показать свои навыки, взломав ряд уязвимых учебных сайтов, и добыть флаги. Успешно сдавшие экзамен получат сертификат.

    Запись на курс до 25 апреля. Получить промодоступ ...

счетчики производительности

  • Автор темы NetDigger
  • Дата начала
Статус
Закрыто для дальнейших ответов.
N

NetDigger

Здравствуйте, уважаемые!
Возможно ли для отдельного процесса вывести насколько он загружает процессор, сколько байт считал и т.п. информацию, которую возможно извлечь из PDH. Нужно НЕ ДЛЯ МАШИНЫ В ЦЕЛОМ, а ДЛЯ ОТДЕЛЬНО ВЫБРАННОГО ПРОЦЕССА
 
B

Barmutik

А если попробовать для получения времени GetProcessTimes и GetProcessIoCounters для чтения\записи..

Не уверен что абсолютно то что ты искал ..
 
N

NetDigger

Хмм, все облазил - в какой модуль подключать для GetProcessIOCounters?
 
B

Barmutik

А ни в каком ... самому декларить надо...

Да и кстати .. можно обратить внимание ещё на вот эту функцию: NtQuerySystemInformation
 
N

NetDigger

Что-то вообще траблы большие: не могу я ее корректно экспортировать эту GetProccessIO

IO_COUNTERS = ^_IO_COUNTERS;
_IO_COUNTERS = record
ReadOperationCount: int64;
WriteOperationCount: int64;
OtherOperationCount: int64;
ReadTransferCount: int64;
WriteTransferCount: int64;
OtherTransferCount: int64;
End;


var
Form1: TForm1;
function GetProcessIoCounters(hProcess: THandle; PIO_COUNTERS:pointer):Boolean; stdcall; external 'kernel32.dll';

procedure TForm1.Button1Click(Sender: TObject);
Var
PIDArray: array [0..1023] of DWORD;
cb: DWORD;
I: Integer;
ProcCount: Integer;
hProcess: THandle;
M : IO_COUNTERS;
begin
EnumProcesses(@PIDArray, SizeOf(PIDArray), cb);
ProcCount := cb div SizeOf(DWORD);
getMem( m, sizeof(_IO_COUNTERS));
for I := 0 to ProcCount - 1 do
begin
hProcess := OpenProcess(PROCESS_QUERY_INFORMATION or
PROCESS_VM_READ,
False,
PIDArray);
if not(GetProcessIoCounters( hProcess, M)) then Halt;
End;

end;
 
B

Barmutik

А в чём конретно проблема ?

Я взял Ваш код .. с мелкими модификациями у меня всё чудно работает ...

Вот мой пример для текущго процесса:

Код:
var
hProcess: THandle;
M : _IO_COUNTERS;
begin
hProcess := GetCurrentProcess;
if not GetProcessIoCounters( hProcess, @M) then
 ShowMessage('Error')
else
begin
 Caption := IntToStr(M.ReadOperationCount) + ' ' + IntToStr(M.WriteOperationCount) +
  ' ' + IntToStr(M.ReadTransferCount);
end;

Единственное что ...
Код:
function GetProcessIoCounters(hProcess: THandle; PIO_COUNTERS: IO_COUNTERS):Boolean; stdcall; external 'kernel32.dll';

вместо Вашего объявления
Код:
function GetProcessIoCounters(hProcess: THandle; PIO_COUNTERS:pointer):Boolean; stdcall; external 'kernel32.dll';
 
N

NetDigger

Прошу прощения - сказывается то, что уже третьи сутки подряд на ногах...Однако с currentProcess действительно все ок - а с остальным не очень. Разберемся. сенкс
 
Статус
Закрыто для дальнейших ответов.
Мы в соцсетях:

Обучение наступательной кибербезопасности в игровой форме. Начать игру!