Форум программистов, компьютерный форум, киберфорум
C/С++ под Linux
Войти
Регистрация
Восстановить пароль
Блоги Сообщество Поиск Заказать работу  
 
 
Рейтинг 4.93/15: Рейтинг темы: голосов - 15, средняя оценка - 4.93
3 / 3 / 0
Регистрация: 22.09.2015
Сообщений: 124

Файловые дескрипторы,а точнее как их побороть

09.06.2016, 08:05. Показов 3380. Ответов 21
Метки нет (Все метки)

Студворк — интернет-сервис помощи студентам
Доброго времени суток
дали задание написать программу которая будет выводить число открытых файловых дескрипторов в системе
программа вроде бы написана но вот незадача она работает только из под рута (что и естественно я ведь лезу вглубь папки proc а доступ туда только rootу и возможен). Но задача сделать так чтобы я смог получить эту информацию без прав root
А как этого сделать ума не приложу.
Собственно надеюсь на светлые умы форума
Может есть какое то место в системе еще кроме proc откуда данную информацию можно достать
C
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
#include <stddef.h>
#include <stdio.h>
#include <stdlib.h>
#include <sys/types.h>
#include <dirent.h>
#include <string.h>
#include <err.h>
#include <unistd.h> 
/*void fd_proc (char* string, char* process)
{
    printf ("PROCCESS       PID       FD\n");
    struct dirent *dp;
    int fd_count=0;
    char buf [64] = "/proc/";
    char line[10];
    FILE *cmd = popen(string, "r");
    fgets(line, 10, cmd);
    pid_t pid = strtoul(line, NULL, 10);
    snprintf(buf, 256, "/proc/%d/fd/", pid);
    DIR  *dir = opendir (buf);
    fd_count=0;
    while ((dp = readdir(dir)) != NULL) 
     {
          fd_count++;
     }
    closedir(dir);
    printf ("%s         %d       %d\n", process, pid, fd_count-2);
    pclose(cmd);
    exit (0);
    }   */
int main (int argc, char* argv[])
{
    system("sudo chmod 777 /proc/*");
    /*if (argc>1)
      {
        char string[64] = "pidof ";
        strcat (string, argv[1]);
        fd_proc (string, argv[1]);
    }*/
    printf ("PID           FD             NAME\n");
    FILE *mf;
    char *estr;char str[50];
    struct dirent *dp;
    struct dirent *dp1;
    char buf [64] = "/proc/";
    int fd_count=0, fd_count_proc=0;
    DIR  *dir = opendir (buf);
    if (dp != NULL)
    {
        while (dp = readdir (dir))
        {
            if ((dp->d_name[0]<='9')&&(dp->d_name[0]>='1'))
            {
                snprintf(buf, 256, "/proc/%s/fd/", dp->d_name);
                DIR  *dir1 = opendir (buf);
                while ((dp1 = readdir(dir1)) != NULL)
                {
                    fd_count_proc++;
                }
                fd_count+=fd_count_proc-2;
                snprintf(buf, 256, "/proc/%s/comm", dp->d_name);
                mf = fopen (buf,"r");
                estr = fgets (str,sizeof(str),mf);
                //printf ("%s \n",str);
                printf ("%s            %d            %s",dp->d_name, fd_count_proc-2, str);
                fd_count_proc=0;
                fclose (mf);
                closedir (dir1);
            }
        }
        printf ("Total FD:       %d\n",fd_count);
        closedir (dir);
        }
    else
    printf ("Couldn't open the directory\n");
    return 0;
}
Добавлено через 17 часов 58 минут
может это через IPC возможно сделать?
0
Лучшие ответы (1)
IT_Exp
Эксперт
34794 / 4073 / 2104
Регистрация: 17.06.2006
Сообщений: 32,602
Блог
09.06.2016, 08:05
Ответы с готовыми решениями:

Файловые дескрипторы
Можно ли проверить, соответствуют ли два файловых дескриптора одному файлу?

Как под Windows прокинуть файловые дескрипторы через os.system или subprocess.Popen ?
Товарищи. Во время портирования софта с юникса под винду возникла проблема... Чтобы я не перепробовал, файловые дескрипторы, открытые...

Что такое дескрипторы? дескрипторы устройсв?
Никак не могу понять и найти нормального определения. Что такое дескрипторы? Что такое дескрипторы устройств? https://prnt.sc/na7b5a...

21
 Аватар для HighPredator
6045 / 2160 / 753
Регистрация: 10.12.2010
Сообщений: 6,005
Записей в блоге: 3
09.06.2016, 08:26
Если я правильно понял ман, то доступ в прок возможно конфигурировать. http://man7.org/linux/man-pages/man5/proc.5.html

