1с ошибка загрузки информационной базы превышен максимально допустимый размер внутреннего файла

Содержание:

1.       Причины ошибки Превышен размер внутреннего файла

2.       Анализ и возможные варианты решения ошибки Превышен размер внутреннего файла

3.       Проверка настроек подсистем

4.       Способы анализа размеров таблиц базы данных

5.       Варианты решения ошибки Превышен размер внутреннего файла

Ошибка СУБД «Превышен максимально допустимый размер внутреннего файла 1Cv8.1CD» характерная для файловых баз данных 1С, имеющих относительно большой объем данных. В этой статье будут рассмотрены возможные причины возникновения ошибки Превышен размер внутреннего файла в 1С,способы и инструменты для ее исправления.  

1.     Причины ошибки Превышен размер внутреннего файла

Появление ошибки Превышен допустимый размер внутреннего файла возможно как в пользовательском режиме работы (рис. 1), в момент записи данных в базу, так и при попытке загрузить архив базы из dt-файла(рис.2). В обоих случаях в тексте ошибки фигурирует файл 1Cv8.1CD, но причина ошибки не в размере самого файла, а в размерах составляющих его структуру внутренних файлов.

Рис.1. Ошибка в пользовательском режиме работы

Рис.2. Ошибка при загрузке базы из dt-файла

Как Вы можете видеть на выше представленных скринах, размеры файла 1Cv8.1CD в момент возникновения ошибки Превышен максимальный размер внутреннего файла существенно разнятся, т.е. определенного лимита на его объем нет. Этим так же можно объяснить возможность работы баз, размер файла которых может значительно превышать 10 Гбайт. Ограничения есть на размер внутренних файлов1Cv8.1CD. Ознакомится с ними можно в приведенной ниже выдержке из приложения «Особенности работы с различными СУБД» к документации1С:Предприятие. Руководство разработчика.

Структура файловой баз данных

Для понимания структуры файловой базы данных важно знать, что файл базы данных 1Cv8.1CD состоит из множества внутренних файлов. Каждой таблице базы данных соответствует максимум четыре внутренних файла.

Размер каждого из внутренних файлов ограничен:

● для формата версии 8.2.14 ‑ 4 Гигабайта.

● для формата версии 8.3.8 с размером страницы 4 096 байт ‑ 4 Гигабайта.

● для формата версии 8.3.8 с размером страницы 8 192, 16 384, 32 768 и 65 536 байт ‑ 6 Гбайт.  

2.     Анализ и возможные варианты решения ошибки Превышен размер внутреннего файла

Утилита CNVDBFL.EXE 

Начиная с версии 8.3.9в новых информационных базах по умолчанию установлен реализованный в версии 8.3.8 оптимизированный формат файловой СУБД. Проверить какая версия формата используется в вашей базе, можно с помощью утилиты командной строки CNVDBFL.EXE, которая включается в комплект поставки технологической платформы «1С:Предприятие» начиная с версии 8.3.8 и расположена в каталоге «bin» установленной версии(например C:ProgramFiles1cv88.3.18.1334bin).

Рис. 3 Получить информацию о файле 1Cv8.1CD

Выполните команду: C:< путь установки 1С:Предприятие>CNVDBFL.EXE-i<путь к 1CV8.1CD>

Утилита выведет информацию о версии формата файла и размере страницы. Если версия формата ниже8.3.8 или размер страницы равен 4096 байта, то самое простое временное решение, позволяющее быстро восстановить работоспособность, увеличив ограничение на размер внутренних файлов с 4 Гбайт до 6Гбайт – выгрузить информационную базу в dt-файлдля последующей его загрузки в созданную в новой папке информационную базу, либо конвертация в формат 8.3.8 со страницей по умолчанию:

cnvdbfl -c -f 8.3.8 <путь к 1CV8.1CD>

ВНИМАНИЕ! Перед выполнением любых операций с информационной базой сделайте резервную копию.  

3.     Проверка настроек подсистем

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

Настройки подсистемы Работа с файлами

По умолчанию в настройках указано хранение файлов в информационной базе данных, что при активном использовании функционала данной подсистемы (прикрепление скан-копий к первичным документам, хранение файлов договоров и т.д.), приводит к быстрому увеличению размера соответствующей таблицы информационной базы. В данном случае рекомендуется настроить хранение файлов в томах на диске и выполнить перенос файлов, предварительно ознакомившись с соответствующим разделом документации к вашей конфигурации.

Рис.4 Настройки работы с файлами

Настройки хранения истории изменений

Проведите аудит настроек подсистемы хранения истории изменений. Особое внимание следует уделить часто изменяемым объектам с бессрочным хранением версии, т.к. каждая версия – это новая отдельная запись, занимающая место в специальной таблице базы дынных. И точно не стоит включать «на всякий случай» бессрочное сохранение версий, создаваемых при записи, для всех объектов.

    


