Если при рассылке закончилось место

23.03.17

База данных - Чистка данных

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

Что имелось:

  1. Клиент-серверный вариант 1С:Предприятие 8.3 (8.3.9.2033).
  2. "Управление торговлей", редакция 10.3 (10.3.40.1)
  3. Рабочая версия рассылки писем с вложениями,всего их 2 суммарным объемом ~1,5-2 мегабайта

Что случилось:

В один прекрасный момент на сервере полностью кончилось место. Анализ диска С привел к тому что в папке User\AppData\Temp повились файлы объем которых превышал 14G:

В отладке поймал момент возникновения этих "папочек":

	Сообщение = Новый ИнтернетПочтовоеСообщение;
	Сообщение.ИмяОтправителя = "";
	Сообщение.Отправитель = УчетнаяЗаписьПочты.АдресЭлектроннойПочты;
	Сообщение.Отправитель.ОтображаемоеИмя = "";
	Сообщение.Кодировка = "windows-1251";
			
	Сообщение.Вложения.Очистить();
	
	мВременныеФайлы = Новый Массив;
	Если НЕ Вложение = Неопределено Тогда
		ФайлВФорматеXLS = ПолучитьИмяВременногоФайла();
		мВременныеФайлы.Добавить(ФайлВФорматеXLS);
		Вложение.Записать(ФайлВФорматеXLS, ТипФайлаТабличногоДокумента.XLSX);
		Сообщение.Вложения.Добавить(ПолучитьДвоичныеДанные(ФайлВФорматеXLS), "Вложение.xlsx");
	КонецЕсли;

	Сообщение.Получатели.Очистить();

конкретно тут

Сообщение.Вложения.Добавить(ПолучитьДвоичныеДанные(ФайлВФорматеXLS), "Вложение.xlsx");

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

Обратите внимание! Это НЕ временный файл непосредственно вложения. Более того я тоже первый раз подумал на эти файлы, хотя они по массе и не превышают 2 мегабайт и лежат в папке temp. Ниже скриншот сравнения файла вложения, который я делаю для отправки и папки созданной системой.

и ещё содержимое этой папки, я не силен в разметке и прочее, но мне кажется это части письма:

 И ещё один скриншот, на котором хорошо видно, что созданный файл вложения имеет маленький размер и хранится отдельно, с возможностью легко удалить его. А "герой" статьи появляется отдельно, в момент когда созданное вложение помещается в письмо.

В итоге написал свою процедуру, которая примерно через равные промежутки времени удаляет эти каталоги.

Процедура ОчисткаКаталогаВременныхФайлов(дВремяНачала = Неопределено, сШаблон = "*.tmp") Экспорт
	Если дВремяНачала = Неопределено Тогда 
		дВремяНачала = Дата(1,1,1)
	КонецЕсли;
	сКаталог = КаталогВременныхФайлов();
	мСодержимое = НайтиФайлы(сКаталог, сШаблон);
	Для Каждого элФайл Из мСодержимое Цикл
		Если элФайл.ЭтоКаталог() Тогда
			дВремяИзменения = элФайл.ПолучитьВремяИзменения();	
			Если дВремяИзменения >= дВремяНачала Тогда
				УдалитьФайлы(элФайл.ПолноеИмя);
			КонецЕсли;
		КонецЕсли;
	КонецЦикла;
КонецПроцедуры

Надеюсь, это кому-нибудь поможет сэкономить время и нервы =)

Вступайте в нашу телеграмм-группу Инфостарт

временные файлы почта код

См. также

Инструментарий разработчика Чистка данных Свертка базы Инструменты администратора БД Системный администратор Программист Руководитель проекта 1С v8.3 1С:ERP Управление предприятием 2 1С:Бухгалтерия 3.0 1С:Управление торговлей 11 1С:Комплексная автоматизация 2.х 1С:Управление нашей фирмой 3.0 Россия Платные (руб)

Инструмент представляет собой обработку для проведения свёртки или обрезки баз данных. Работает на ЛЮБЫХ конфигурациях (УТ, БП, ERP, УНФ, КА и т.д.). Поддерживаются серверные и файловые базы, управляемые и обычные формы. Может выполнять свертку одновременно в несколько потоков. А так же автоматически, без непосредственного участия пользователя. Решение в Реестре отечественного ПО

