172 похожих чатов

Всем привет. Я хочу сделать обертку вокруг стандартной структуры std::io::File,

которая бы могла время от времени заниматься ротацией этого самого файла. У меня получился вот такой код. Собственно, по коду вот такой вопрос: верно ли, что в ф-ции rotate_file (в самом конце) для файла будет вызван drop и старый файл будет закрыт? Я просто не совсем понимаю, как работает drop для полей структур, если этот момент кто-нибудь осветит, буду искренне благодарен )

7 ответов

17 просмотров

Да

Если это просто log-файл. То лучше открывать и закрывать файл лога при каждом выводе строки. Современные ОС достаточно оптимизируют этот момент. Зато это позволит использовать стандартный logrotate, а также такие утилиты как tail.

Denis-Novozhilov Автор вопроса
Alexandr Rudalev
Если это просто log-файл. То лучше открывать и зак...

Насколько я понимаю, это должно привести к принудительному flush на каждую запись, что может замедлить работу (может и не замедлить, конечно 🤪). Суть задумки как раз в том, чтобы через пайп писать в свою утилиту, которая будет заниматься ротацией и не будет терять логи (как это умеет делать logrotate, если не флашить каждую запись принудительно)

Denis Novozhilov
Насколько я понимаю, это должно привести к принуди...

Нормальный способ ротации файла: * создать новую жёсткую ссылку foo_YYYY_MMM_DD_XXXX.log на foo.log, * удалить жёсткую ссылку foo.log Тогда, даже если сейчас foo.log пишется, все данные попадут куда надо. З.Ы.: При условии что ФС знает что такое жёсткие ссылки.

место имение рейверы
Там же будет open file description пересоздаваться

Если дескриптор последний на процесс/дерево процессов

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

Обсуждают сегодня

30500 за редактор? )
Владимир
47
а через ESC-код ?
Alexey Kulakov
29
Чёт не понял, я ж правильной функцией воспользовался чтобы вывести отладочную информацию? но что-то она не ловится
notme
18
Добрый день! Скажите пожалуйста, а какие программы вы бы рекомендовали написать для того, чтобы научиться управлять памятью? Можно написать динамический массив, можно связный ...
Филипп
7
У меня есть функция где происходит это: write_bit(buffer, 1); write_bit(buffer, 0); write_bit(buffer, 1); write_bit(buffer, 1); write_bit(buffer, 1); w...
~
14
Недавно Google Project Zero нашёл багу в SQLite с помощью LLM, о чём достаточно было шумно в определённых интернетах, которые сопровождались рассказами, что скоро всех "ибешни...
Alex Sherbakov
5
Ребят в СИ можно реализовать ООП?
Николай
33
Вот еще странный косяк, подскажите как бороться. Я git clone сделал себе всего embassy и примеры там запускаю. Всё хорошо. Но вот решил в cargo.toml зависимости не как в приме...
Lukutin R2AJP
5
https://github.com/erlang/otp/blob/OTP-27.1/lib/kernel/src/logger_h_common.erl#L174 https://github.com/erlang/otp/blob/OTP-27.1/lib/kernel/src/logger_olp.erl#L76 15 лет назад...
Maksim Lapshin
20
Как передать управляющий символ в открытую через CreateProcess консоль? Собсна, есть процедура: procedure TRedirectThread.WriteData(Data: OEMString); var Written: Cardinal;...
Serjone
6
Карта сайта