Рис.5 Настройки хранения истории изменений

Удаление помеченных объектов

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

Рис.6 Настройка расписания удаления помеченных объектов  

4.     Способы анализа размеров таблиц базы данных

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

К сожалению, готовых утилит для анализа размеров таблиц баз данных в комплекте поставки «1С:Предприятие» не предусмотрено. Тем не менее есть несколько способов определить виновника ошибки.

Загрузка dt-файла в клиент-серверную базу данных

Разберем на примере файловой СУБДMSSQL.

В SQL ServerManagementStudio выберем в обозревателе объектов исследуемую базу и сформируем стандартный отчет «Использование дисковой памяти таблицами». Включив сортировку по убыванию значения в колонке «Данные», мы увидим самые большие таблицы. В моем случае явный лидер -«dbo._InfoRg10162»

 

Рис. 7 Анализ размера таблиц базы данныхвSQLServerManagementStudio

Далее нам потребуется определить какие данных хранятся в этой таблице. В этом нам поможет метод глобального контекста ПолучитьСтруктуруХраненияБазыДанных(). Вызвать данный метод можно установив точку остановки в любой процедуре, выполняемой в контексте сервера, например в процедуре ПриСозданииНаСервере формы внешней обработки. Указав в табло выражение ПолучитьСтруктуруХраненияБазыДанных(), мы получим таблицу значений с описаниями структуры таблиц, индексов и полей базы данных. Посмотреть ее можно нажав «F2»,либо выполнив команду контекстного меню «Показать значения в отдельном окне». В открывшемся окне выполняем поиск значения «InfoRg10162» в колонке ИмяТаблицыХранения и определяем по колонкам ИмяТаблицы или Метаданные имя, соответствующее объекту метаданных конфигурации — «РегистрСведений.ДвоичныеДанныеФайлов»

Рис. 8 Просмотр структуры хранения базы данных

Стоит отметить, что данный метод требует серверной лицензии 1С.

На момент написания статьи действует акция: антикризисные льготные поставки «1С:Предприятия 8» для разработчиков.

В качестве СУБД для разработки и тестирования удобно использовать следующие версии:

SQL Server 2019 Express является бесплатным выпуском SQL Server, который идеально подходит для разработки приложений для использования на настольных компьютерах, веб-серверах и других небольших серверах.

SQL Server 2019 Developer — это бесплатный выпуск с полным набором функций, лицензируемый для использования в качестве базы данных для разработки и тестирования и не предназначенный для применения в рабочей среде.

Использование сторонних программ для анализа файла базы

Для определения размеров таблиц базы данных, можно воспользоваться программой для просмотра файлов базы 1Сv8.1CD. Tool_1CD позволяет увидеть структуру БД 1С и узнать размер внутренних таблиц. Tool_1CDверсии 0.3.0, поддерживает работу только с базами в формате не выше 8.2.14.

 

Рис. 9 Tool_1CDверсии 0.3.0

Для анализа базы в формате 8.3.8.0 потребуется конвертация копии базы с помощью утилиты cnvdbfl в версию, совместимую с 8.2 (cnvdbfl -c -f -8.2.14 «путь к базе»)

Tool_1CD версии 0.4.0поддерживает работу с базами версии формата 8.3.8.0 и не требует дополнительных операций с базой.

Рис. 10 Tool_1CDверсии 0.4.0

Определив имя «проблемной» таблицы, далее поступаем аналогично первомупримеру(Рис. 8).Выполняем поиск значения «InfoRg10162″в колонке ИмяТаблицыХранениятаблицы, полученной методом ПолучитьСтруктуруХраненияБазыДанных()и определяем по колонкам ИмяТаблицы или Метаданные имя соответствующее объекту метаданных конфигурации.

Подсистема «Инструменты разработчика» 1С 8

На практике меня часто выручает подсистема «Инструменты разработчика» 1С 8

Это набор мощных инструментов для разработчика на платформе «1С:Предприятия 8», который можно подключить в виде расширения конфигурации.

В рамках рассматриваемой в статье ошибки, нам будет интересна обработка «Структура хранения БД», в которой есть опция получения размеров таблиц и индексов для файловой СУБД.

Рис. 11 Запуск обработки Структура хранения БД в толстом клиенте

Почти все обработки входящие в подсистему выполнены на обычных формах и потому работают только в толстом клиенте и обычном приложении.

Рис. 12 Выбор варианта запуска подсистемы

Рис. 13 Запуск обработки Структура хранения БД в обычном приложении