8400 руб.

20.08.2024    39622    217    113    

204

Чистка данных Системный администратор Программист 1С v8.3 Управляемые формы 1C:Бухгалтерия 1С:Бухгалтерия 1.6 1С:Бухгалтерия 3.0 1С:ERP Управление предприятием 2 1С:Зарплата и Управление Персоналом 3.x 1С:Управление нашей фирмой 1.6 1С:Управление нашей фирмой 3.0 1С:Управление торговлей 10 1С:Управление торговлей 11 1С:Розница 2 1С:Розница 3.0 Платные (руб)

Данные обработки помогут Вам легко и, главное быстро, выполнить удаление любых данных в Ваших базах 1С на платформах 8.1-8.3. Обработки помогут легко просмотреть связи ссылок в виде дерева, выбрать что удалять, а что нет, используя любые отборы. Это позволит уменьшить объем лишней и не нужной информации в справочниках и документах, планах видов характеристик и др. объектах и облегчит работу с данными пользователям и Вам. Понятное расположение команд и настроек, в сочетании с описанием и справкой, еще упростят процесс. (Обновление от 27.08.2025, версия 4.4)

10800 руб.

22.02.2013    141995    277    147    

447

Чистка данных Системный администратор Программист 1С v8.3 Управляемые формы 1C:Бухгалтерия 1С:ERP Управление предприятием 2 1С:Бухгалтерия 3.0 1С:Управление торговлей 11 1С:Розница 3.0 Платные (руб)

Позволяет удалить организации из любых из информационных баз 1С на управляемых формах (БП 3.0, УТ 11, КА 2, ERP 2, ЗУП 3.0, УНФ, Розница 2.0 и пр.). Главное требование - программа должна содержать справочник "Организации". Реализован самый быстрый алгоритм непосредственного удаления объектов. Работает даже на базах большого размера. Для ускорения работы алгоритма не запускается проверка контроля ссылочной целостности. Проверку учета можно запустить отдельно с помощью дополнительной обработки. Необходимо перед удалением самостоятельно проверить базу на наличие перекрестных ссылок разных организаций в одном документе. Эту дополнительную обработку проверки перекрестных ссылок по запросу предоставляем бесплатно нашим покупателям.

3582 руб.

16.03.2015    250157    231    83    

266

Чистка данных Программист 1С v8.3 Управляемые формы 1C:Бухгалтерия Платные (руб)

Данные обработки помогут Вам быстро и просто выполнить перезапись любых ссылочных объектов, а также провести/снять с проведения документы с возможностью выбора регистров и произвольными отборами, в Ваших базах 1С на платформах 8.1-8.3. Обработка позволят найти документы с движениями или без них. Все это дает Вам мощный инструмент для работы. Понятное расположение команд и настроек, в сочетании с описанием и справкой, еще упростят процесс. А также обновления Вы получаете бесплатно в течение года с момента приобретения данных обработок! Данные обработки входят в ТОП-100 продаж, что является залогом популярности, надежности в работе, и признанием других покупателей.

7200 руб.

17.09.2013    806185    58    51    

94

Чистка данных Программист Пользователь 1С v8.3 Управляемые формы 1С:Розница 2 1С:Управление нашей фирмой 1.6 1С:ERP Управление предприятием 2 1С:Зарплата и кадры государственного учреждения 3 1С:Бухгалтерия 3.0 1С:Управление торговлей 11 1С:Комплексная автоматизация 2.х 1С:Зарплата и Управление Персоналом 3.x Платные (руб)

Обработка позволяет удобно и выборочно удалить данные из базы 1С на управляемых формах например БП 3.0, УТ 11, КА 2, ERP, УНФ, ЗУП 3, Розница и др. Это могут быть неактуальные организации или другие перечни объектов. При этом есть возможность провести анализ пересечений документов с другими организациями и таким образом уберечься от того, что при удалении обороты по другой организации изменятся. Объекты нужно выбирать вручную и после этого запускать команду удаления. Будут удалены все ссылки на них.