Откладывается ли инфа о декскрипторах где-то еще, без понятия.
0
Эксперт NIX
 Аватар для nezabudka
3334 / 752 / 252
Регистрация: 28.06.2015
Сообщений: 1,552
Записей в блоге: 16
09.06.2016, 15:43
C
1
2
3
4
5
6
7
8
#include <stdio.h>
#include <stdlib.h>
 
int main(void)
{
        system("lsof -ap $BASHPID -d 0-5");
        return 0;
}
0
 Аватар для TheAthlete
174 / 170 / 19
Регистрация: 31.08.2010
Сообщений: 575
09.06.2016, 16:12
Можно сделать проще - распарсить вывод команды

$ sysctl -n fs.file-nr
12768 0 787812
Данная команда по порядку он выдает три значения: число открытых в данный момент файлов; число открытых, но не используемых файлов; максимальное число открытых файлов

Добавлено через 5 минут
Если добавить awk, то можно сразу получить число открытых файловый дескрипторов:

$ sysctl -n fs.file-nr | awk '{print $1}'
12768
Добавлено через 10 минут
C
1
2
3
4
5
#include <stdlib.h>
 
int main() {
  return system("sysctl -n fs.file-nr | awk '{print $1}'");
}
0
3 / 3 / 0
Регистрация: 22.09.2015
Сообщений: 124
09.06.2016, 18:32  [ТС]
TheAthlete, в если мне ещё потом может понадобиться для конкретного процесса та же самая история?проблема в том что потом прога зальётся на железку поэтому надо чтобы все работало от обычного пользователя ни каких рутов и паролей надо

Добавлено через 1 час 32 минуты
TheAthlete, на железке нет lsof там busy box стоит а у него обрезанный Линукс
А можно как то sudoers файл исправить программно ??или нет?
0
Жарю без масла
867 / 749 / 225
Регистрация: 13.01.2012
Сообщений: 1,702
09.06.2016, 18:36
/proc/sys/fs/file-nr
0
3 / 3 / 0
Регистрация: 22.09.2015
Сообщений: 124
09.06.2016, 19:19  [ТС]
retmas, ну так это по всем процессам а если мне по одному надо узнать количество дескрипторов?думаю если принимать во внимание железку с урезанным Линукс надо как то переписать sudoers но как не могу понять
0
Жарю без масла
867 / 749 / 225
Регистрация: 13.01.2012
Сообщений: 1,702
09.06.2016, 19:44
sudoers конечно можно изменить, например, так:
user ALL=(root) NOPASSWD: /path/to/program
но лично мне непонятно зачем вот это требование:
Цитата Сообщение от Sibmax1988 Посмотреть сообщение
получить эту информацию без прав root
хотя дело ваше
0
3 / 3 / 0
Регистрация: 22.09.2015
Сообщений: 124
10.06.2016, 09:13  [ТС]
retmas, тут вопрос не в моем желании а вопрос в том что это должно работать на железке и так чтобы не прописывать на ней ничего в ручную
Запустил команду она заработала
Поэтому и вопрос как сделать так чтобы права не мешали

Добавлено через 12 часов 8 минут
И еще один момент который я упустил к сожалению