По умолчанию опция «Показывать размеры» выключена. Включим этот флаг и выполним сортировку по убыванию в колонке «Размер общий»

Рис. 14 Анализ данных в обработке Структура хранения БД

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

Обратите внимание, опция «Показывать размеры» работает только в 32-битныхприложениях

Рис. 15 Настройка разрядности клиента  

5.     Варианты решения ошибки Превышен размер внутреннего файла

Выбор способа решения ошибки Превышен размер внутреннего файла зависит от результатов анализа и сводится к двум вариантам:

·         Уменьшение размера базы данных;

·         Переход на клиент-серверный вариант работы;

Если анализ выявил таблицы, занимающие «львиную долю» от общего размера внутреннего файла 1Cv8.1CD, то в первую очередь надо разобраться с ними. Как правило это объекты конфигурации, имеющие реквизиты с типом значения Хранилище Значения, в которых хранятся связанные файлы, версии объектов, вложения писем и т.д.

В случае, когда в результате анализа обнаружено множество таблиц с размером близким к граничному поможет свертка базы с удалением документов прошлых периодов и выполнение процедуры «Тестирование и исправление» в конфигураторе с включенными опциями реиндексации, реструктуризации и сжатием таблиц, а также с пересчетом итогов.

Если свертка базы не приемлема, то остается только вариант перехода на клиент-серверный вариант работы. В данном варианте ограничения на размер таблиц отсутствуют, а управление информационной базой осуществляется одной из поддерживаемых файловых СУБД.

Взаимодействие между клиентским приложением и файловой СУБД осуществляет кластер серверов «1С:Предприятия 8».

Так же клиент-серверный вариант работы будет решением проблемы при загрузке архива базы из dt-файла

Рис. 16 Загрузка из dt-файла заведомо большой ИБ

Специалист компании «Кодерлайн»

Александр Бачурин

Вопрос  

При попытке отправки  из 1С:Бухгалтерии  ответа на требование ИФНС появилась ошибка «Превышен  максимально допустимый  размер внутреннего файла…», хотя общий размер файлов  вложений в подготовленном ответе не превышает установленного лимита.

Ответ  

Причиной ошибки является то, что в файловой информационной  базе 1С все данные хранятся в одном файле 1Cv8.1CD, который имеет ограничения по объему и структуре.

Как исправить ситуацию?

В этом случае поможет перенос файлов  сервиса 1С-Отчетность и других внешних файлов  из информационной базы во внешнее хранилище (отдельный каталог на диске компьютера).

Итак, для уменьшения размера базы можно выполнить следующие действия:

  1. Настроить  хранение внешних файлов в отдельном хранилище вне программы 1С с сохранением доступа к таким файлам из 1С.

  2. Создать архив файлов 1С-Отчетности  без доступа к нему из 1С.

Рассмотрим подробнее оба способа.

Настроить хранение файлов  во внешнем хранилище с сохранением доступа к ним из 1С.  

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

Для включения настройки перейдите:  Администрирование – Настройки работы с файлами – Включить флаг «Хранить файлы в томах на диске» — Тома хранения файлов — Создать.

Путь к хранилищу файлов должен быть указан в сетевом варианте (с указанием имени компьютера), а сам каталог с хранилищем должен быть доступен пользователям 1С по локальной сети.

По завершению  настройки тома для внешних файлов искомая ошибка с превышением размера файла базы разрешится. Можно отправлять ответ на требование.

Помимо настройки хранения в отдельном каталоге  новых поступающих внешних  файлов,  можно перенести все  старые файлы 1С-Отчетности во внешний каталог с сохранением к нему доступа из базы 1С. Для этого  необходимо выполнить  регламентное задание «Перенос сообщений 1С-Отчетности в присоединенные файлы» (Администрирование – Обслуживание – Регламентные и фоновые задания – Выбрать задание из списка  — Выполнить). За один запуск задание переносит только 10 файлов. Можно  настроить расписание запусков регламентного задания в фоновом режиме, помня, что регламентные задания в файловой информационной базе  выполняются только тогда, когда информационная база запущена в  режиме 1С:Предприятие.

После переноса архивов  необходимо выполнить сжатие и реструктуризацию  таблиц информационной базы  режиме «Конфигуратор» (см. ниже).

Описанный  вариант  не подходит в случае переноса  базы 1С за пределы локальной сети.  

Если по какой-то причине описанные выше действия решить проблему с отправкой ответа на требование 1С не помогли, и ошибка «Превышен максимально допустимый размер внутреннего файла»  осталась, можно попробовать второй способ.

Создать архив файлов 1С-Отчетности  без доступа к нему из 1С.

Перенести хранящиеся в 1С  файлы отчетности  в отдельный архив при помощи специальной  бесплатной обработки от фирмы 1С. Тогда присоединенные файлы 1С-Отчтености  не будут доступны к просмотру  из рабочей программы 1С.

