Что имелось:
- Клиент-серверный вариант 1С:Предприятие 8.3 (8.3.9.2033).
- «Управление торговлей», редакция 10.3 (10.3.40.1)
- Рабочая версия рассылки писем с вложениями,всего их 2 суммарным объемом ~1,5-2 мегабайта
Что случилось:
В один прекрасный момент на сервере полностью кончилось место. Анализ диска С привел к тому что в папке UserAppDataTemp повились файлы объем которых превышал 14G:
В отладке поймал момент возникновения этих «папочек»:
Сообщение = Новый ИнтернетПочтовоеСообщение;
Сообщение.ИмяОтправителя = "";
Сообщение.Отправитель = УчетнаяЗаписьПочты.АдресЭлектроннойПочты;
Сообщение.Отправитель.ОтображаемоеИмя = "";
Сообщение.Кодировка = "windows-1251";
Сообщение.Вложения.Очистить();
мВременныеФайлы = Новый Массив;
Если НЕ Вложение = Неопределено Тогда
ФайлВФорматеXLS = ПолучитьИмяВременногоФайла();
мВременныеФайлы.Добавить(ФайлВФорматеXLS);
Вложение.Записать(ФайлВФорматеXLS, ТипФайлаТабличногоДокумента.XLSX);
Сообщение.Вложения.Добавить(ПолучитьДвоичныеДанные(ФайлВФорматеXLS), "Вложение.xlsx");
КонецЕсли;
Сообщение.Получатели.Очистить();
конкретно тут
Сообщение.Вложения.Добавить(ПолучитьДвоичныеДанные(ФайлВФорматеXLS), "Вложение.xlsx");
И что самое интересно, за собой 1С это чистит только после выхода из программы 1С. Долго и безрезультатно искал с чем это связано и можно ли настроить очистку сразу или периодически…
Обратите внимание! Это НЕ временный файл непосредственно вложения. Более того я тоже первый раз подумал на эти файлы, хотя они по массе и не превышают 2 мегабайт и лежат в папке temp. Ниже скриншот сравнения файла вложения, который я делаю для отправки и папки созданной системой.
и ещё содержимое этой папки, я не силен в разметке и прочее, но мне кажется это части письма:
И ещё один скриншот, на котором хорошо видно, что созданный файл вложения имеет маленький размер и хранится отдельно, с возможностью легко удалить его. А «герой» статьи появляется отдельно, в момент когда созданное вложение помещается в письмо.
В итоге написал свою процедуру, которая примерно через равные промежутки времени удаляет эти каталоги.
Процедура ОчисткаКаталогаВременныхФайлов(дВремяНачала = Неопределено, сШаблон = "*.tmp") Экспорт
Если дВремяНачала = Неопределено Тогда
дВремяНачала = Дата(1,1,1)
КонецЕсли;
сКаталог = КаталогВременныхФайлов();
мСодержимое = НайтиФайлы(сКаталог, сШаблон);
Для Каждого элФайл Из мСодержимое Цикл
Если элФайл.ЭтоКаталог() Тогда
дВремяИзменения = элФайл.ПолучитьВремяИзменения();
Если дВремяИзменения >= дВремяНачала Тогда
УдалитьФайлы(элФайл.ПолноеИмя);
КонецЕсли;
КонецЕсли;
КонецЦикла;
КонецПроцедуры
Надеюсь, это кому-нибудь поможет сэкономить время и нервы =)
Документация. хотя и указывает на то, что временные файлы очищаются при рестарте, тем не менее возлагает ответственность за их своевременное удаление на разработчика прикладного решения.
Так что это ошибка.
(0) зачем вы ищете все временные файлы? вы случайно можете удалить файлы с которыми сейчас идёт работа других сеансов.
у вас есть переменная мВременныеФайлы, её и используйте для удаления
(2) Не. Я на другом форуме тоже никак не могу объяснить ) сейчас попробую ещё раз. Мои файлы в мВременныеФайлы хранятся в каталоге Temp непосредственно и весят они не так уж и много на самом деле, файл xlsx не больше 1.5 мегабайт. А вот эти папки создаются «сами» во время
Даже если я укажу
все равно он создаст эти папочки.
По идее Temp располагается в папке Users, т.е. если я это дело повешу на клиенте, то разные пользователи друг другу не помешают точно. В моем конкретном примере я повесил все это дело на сервере. Одновременно 2 рассылки на сервере я не запускаю, не за чем. Поэтому перекрытия не должно быть.
(1) У меня тоже была первая мысль что это ошибка платформы, на ранних версиях это не возникало. Но последнее время все «ошибки» 1с оформляет как фичи =) поэтому сразу решил не ждать, а править как получится.
(4) это ошибка не платформы, а прикладного решения.
(5) Ок.
А как тогда чистить? Может есть какие-то специальные методы, я таких в документации не нашел.
(6) Требуется вызывать метод УдалитьФайлы(ПолноеИмяВременногоФайла) после прекращения работы с файлом. Т.е. «
Чемя тебя породил,темя тебя и убью».Я обычно сразу после отправки удаляю временный файл. При этом не нужно дополнительное регламентное задание для удаления
(7) (8) ещё разок, это не Я «порождаю»,в противном случае у меня была бы ссылка на то что я породил и я бы это удалил. Данные папки создаются системой в момент Сообщение.Вложения.Добавить(…). В комментарии (3) я это попытался расписать. В предыдущих релизах такого не было, видимо если и создавалась папка tmp, она тут же удалялась системой. Блин, видео что ли сделать =) я на мисте это объяснял, не поняли и тут тоже…
(9) Если бы ты в описании обработки добавил, что она создана с целью не трогать конфигурацию, то , возможно, подобных комментариев не появилось. Спасибо за разъяснение.
(9) А покажите код функции ПолучитьДвоичныеДанные().
Поскольку на
никакие папки не создаются.
(11)
ПолучитьДвоичныеДанные (GetBinaryData)
Синтаксис:
ПолучитьДвоичныеДанные()
Возвращаемое значение:
Тип: ДвоичныеДанные.
Описание:
Получает результат чтения в виде двоичных данных.
Доступность:
Тонкий клиент, сервер, толстый клиент, внешнее соединение.
Попробовал ваш вариант, все тоже самое. Думаю что функция и ваш вариант через Конструктор на основании файла работают абсолютно аналогично.
(11) Вы проверяли на платформе (8.3.9.2033) ?
(12) Вы описали метод объекта РезультатЧтенияДанных. Не уверен, что в режиме совместимости, в котором работает УТ 10.3, вообще поддерживается потоковая работа с двоичными данными.
В коде же, приведенном в публикации, вызывается метод глобального либо текущего контекста с названием ПолучитьДвоичныеДанные(), в платформе не существующий. Нажмите правой кнопкой — «перейти к определению».
(14) Антон, это не моя процедура. Я не первый день программирую и это мой код, я помню что писал, а что не писал =). Конкретно эта функция типовая. Кроме того, я попробовал вариант через Конструктор (в публикации есть скриншот с отладкой ровно в этом месте), в плане создания временных файлов ничего не поменялось. Скажите на какой платформе вы пробовали использовать метод Вложения.Добавить(…) и у вас никакие каталоги не создавались?
(15) А чья? Пушкина?
PS Вы же указали в публикации версию платформы. Странно было бы с моей стороны пытаться воспроизводить на другой версии.
(16)
//вспомогательные процедуры и функции
Показать
Даже хз что сказать в свое оправдание… =) Был не прав!
(17) ок, давайте дальше. режим совместимости у конфигурации какой?
(18) Вот на скриншоте.