3350 руб.

28.11.2019    28179    75    19    

90

Чистка данных Программист 1С v8.3 1C:Бухгалтерия Платные (руб)

Если в вашей информационной базе крутится очень много данных, или база должна быть доступна 24/7 (как в моем случае), или же вы боитесь запускать тестирование и исправление, НО существует потребность удалить битые ссылки, тогда эта обработка сможет Вам помочь. Обработка выявляет битые ссылки как в самих объектах метаданных, так и в их табличных частях(!), а так же может их удалить.

2400 руб.

23.08.2021    10945    22    3    

28

Чистка данных Системный администратор Программист Бухгалтер Пользователь Управляемые формы 1C:Бухгалтерия Россия Платные (руб)

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

6000 руб.

27.06.2018    19977    16    3    

20

Чистка данных Системный администратор 1С v8.3 1C:Бухгалтерия Россия Платные (руб)

Такое бывает? Удалили документ, а проводки (движения) остались? Эта простая обработка решает данную проблему.. почему по проводкам? да потому что обычно такие вещи замечают именно бухгалтера.на самом же деле данная обработка при нахождении документа удаленного или помеченного на удаление и имеющего движения очищает все движения без исключений.

3000 руб.

06.02.2012    37327    363    30    

32
Комментарии
Подписаться на ответы Инфостарт бот Сортировка: Древо развёрнутое
Свернуть все
1. asved.ru 37 29.03.17 08:29 Сейчас в теме
Документация. хотя и указывает на то, что временные файлы очищаются при рестарте, тем не менее возлагает ответственность за их своевременное удаление на разработчика прикладного решения.
Так что это ошибка.
4. hydro2588_2015 15 30.03.17 06:14 Сейчас в теме
(1) У меня тоже была первая мысль что это ошибка платформы, на ранних версиях это не возникало. Но последнее время все "ошибки" 1с оформляет как фичи =) поэтому сразу решил не ждать, а править как получится.
5. asved.ru 37 30.03.17 10:47 Сейчас в теме
(4) это ошибка не платформы, а прикладного решения.
6. hydro2588_2015 15 30.03.17 11:35 Сейчас в теме
(5) Ок.
возлагает ответственность за их своевременное удаление на разработчика
А как тогда чистить? Может есть какие-то специальные методы, я таких в документации не нашел.
7. asved.ru 37 30.03.17 15:18 Сейчас в теме
(6) Требуется вызывать метод УдалитьФайлы(ПолноеИмяВременногоФайла) после прекращения работы с файлом. Т.е. "Чем я тебя породил, тем я тебя и убью".
9. hydro2588_2015 15 31.03.17 06:15 Сейчас в теме
(7) (8) ещё разок, это не Я "порождаю",в противном случае у меня была бы ссылка на то что я породил и я бы это удалил. Данные папки создаются системой в момент Сообщение.Вложения.Добавить(...). В комментарии (3) я это попытался расписать. В предыдущих релизах такого не было, видимо если и создавалась папка tmp, она тут же удалялась системой. Блин, видео что ли сделать =) я на мисте это объяснял, не поняли и тут тоже...
10. МимохожийОднако 142 31.03.17 09:47 Сейчас в теме
(9) Если бы ты в описании обработки добавил, что она создана с целью не трогать конфигурацию, то , возможно, подобных комментариев не появилось. Спасибо за разъяснение.
11. asved.ru 37 31.03.17 10:25 Сейчас в теме
(9) А покажите код функции ПолучитьДвоичныеДанные().

Поскольку на
		Сообщение.Вложения.Добавить(Новый ДвоичныеДанные(ИмяИсходногоФайла), "Вложение.xlsx");

никакие папки не создаются.
12. hydro2588_2015 15 03.04.17 07:58 Сейчас в теме
(11)
ПолучитьДвоичныеДанные (GetBinaryData)
Синтаксис:

ПолучитьДвоичныеДанные()
Возвращаемое значение:

Тип: ДвоичныеДанные.

Описание:

Получает результат чтения в виде двоичных данных.

Доступность:

Тонкий клиент, сервер, толстый клиент, внешнее соединение.


Попробовал ваш вариант, все тоже самое. Думаю что функция и ваш вариант через Конструктор на основании файла работают абсолютно аналогично.
14. asved.ru 37 03.04.17 11:35 Сейчас в теме
(12) Вы описали метод объекта РезультатЧтенияДанных. Не уверен, что в режиме совместимости, в котором работает УТ 10.3, вообще поддерживается потоковая работа с двоичными данными.

В коде же, приведенном в публикации, вызывается метод глобального либо текущего контекста с названием ПолучитьДвоичныеДанные(), в платформе не существующий. Нажмите правой кнопкой - "перейти к определению".
15. hydro2588_2015 15 03.04.17 11:47 Сейчас в теме
(14) Антон, это не моя процедура. Я не первый день программирую и это мой код, я помню что писал, а что не писал =). Конкретно эта функция типовая. Кроме того, я попробовал вариант через Конструктор (в публикации есть скриншот с отладкой ровно в этом месте), в плане создания временных файлов ничего не поменялось. Скажите на какой платформе вы пробовали использовать метод Вложения.Добавить(...) и у вас никакие каталоги не создавались?
16. asved.ru 37 04.04.17 05:38 Сейчас в теме
(15) А чья? Пушкина?

PS Вы же указали в публикации версию платформы. Странно было бы с моей стороны пытаться воспроизводить на другой версии.
Прикрепленные файлы:
17. hydro2588_2015 15 04.04.17 06:17 Сейчас в теме
(16)
//вспомогательные процедуры и функции
Функция ПолучитьДвоичныеДанные(ИмяФайла)

	Файл = Новый Файл(ИмяФайла);
	
	Если Файл.Существует() Тогда
		Данные = Новый ДвоичныеДанные(ИмяФайла);
		Попытка
			УдалитьФайлы(ИмяФайла);
		Исключение
		КонецПопытки;
		Возврат Данные;
	Иначе
		Возврат Неопределено;
	КонецЕсли; 
	

КонецФункции
Показать


Даже хз что сказать в свое оправдание... =) Был не прав!
18. asved.ru 37 04.04.17 07:52 Сейчас в теме
(17) ок, давайте дальше. режим совместимости у конфигурации какой?
19. hydro2588_2015 15 04.04.17 08:22 Сейчас в теме
(18) Вот на скриншоте.
Прикрепленные файлы:
13. hydro2588_2015 15 03.04.17 09:22 Сейчас в теме
(11) Вы проверяли на платформе (8.3.9.2033) ?
2. kolya_tlt 91 29.03.17 08:50 Сейчас в теме
(0) зачем вы ищете все временные файлы? вы случайно можете удалить файлы с которыми сейчас идёт работа других сеансов.
у вас есть переменная мВременныеФайлы, её и используйте для удаления
3. hydro2588_2015 15 30.03.17 06:11 Сейчас в теме
(2) Не. Я на другом форуме тоже никак не могу объяснить ) сейчас попробую ещё раз. Мои файлы в мВременныеФайлы хранятся в каталоге Temp непосредственно и весят они не так уж и много на самом деле, файл xlsx не больше 1.5 мегабайт. А вот эти папки создаются "сами" во время
Сообщение.Вложения.Добавить(ПолучитьДвоичныеДанные(ФайлВФорматеXLS), "Вложение.xlsx");

Даже если я укажу
Сообщение.Вложения.Добавить(ТабДокДвоичноеПредставление, "Вложение");

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

По идее Temp располагается в папке Users, т.е. если я это дело повешу на клиенте, то разные пользователи друг другу не помешают точно. В моем конкретном примере я повесил все это дело на сервере. Одновременно 2 рассылки на сервере я не запускаю, не за чем. Поэтому перекрытия не должно быть.
8. МимохожийОднако 142 30.03.17 21:57 Сейчас в теме
Я обычно сразу после отправки удаляю временный файл. При этом не нужно дополнительное регламентное задание для удаления
Для отправки сообщения требуется регистрация/авторизация