Для подключения обработки  в 1С Бухгалтерии 3.0 перейдите Администрирование – Печатные формы, отчёты и обработки – Дополнительные отчеты и обработки Включите соответствующий флаг и перейдите по одноименной ссылке.

Нажмите Добавить из файла,   согласитесь с предупреждением безопасности.

Запустите обработку  «Создание архива документооборота»

После переноса файлов в тома необходимо выполнить реструктуризацию и сжатие таблиц информационной базы в режиме Конфигуратор  для уменьшения физического размера файла  1Cv8.1CD (Администрирование – Тестирование и исправление —  Включить флаги — Выполнить). Перед тестированием необходимо сохранить резервную копию базы.

После сжатия и реструктуризации база уменьшится, что позволит отправить ответ на требование.  
Дополнительно  смотрите статью на сайте ИТС 
https://its.1c.ru/db/elreps#content:59:1

 

elite128

Заглянувший

Сообщений: 602
Авторитет:

5

Регистрация: 24.09.2012

База УТ+CRM перестала выгружаться в файловый вариант изза ограничения файловой платформы на размер базы
В SQL занимает 3.4 гига, выгрузка 450 мегабайт
Вероятнее всего разрослись таблицы из-за включения версонифицирования обьектов, как могу посмотреть что за таблица разрослась, а также почистить регистры сведений (или не сведений, если виновато не версонифицирование обьекта)?

 

Добрый день!
Передала вопрос разработчикам.

Изменено: Мария Измайлова07.07.2014 16:13:32

 

elite128

Заглянувший

Сообщений: 602
Авторитет:

5

Регистрация: 24.09.2012

Скрин статистики базы

http://joxi.ru/NYm6UxjKTJAkH9KwYNg

 

elite128

Заглянувший

Сообщений: 602
Авторитет:

5

Регистрация: 24.09.2012

файл статистики

Прикрепленные файлы

  • база.xls (3.41 МБ)

 

Мария Измайлова

Посетитель

Сообщений: 1178
Авторитет:

135

Регистрация: 09.11.2012

#5



0


07.07.2014 16:01:01

Цитата
elite128 пишет:
файл статистики

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

Изменено: Мария Измайлова07.07.2014 16:21:41

 

elite128

Заглянувший

Сообщений: 602
Авторитет:

5

Регистрация: 24.09.2012

присоединенные файлы хранятся в томах, неархивированные занимают всего 275 мегабайт

 

elite128

Заглянувший

Сообщений: 602
Авторитет:

5

Регистрация: 24.09.2012

сжал базу на сервере SQL, предварительно переведя режим simple, получил 1.9 гига, все равно файлово не разворачивается

 

Мария Измайлова

Посетитель

Сообщений: 1178
Авторитет:

135

Регистрация: 09.11.2012

#8



0


07.07.2014 16:53:56

Цитата
elite128 пишет:
сжал базу на сервере SQL, предварительно переведя режим simple, получил 1.9 гига, все равно файлово не разворачивается

Что именно пишется при разворачивании файловой базы?

 

elite128

Заглянувший

Сообщений: 602
Авторитет:

5

Регистрация: 24.09.2012

Ошибка загрузки информационной базы. В информационную базу загружены не все данные
по причине:
Ошибка СУБД:
Превышен максимально допустимый размер внутреннего файла ‘D:1C_TestDT/1Cv8.1CD’
по причине:
Превышен максимально допустимый размер внутреннего файла ‘D:1C_TestDT/1Cv8.1CD’

 

elite128

Заглянувший

Сообщений: 602
Авторитет:

5

Регистрация: 24.09.2012

#10



0


07.07.2014 17:05:03

 

#11



0


07.07.2014 17:24:39

Добрый день!
в файловом режиме у платформы ограничение на размер одной таблицы 4Gb. Именно любой таблицы данных, а не всей конфигурации.
99.9% это именно почта.
Возможно вы недавно перешли на хранение в томах, а все старые остались в базе? Ведь при переходе на хранения в томах уже существующие файлы автоматически не переносятся из ИБ в тома.
Просмотрите средствами СУБД или спец. обработкой для 1С — какая таблица самая большая и по ее имени определите что это за таблица.
Во вложении одна из обработок, позволяющих провести анализ (скачена из интернета)

Если дело в размере, то не вы сможете выгрузить в файловую базу, пока не уменьшите размер таблиц(ы)

Изменено: Алексей Полубенский07.07.2014 17:25:29

 

Алексей Полубенский

Посетитель

Сообщений: 1577
Авторитет:

190

Регистрация: 12.02.2010

#12



0