Есть у нас процесс у процесса есть какие то файловые дескрипторы
А как можно узнать какие именно файлы открыты ??
Т е получается по дескриптору можно узнать имя файла насколько я понимаю
только вот как это сделать?
хотя бы в линуксе а желательно конечно узнать с помощью СИ
0
Жарю без масла
867 / 749 / 225
Регистрация: 13.01.2012
Сообщений: 1,702
10.06.2016, 09:50
Цитата Сообщение от Sibmax1988 Посмотреть сообщение
как сделать так чтобы права не мешали
в любом случае, если нужно выводить инфу о произвольном процессе(в том числе, запущенным от рута), нужны права рута. соответственно, ваша программа должна запускаться с правами рута: ручками с помощью sudo(добавление прав в sudoers см выше), либо кроном, либо как демон инитом и т.п.
Цитата Сообщение от Sibmax1988 Посмотреть сообщение
по дескриптору можно узнать имя файла
lstat+readlink для /proc/pid/fd/*
0
3 / 3 / 0
Регистрация: 22.09.2015
Сообщений: 124
10.06.2016, 10:39  [ТС]
retmas, а команду можно целиком написать для какого нибудь процесса? а то что то не получается получить список фалов открытых а не дескрипторов
0
Жарю без масла
867 / 749 / 225
Регистрация: 13.01.2012
Сообщений: 1,702
10.06.2016, 10:59
как пример, выведет имя файла(девайса) для дескриптора 0 текущего процесса
C
1
2
3
4
5
6
7
8
struct stat sb;
char *name;
ssize_t ret;
lstat("/proc/self/fd/0", &sb);
name = malloc(sb.st_size + 1);
ret = readlink("/proc/self/fd/0", name, sb.st_size + 1);
name[ret] = '\0';
puts(name);
0
3 / 3 / 0
Регистрация: 22.09.2015
Сообщений: 124
10.06.2016, 11:23  [ТС]
retmas, извини просто но правда как то не доходит
можешь например написать тоже самое например для firefox или gedit а то не могу понять
мне надо знать какие именно файлы открыты не дескрипторы и т п
и причем папка self тоже не возьму в толк
0
Жарю без масла
867 / 749 / 225
Регистрация: 13.01.2012
Сообщений: 1,702
10.06.2016, 11:50
вместо self пишешь пид нужного процесса
для каждого файла из папки /proc/[pid]/fd/ делаешь lstat+readlink по образу и подобию коду выше

Добавлено через 1 минуту
/proc/self для текущего процесса значит то же, что /proc/[мой пид]
0
3 / 3 / 0
Регистрация: 22.09.2015
Сообщений: 124
10.06.2016, 13:27  [ТС]
retmas, спасибо да все работает только проблема в том что если взять процесс который запущен не моим пользователем то я получаю дамп памяти что для меня не хорошо т к на железке я не знаю что запустил мой пользователь а что нет.
Суть в чем на железке есть некий процесс который следит за утечками и тп и я должен для этого процесса выводить файловые декрипторы и исходя из них еще и файлы которые он открыл
и если в случае с выводом просто количества дескрипторов получилось обойти права подшаманив sudoers то как тут обойти не понятно
но очевидно что lstat и readlinkне хватат прав
нет мыслей как это можно обойти?

Добавлено через 3 минуты
на данный момент программа вот что представляет из себя
C
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
#include <stddef.h>
#include <stdio.h>
#include <stdlib.h>
#include <sys/types.h>
#include <dirent.h>
#include <string.h>
#include <sys/stat.h>
#include <unistd.h> 
int main (int argc, char* argv[])
{
    struct stat sb;
    char *name;
    char str[128];
    ssize_t ret;
    int fd_count=0;
    char buf [64] ;
    char line[10];
    FILE *cmd = popen("pidof pmchal", "r");
    fgets(line, 10, cmd);
    pclose(cmd);    
    pid_t pid = strtoul(line, NULL, 10);
    sprintf(buf, "sudo ls /proc/%d/fd/", pid);
    cmd= popen(buf, "r");
    printf ("The names of open files: \n");
    while (!feof (cmd))
    {
        fscanf (cmd,"%s", line);
        sprintf(buf, "/proc/%d/fd/%s", pid,line);
        lstat(buf, &sb);
        name = malloc(sb.st_size + 1);
        ret = readlink(buf, name, sb.st_size + 1);
        name[ret] = '\0';
        strcpy (str,name);
        printf ("%s \n", str);
        fd_count++;
        }
    printf ("\nOpen file descriptors:   %d\n", fd_count);
    pclose(cmd);
  return 0;
}
0
Жарю без масла
867 / 749 / 225
Регистрация: 13.01.2012
Сообщений: 1,702
10.06.2016, 14:12
Цитата Сообщение от Sibmax1988 Посмотреть сообщение
если взять процесс который запущен не моим пользователем то я получаю дамп памяти
очевидно же, что и эта программа должна иметь права рута. добавьте ее(как и ту с выводом количества дескрипторов) вашему пользователю в sudoers
0
3 / 3 / 0
Регистрация: 22.09.2015
Сообщений: 124
10.06.2016, 14:16  [ТС]
retmas, я ее не могу добавить
тогда у меня дамп памяти был при вызове из программы команды ls /proc/pid/fd
а теперь дамп возникает при lstat и readlink вы скажете какая разница есть же бинарник его и пропиши в sudoers
но проблема в том что если мне нужно было это сделать у себя на компе то вопроса бы не было а вопрос в том что при залитии программы на железку я заливаю туда не бинарник и тупо код функции как и тысячи других в этой прошивке
поэтому прописать там как в случае с ls я уже не смогу и там я добавлял не саму программу а только ls в sudoers
0
Жарю без масла
867 / 749 / 225
Регистрация: 13.01.2012
Сообщений: 1,702
10.06.2016, 14:25
значит используйте не системные функции, а утилиты readlink (man 1 readlink)

Добавлено через 51 секунду
и их добавляйте в sudoers (как ls)
0
3 / 3 / 0
Регистрация: 22.09.2015
Сообщений: 124
10.06.2016, 14:29  [ТС]
retmas, ну допустим readlink еще можно утилитой заменить а как быть с lstat
0
Жарю без масла
867 / 749 / 225
Регистрация: 13.01.2012
Сообщений: 1,702
10.06.2016, 14:35
курим man 1 stat

Добавлено через 3 минуты
а вообще, я не понял, почему нельзя добавить свою программу?
Цитата Сообщение от Sibmax1988 Посмотреть сообщение
я заливаю туда не бинарник и тупо код функции
тупо код не выполняется. выполняется исполняемый файл. значит ваш код компилится на целевой машинке
1
Надоела реклама? Зарегистрируйтесь и она исчезнет полностью.
BasicMan
Эксперт
29316 / 5623 / 2384
Регистрация: 17.02.2009
Сообщений: 30,364
Блог
10.06.2016, 14:35
Помогаю со студенческими работами здесь

Как найти все дескрипторы окон в системе?
как найти все дескрипторы окон в системе? уже пол часа штурмую гугл - без результатно

V-USB: как удобнее писать дескрипторы HID-устройств
Разрабатываю тут многоточечный датчик температуры, который должен работать по спецификации HID Sensor (в современных операционках умеет...

Как побороть дорвеи
Добрый вечер уважаемые форумчане! Сталкнулся с такой не приятной проблемой как довери, вот уже около месяца от яндекса поступают письма:,...

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

Как побороть событие OnKeyUp
Имеем: Edit1, Edit2, Button1, и нажатие VK_RETURN 1. при Edit1KeyPress - Edit2-&gt;SetFocus(); 2. при Edit2KeyUp -...


Искать еще темы с ответами

Или воспользуйтесь поиском по форуму:
20
Ответ Создать тему
Новые блоги и статьи
Подключение Box2D v3 к SDL3 для Android: физика и отрисовка коллайдеров
8Observer8 29.01.2026
Содержание блога Box2D - это библиотека для 2D физики для анимаций и игр. С её помощью можно определять были ли коллизии между конкретными объектами. Версия v3 была полностью переписана на Си, в. . .
Инструменты COM: Сохранение данный из VARIANT в файл и загрузка из файла в VARIANT
bedvit 28.01.2026
Сохранение базовых типов COM и массивов (одномерных или двухмерных) любой вложенности (деревья) в файл, с возможностью выбора алгоритмов сжатия и шифрования. Часть библиотеки BedvitCOM Использованы. . .
Загрузка PNG с альфа-каналом на SDL3 для Android: с помощью SDL_LoadPNG (без SDL3_image)
8Observer8 28.01.2026
Содержание блога SDL3 имеет собственные средства для загрузки и отображения PNG-файлов с альфа-каналом и базовой работы с ними. В этой инструкции используется функция SDL_LoadPNG(), которая. . .
Загрузка PNG с альфа-каналом на SDL3 для Android: с помощью SDL3_image
8Observer8 27.01.2026
Содержание блога SDL3_image - это библиотека для загрузки и работы с изображениями. Эта пошаговая инструкция покажет, как загрузить и вывести на экран смартфона картинку с альфа-каналом, то есть с. . .
Влияние грибов на сукцессию
anaschu 26.01.2026
Бифуркационные изменения массы гриба происходят тогда, когда мы уменьшаем массу компоста в 10 раз, а скорость прироста биомассы уменьшаем в три раза. Скорость прироста биомассы может уменьшаться за. . .
Воспроизведение звукового файла с помощью SDL3_mixer при касании экрана Android
8Observer8 26.01.2026
Содержание блога SDL3_mixer - это библиотека я для воспроизведения аудио. В отличие от инструкции по добавлению текста код по проигрыванию звука уже содержится в шаблоне примера. Нужно только. . .
Установка Android SDK, NDK, JDK, CMake и т.д.
8Observer8 25.01.2026
Содержание блога Перейдите по ссылке: https:/ / developer. android. com/ studio и в самом низу страницы кликните по архиву "commandlinetools-win-xxxxxx_latest. zip" Извлеките архив и вы увидите. . .
Вывод текста со шрифтом TTF на Android с помощью библиотеки SDL3_ttf
8Observer8 25.01.2026
Содержание блога Если у вас не установлены Android SDK, NDK, JDK, и т. д. то сделайте это по следующей инструкции: Установка Android SDK, NDK, JDK, CMake и т. д. Сборка примера Скачайте. . .
КиберФорум - форум программистов, компьютерный форум, программирование
Powered by vBulletin
Copyright ©2000 - 2026, CyberForum.ru