07.07.2014 17:29:18

Цитата
elite128 пишет:
файл статистики

Не заметил этой таблички.
Есть  таблицы размером больше 4Gb?

И еще вопрос — вы провели из 1С «Тестирование и Исправление ИБ » с флагом «Сжатие таблиц информационной базы»? Помимо средств SQL

Изменено: Алексей Полубенский07.07.2014 17:33:30

 

elite128

Заглянувший

Сообщений: 602
Авторитет:

5

Регистрация: 24.09.2012

#13



0


07.07.2014 18:00:53

Почты у нас в базе нет, и надеюсь не будет, во избежании таких вот проблем и роста базы
Файлы изначально были в томах
Сжатие или реиндексация? ) Сжатие не вижу такого флага, реиндексацию и пересчет итогов ставил

 

Мария Измайлова

Посетитель

Сообщений: 1178
Авторитет:

135

Регистрация: 09.11.2012

#14



0


07.07.2014 18:04:10

Цитата
elite128 пишет:
Почты у нас в базе нет, и надеюсь не будет, во избежании таких вот проблем и роста базы
Файлы изначально были в томах
Сжатие или реиндексация? ) Сжатие не вижу такого флага, реиндексацию и пересчет итогов ставил

Администрирование-тестирование и исправление. Сори это скрин файловой базы.

Прикрепленные файлы

Изменено: Мария Измайлова07.07.2014 18:10:40

 

elite128

Заглянувший

Сообщений: 602
Авторитет:

5

Регистрация: 24.09.2012

#15



0


07.07.2014 18:08:47

http://joxi.ru/0Km6UxjKTJAmH0znoqU

платформа 8.3.4.482

 

#16



0


07.07.2014 18:11:40

Да, извините, я смотрел на файловой базе. В клиент-серверном варианте сжатие делается средствами СУБД.
А по приложенной таблице структуры — там нет больших таблиц (>4Gb) или вы ее еще не проанализировали?

Изменено: Алексей Полубенский07.07.2014 18:12:04

 

elite128

Заглянувший

Сообщений: 602
Авторитет:

5

Регистрация: 24.09.2012

#17



0


08.07.2014 10:42:17

Обработка выдает ошибку после выбора таблиц и запуска

{Документ.АктВыполненныхРабот.МодульМенеджера(3010,2)}: Переменная не определена (ОтложенноеОбновлениеИБ)
<<?>>ОтложенноеОбновлениеИБ.ЗаписатьИнформациюОбОтложенномОбновлении(ПараметрыОбработчиков, МоментВремени, «ГраницаАктВыполненныхРаботПроизводственныеЗатраты»);

 

Мария Измайлова

Посетитель

Сообщений: 1178
Авторитет:

135

Регистрация: 09.11.2012

#18



0


08.07.2014 10:51:12

Цитата
elite128 пишет:
Обработка выдает ошибку после выбора таблиц и запуска

{Документ.АктВыполненныхРабот.МодульМенеджера(3010,2)}: Переменная не определена (ОтложенноеОбновлениеИБ)
<<?>>ОтложенноеОбновлениеИБ.ЗаписатьИнформациюОбОтложенномОбновлении(ПараметрыОбработчиков, МоментВремени, «ГраницаАктВыполненныхРаботПроизводственныеЗатраты ­»);

Эту обработку нужно запускать в Толстом клиенте, если все равно будет ошибка, то поищите в интернете подходящую Вам.

Изменено: Мария Измайлова08.07.2014 11:12:04

 

elite128

Заглянувший

Сообщений: 602
Авторитет:

5

Регистрация: 24.09.2012

#19



0


08.07.2014 11:03:13

В толстом выдает другую ошибку )

http://joxi.ru/lZe7U_3JTJAnY6aIWAs

До этого запускал без управляемых форм

У нас версия SQL, вторая обработка для файлового варианта

Изменено: elite12808.07.2014 11:06:04

 

Мария Измайлова

Посетитель

Сообщений: 1178
Авторитет:

135

Регистрация: 09.11.2012

#20



0


08.07.2014 11:07:39

Цитата
elite128 пишет:
В толстом выдает другую ошибку )
http://joxi.ru/lZe7U_3JTJAnY6aIWAs
До этого запускал без управляемых форм

тогда проанализируйте свою таблицу, как Вам и писал Алексей.

 

elite128

Заглянувший

Сообщений: 602
Авторитет:

5

Регистрация: 24.09.2012

#21



0


08.07.2014 11:11:14

И как может быть таблица больше 4 гиг, если база в SQL 1.8 гига?

 

elite128

Заглянувший

Сообщений: 602
Авторитет:

5

Регистрация: 24.09.2012

#22



0


08.07.2014 11:12:08

Обработка Алексея тоже выдает ошибку

{Документ.АктВыполненныхРабот.МодульМенеджера(3010,2)}: Переменная не определена (ОтложенноеОбновлениеИБ)
<<?>>ОтложенноеОбновлениеИБ.ЗаписатьИнформациюОбОтложенномОбновлении(ПараметрыОбработчиков, МоментВремени, «ГраницаАктВыполненныхРаботПроизводственныеЗатраты­»);

 

Алексей Полубенский

Посетитель

Сообщений: 1577
Авторитет:

190

Регистрация: 12.02.2010

#23



0


08.07.2014 11:30:28

Цитата
elite128 пишет:
файл занимает 5.4 гига
Цитата
elite128 пишет:
И как может быть таблица больше 4 гиг, если база в SQL 1.8 гига?

Как то мы запутались…

Цитата
elite128 пишет:
Обработка выдает ошибку после выбора таблиц и запуска

Когда я ее тестировал — она корректно работала, правда я ее запускал на 8.2, а не 8.3.
Вы запустили ее именно в Толстом режиме, а не «в эмуляции» тонкого?

Прикрепленные файлы

 

Алексей Полубенский

Посетитель

Сообщений: 1577
Авторитет:

190

Регистрация: 12.02.2010

#24



0


08.07.2014 11:35:04

Цитата
elite128 пишет:
И как может быть таблица больше 4 гиг, если база в SQL 1.8 гига?

Не знаю… возможно  SQL сжимает так сильно, а при выгрузке/загрузке ИБ данные распаковываются и таблицы становятся намного больше.
Либо у вас какой то сбой в базе, ошибка в параметрах таблиц….
Вы пробовали выгрузить базу, загрузить ее в новую на SQL и уже из новой выгрузить в файловую?

 

elite128

Заглянувший

Сообщений: 602
Авторитет:

5

Регистрация: 24.09.2012

#25



0


08.07.2014 11:40:48

Запускаю в толстом клиенте с параметром /RunModeOrdinaryApplication
Запускается, в выборе версии платформы есть только 8.1 и 8.2, заполняю поля подключения, жму вперед, выбираю таблицы, получаю:

http://joxi.ru/baC7UxjKTJBNH9GtwTk

В новую базу тоже загружал, не помогает

Изменено: elite12808.07.2014 11:41:10

   ALEX7519

17.02.22 — 08:55

Тут да днях случилась такая штука — перестала работать синхронизация Бухгалтерии 30 с ЗУП 30 , т.е из зупа выгрузка проходит, в бух не грузится. Посмотрел по журналу пишет в ошибках Ошибка СУБД Превышен максимально допустимый размер внутреннего файла 1Cv8.1CD. ( синхронизация настроена не через файл а обращением к базе )

посмотрел размер бух базы — около 20 гигов. (базы файловые ).

я так понимаю дело в этом (хотя сама база работает без ошибок, не совсем ясно почему толькро при синхронизации ??? )

надо уменьшать размер базы ?

правильно ли я понимаю последовательность действии : ??

1. Прогнать cd c помощью chdbfl.exe с галкой испралять

2. В конфигуратере через тестирование и исправление с галками сжатие и реструкторизация

если не уменьшится перенести файлы в тома на диске ?

(тут тоже не совсем понял, в настройках работы с файлами надо поставить Хранить файлы «в томах на диске» или «в инф базе и в томах на диске» ? , потом создаю том и через гиперссылку «перенос файло» переношу туда файлы ? после этого они будут открываться у пользователей ?)

посмотрел с помощью CNVDBFL.EXE -i G:1Cv8.1CD структуру файла

формат : 8.3.8

размер страницы : 8192 — это норм ?

   Волшебник

Модератор

1 — 17.02.22 — 08:58

Надо перейти на серверную базу

   Chai Nic

2 — 17.02.22 — 09:04

С учетом «размер страницы : 8192» у вас уже был использован «последний шанс» увеличения размера внутреннего файла с 4 до 6 Гб. Это прибитое гвоздями ограничение, при использовании файловой базы с увеличенным размером страницы. Чтобы покупали серверную лицензию. Вот и покупайте..

   ALEX7519

3 — 17.02.22 — 09:15

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

разве она может влиять на синхронизацию с зуп ?  т.е. уменьшу я сдшник за счет них, но не факт что это поможет ? да?

   Guk

4 — 17.02.22 — 09:20

(3) да…

   Winnie Buh

5 — 17.02.22 — 09:27

(0) 100% вариант — это только переход на SQL

все остальные 50/50

   mistеr

6 — 17.02.22 — 09:33

(1) Или почистить лишнее

   mistеr

7 — 17.02.22 — 09:35

(3) Посмотри с помощью Tool1CD какой файл подошел к 6 Гб. И можно ли его уменьшить.

   ALEX7519

8 — 17.02.22 — 09:54

а как узнать что это за таблица, через тулс1с посмотрел вот эта к примеру : INFORG24411 — что это ?

   Ёпрст

9 — 17.02.22 — 09:55

(8) табличка регистра сведения

   Ёпрст

10 — 17.02.22 — 09:55

   Ёпрст

11 — 17.02.22 — 09:56

Что за рс, можео посмотреть через получитьструктурутаблицхранения блатбла бла, в сп найдешь метод, ну или поделками, коих как грязи на нимфостарте

   mistеr

12 — 17.02.22 — 09:57

(8) Инструменты Разработчика, Структура хранения БД.

   Winnie Buh

13 — 17.02.22 — 10:45

Сервер МИНИ до 5-ти сеансов — 14400 руб.

   ALEX7519

14 — 17.02.22 — 10:56

посмотрел самая большая таблица «РегистрСведений.ВерсииОбъектов»

что это за ? его можно почистить ? 6.5 гигов занял

   rozer76

15 — 17.02.22 — 11:00

(14) конечно, это версионирование БСП. Хотя давно в платформе это нативно есть

   Ёпрст

16 — 17.02.22 — 11:03

(14) да. Просто грохаешь все записи в нём и привет. Оно тебе не нужно.

И в свойствах конфы отключи версионирование совсем. Ну можешь только на значимые доки/справочники оставить

   ALEX7519

17 — 17.02.22 — 11:09

по инету покопался народ пишет обработки оставляет только последние записи и т.п. … это для чего то или можно все сразу грохнуть ?

   Ёпрст

18 — 17.02.22 — 11:10

(17) ну. кто-то видать хоть иногда смотрит версии объектов, и оставляют последние, для истории.

   mistеr

19 — 17.02.22 — 11:11

(17) Если до сих пор не понадобилось, значит можно грохнуть. Если вдруг понадобится, есть же бэкапы. (Они же есть, да?)

   Ёпрст

20 — 17.02.22 — 11:16

И..лучше насовсем версионирование отключи в константах. Быстрее будут доки проводится/записываться.

Один хрен, не используете

   Dmitrii

21 — 17.02.22 — 11:31

Забавно. А с чего все взяли, что версионирование не используется? Может там бухи регулярно проверяют — кто, что и когда поменял в базе.

Сначала надо у пользователей спросить. Если опрос покажет, что никто не знает о чём идёт речь (такое вполне возможно), то можно смело грохать.

Но если выяснится, что всё таки кому-то нужно версионирование, то придётся настроить регулярную очистку старых версий объектов. И возможно отключить версионирование у некоторых объектов, оставив только у самых важных.

   ALEX7519

22 — 17.02.22 — 11:39

В базе в администрировании не стоит галки хранить историю изменений,

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

( видимо так как настроена автоматическая синхронизация с зуп то он при каждом обращении к базе зуп туда фигачит записи )

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

   Обработка

23 — 17.02.22 — 11:46

(22) Очень странно что именно обмен влияет на версии.

Хотя ад у меня те ведь при обмене если изменился объектов автоматом регит.

Просто надо выяснить нужно это кому или нет.

И удалить. На крайняк можно оставить последний месяц или два.

Я недавно у себя чистил версии и база сильно уменьшился.

   Ёпрст

24 — 17.02.22 — 11:52

(22) это не история изменений, это старый механизм версионирование

   Жан Пердежон

25 — 17.02.22 — 11:53

(0)

https://v8.1c.ru/price/

1С:Предприятие 8.3. Сервер МИНИ на 5 подключений

14 400 руб.

   ALEX7519

26 — 17.02.22 — 12:03

(24) ну т.е. если почикать вот так

НаборЗаписей = РегистрыСведений.ВерсииОбъектов.СоздатьНаборЗаписей();

НаборЗаписей.Записать();    

то ничего плохого не случится ? :))

   ALEX7519

27 — 17.02.22 — 12:05

(25) 1С:Предприятие 8.3. Сервер МИНИ на 5 подключений

14 400 руб.

это дешовая версия для перехода на SQL ? еще что-ниб локупать надо будет ?

   Dmitrii

28 — 17.02.22 — 12:05

(22) >> В базе в администрировании не стоит галки хранить историю изменений.

Тогда включи эту галку. Перейди в диалог настройки. оставь у всех объектов «Когда сохранять версии» = «Никогда». У документа «Отражение зарплаты в бухучете» установи «Когда сохранять версии» = «При проведении» и «Срок хранения версий» = «Неделя».

Внизу формы есть галочка «Автоматически удалять устаревшие версии». Установи её и настрой расписание этого регламента. Например, раз в неделю. При первом выполнении это регламент заодно удалит все старые имеющиеся записи.

   Dmitrii

29 — 17.02.22 — 12:11

(27) >> это дешёвая версия для перехода на SQL?

В некотором роде. Если у вас действительно не больше пяти одновременно работающих с 1С пользователей. Больше 5 подключений сервер МИНИ сделать не даст.

>> еще что-нибудь докупать надо будет?

СУБД. Но есть бесплатные версии. Например.

MS-SQL Express (имеет ряд ограничений на размер базы, объём используемой памяти, что-то ещё — подробнее надо смотреть на сайте MS). Для вас должен подойти.

PostgreSQL. Полностью бесплатен. Есть версии для Windows и Linuх.

   Ёпрст

30 — 17.02.22 — 12:12

(26) делай.

   Повелитель

31 — 17.02.22 — 12:27

(29) MS-SQL Express (имеет ряд ограничений на размер базы, объём используемой памяти, что-то ещё — подробнее надо смотреть на сайте MS). Для вас должен подойти.

Там ограничение на 2 Гб база )))

Бесплатная только PostgreSQL будет

   1Сергей

32 — 17.02.22 — 12:32

(31) 2 гб? Ничо не путаете? Вроде, 10 было

   acht

33 — 17.02.22 — 12:32

   Winnie Buh

34 — 17.02.22 — 12:33

(31) у MS SQL Express ограничение на размер базы до 10Гб, но ТС в любом случае не подойдет,

PostgreSQL или платная MS SQL

   Dmitrii

35 — 17.02.22 — 13:02

(34) >> у MS SQL Express ограничение на размер базы до 10Гб.

Странно. Действительно только 10Гб. Мне почему-т оказалось, что больше.

Ну значит только PostgreSQL.

   ALEX7519

36 — 17.02.22 — 15:55

А ЕЩЕ ВОПРОС :

НаборЗаписей = РегистрыСведений.ВерсииОбъектов.СоздатьНаборЗаписей();

НаборЗаписей.Записать();    не сработало, вернее работало работало потом выдало что не хватает памяти и вылетело.

переписал вот так, но тоже медленно работает ( удаляю по частям ): может как-ниб по другому можно написать чтобы быстрее работало ?

ТЗ = Новый ТаблицаЗначений;

    ТЗ.Колонки.Добавить(«Док»);

    
    Запрос = Новый Запрос;

    Запрос.Текст = «ВЫБРАТЬ

    |    ВерсииОбъектов.Объект КАК Объект

    |ИЗ

    |    РегистрСведений.ВерсииОбъектов КАК ВерсииОбъектов

    |ГДЕ

    |    ВерсииОбъектов.ДатаВерсии МЕЖДУ &Дата1 И &Дата2

    |

    |СГРУППИРОВАТЬ ПО

    |    ВерсииОбъектов.Объект»;

    
    Запрос.УстановитьПараметр(«Дата1»,ДатаН );

    Запрос.УстановитьПараметр(«Дата2»,ДатаК );

    
    Результат = Запрос.Выполнить();

    Выборка = Результат.Выбрать();

    
    Пока Выборка.Следующий() Цикл

    
        стр = ТЗ.Добавить();

        стр.Док = Выборка.объект;

    
    КонецЦикла;

    
    ТЗ.Свернуть(«Док»);

    
    для Каждого стр из ТЗ Цикл

        
        Если  стр.Док.Метаданные().Имя = «ОтражениеЗарплатыВБухучете» или стр.Док.Метаданные().Имя = «ВедомостьНаВыплатуЗарплаты»  Тогда

        
        НаборЗаписей = РегистрыСведений.ВерсииОбъектов.СоздатьНаборЗаписей();

        НаборЗаписей.Отбор.Объект.Установить(стр.Док);

        НаборЗаписей.Записать();

        
        КонецЕсли;

        
    КонецЦикла;

   Ёпрст

37 — 17.02.22 — 15:56

(36) через менеджер можно удалять еще

   Ёпрст

38 — 17.02.22 — 15:56

чуток удалить, и потом записать пустой набор

  

johnnik

39 — 17.02.22 — 17:26

Дважды в «карьере» сталкивался с подобной ошибкой и оба раза причиной был распухший регистр сведений «Замеры производительности». Очищается легко (есть обработка на инфостарте)

  • 1с ошибка доступа к файлу 64 0x00000040 указанное сетевое имя более недоступно
  • 1с ошибка доступа к серверу обновлений модуля документооборота
  • 1с ошибка дампа памяти как исправить
  • 1с ошибка выполнения функции при установке
  • 1с ошибка выполнения правил регистрации объектов для плана обмена