gifts2017

Ошибка "Нарушена целостность структуры конфигурации"

Опубликовал ООО ЛИКА (olenaNT) в раздел Администрирование - Тестирование и исправление

Один из многих вариантов решения ошибки "Нарушена целостность структуры конфигурации".
Если Вам довелось столкнуться с этой ошибкой обратитесь к специалисту 1С однозначно. Вариантов решения много, но от ситуации и источника проблемы - решения совершенно разные.

Один из многих вариантов решения ошибки "Нарушена целостность структуры конфигурации".
Если Вам довелось столкнуться с этой ошибкой обратитесь к специалисту 1С однозначно. Вариантов решения много, но от ситуации и источника проблемы - решения совершенно разные.

 

Предлагаю вашему вниманию одну из таких ситуаций.
Описание задачи:
Обновление конфигурации произошло автоматически. При запуске 1С режиме конфигуратор имеем сообщение "Нарушена целостность структуры конфигурации". При автообновлении конфигурацию поставщика обновить корректно не получилось. Запуск в пользовательском режиме выдает ошибку ссылаясь на модуль в конфигурации.
Во первых необходимо очистить кеш. В ОС Windows 7 находиться C:\Users\Администратор\AppData\Roaming\1C\1Cv82 и C:\Users\Администратор\AppData\Local\1C\1Cv82 (Win7x64). После очистки кеша 1С запуститься в режиме конфигуратора. При попытке открыть конфигурацию 1С вылетает. Выгрузить информационную базу в файл для подстарховки. Тестирование и исправление не помогает. Утилита проверки файловой базы говорит, что ошибок нет. Пункты меню загрузки, выгрузки конфигурации, поддержки и т.п. без открытой конфигурации не активны. Доступна сохранение конфигурации данных - это значит что данные не уничтожены, что является главным..
Так же из конфигуратора в пользовательский режим в режиме отладки может запуститься, а возможно и нет, это не влияет на ситуацию.
Попытка загрузить информационную базу в SQL не приведет к положительному результату.

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

Решение:
1. Необходима чистая конфигурация той же версии - рабочая.
2. Очиста кеша полная (указано выше).
3. Запускаем чистую базу в режиме конфигуратора и открываем конфигурацию. При этом 1С создает ее кеш в C:\Users\Администратор\AppData\Local\1C\1Cv82 (набор файлов и папок в папке с ID конфигурации.) так же нам нужен кеш C:\Users\Администратор\AppData\Roaming\1C\1Cv82. Можно просто переименовать данные папки после закрытия 1С.
4. Запускаем наш не рабочую базу в режиме конфигуратора и смотрим кеш. И в результате имеем две папки с ID конфигурации (Живой и Мертвой).
5. Закрываем все и подменяем кеш мертвой конфы на живую полностью. Т.е. удаляем текущую и заменяем ранее переименованной папкой.
6. Запускаем не рабочую базу в режиме конфигуратора И ВОТ первый успех -  дерево конфигурации открыто, разделы меню управления конфигурацией активны.
7. Идем в управление поддержкой, и снимаем с поддержки полностью. сохраняем, обновляем. Можно обновить через файл конфигурацией рабочей базы.
8. Удалем кеш полностью. 
9. Запускаем не рабочую базу в режиме конфигуратора, пытаемся открыть конфигурацию - все открывается, ошибки нет.
10. Запускаем 1С. Все доступно. Данные на месте. 

Вот еще вариант спасения предложенный пользователем инфостара Tavalik:

1. "Конфигурация" - "Конфигурация базы данных" - "Вернуться к конфигурации БД" 
2. "Конфигурация" - "Обновить конфигурацию баз данных"

http://olenant.ru

См. также

Вознаграждение за ответ
Сумма: 0 $m
Добавили:
ООО ЛИКА (olenaNT) (0.02 $m)
Подписаться Добавить вознаграждение

Комментарии

1. Яков Коган (Yashazz) 07.10.13 13:50
А что, делать свежие бэкапы - уже совсем не модно? Мне вот за одну фразу "подняться из древнего бекапа, если таковой имеется" - уже хочется прибить тяжёлым предметом.
alexander-pro; freeek; CHSN8; lamelioss; anchovy; Bukaska; kotloff; +7 Ответить 2
2. Елена Пименова (Bukaska) 07.10.13 14:10
(1) Yashazz, Программистов две категории: бекапники и безбекапники))) Вот для вторых и делают)))
3. ediks (ediks) 08.10.13 10:35
(1) Бекап - это акт проявления трусости. :).
ЗЫ. Совсем не хочу принизить ценности публикации. Любой вариант успешного восстановления имеет право на жизнь.
freeek; Wildpig; CHSN8; dour-dead; PokerFace; kozlovvp; quebracho; +7 Ответить
4. Андрей Тарлыков (Tarlich) 09.10.13 11:10
Необходима чистая конфигурация той же версии - рабочая.
а если не знаю?
5. Андрей Кузнецов (13jaguar) 09.10.13 11:35
Я считаю, что перед восстановлением из бекапа все-же следует попробовать иные варианты восстановления текущей информации БД. Автору респект!
6. ООО ЛИКА (olenaNT) 11.10.13 14:02
(4) Tarlich,
[IS-QUOTE]Необходима чистая конфигурация той же версии - рабочая.
а если не знаю?[/IS-QUOTE]
По любому существуют бекапы хоть какие нибудь хоть полугодовой давности. И еще вариант, Вы можете обратиться к специалисту 1С, у которого найдется типовая конфигурация +7(3435)370307. Выгрузить конфигурацию в файл. Создать новую пустую конфигурацию и загрузить т.е. заменить конфигурацией из файла.
7. Денис Vvv (EvilDoc) 28.11.13 12:51
Интересный момент. Запомню =-)
8. Юрий Кириллов (FullMoon) 10.01.14 22:29
1сники делятся на тех, кто делает бэкапы и тех, кто будет их делать))
9. Елена Пименова (Bukaska) 11.01.14 00:23
(8) FullMoon, о чем я и сказала в предыдущем посте)))
10. Юрий Кириллов (FullMoon) 11.01.14 10:11
(9) Bukaska, я имел ввиду, что те кто не делают бэкапы всё равно будут их делать после падения базы.
11. soroka (EugeneR1c) 13.02.14 18:17
Во первых необходимо очистить кеш. В ОС Windows 7 находиться C:\Users\Администратор\AppData\Roaming\1C\1Cv82 и C:\Users\Администратор\AppData\Local\1C\1Cv82 (Win7x64). После очистки кеша 1С запуститься в режиме конфигуратора. При попытке открыть конфигурацию 1С вылетает. Выгрузить информационную базу в файл для подстарховки. Тестирование и исправление не помогает. Утилита проверки файловой базы говорит, что ошибок нет.


Помогло: (при условии возможности выгрузить данные)
В режиме Конфигуратора -Администрирование-Выгрузка данных, и сразу "Загрузка данных" - этого же файла.
Прикрепленные файлы:
12. Вика Козлова (natarezn) 20.02.14 09:20
а если я накатываю обновления с 53,6 до 55,7 ? и она пишет вот эту табличку ?
13. ООО ЛИКА (olenaNT) 20.02.14 10:14
(12) natarezn, вернитесь к бекапу. Тестирование и исправление ошибок. Если такого нет восстанавливайте согласно статье.
14. Галина Ивлева (galinka1c8) 21.04.14 23:46
Спасибо очень помогло. Сообщение об ошибке стал выдавать при обновлении. и то через раз( при попытке обновить с типовой пару раз выбивал, затем вроде пошло, но при запуске в режиме предприятия выбил насовсем). Чистка кеша спасла ситуацию, дальше вроде дело не пошло). А по поводу копий не каждый клиент их делает(хорошая мысль приходит как говорится опосля, когда все слетело и наученные горьким опытом, все начинают выгружать арх копии). Но даже у тех у кого это поставлено на автом. архивирование ночью периодически архив не формируется - чисто человеческий фактор- забыли на ночь правильно закрыть программу при рабоче по удаленке)) Так что тоже может пригодится.
15. Anna Selivanova (nance) 25.07.14 20:33
СПАСИБО!!! Очень выручило! Помимо этой ошибки - были также "Ошибка формата потока" и ошибка при создании архива - заверщение работы 1С Предприятие. От всего помогла замена кеша, универсальный метод)
16. Иван Шевченко (Korvinfromamber) 28.11.14 13:55
а у меня тепо не обновлялась ИБ .. залил конфу версия поддержки обновилась, а конфигурации нет (( .. вот и думаю получится нет ? ... ну .. думаю получится конечно же .. ))
17. Иван Шевченко (Korvinfromamber) 28.11.14 13:56
вот только не понял - смысл от чистки кэша то ?
18. Иван Шевченко (Korvinfromamber) 28.11.14 14:57
Спасибо други .. все работает ..
19. Игорь Дайнеко (Dnki) 29.11.14 22:40
Только что случилась описанная ситуация. Рад бы разделить эйфорию коллег, но метод не сработал. Мой случай:
- обновлял базу конфигурацией с флэшки. ("Загрузить .. из файла")
- Основная конфигурация загрузилась, и выдала "Страшное Сообщение". БД не обновилась.
- В режиме "1С Предпр." запускается и работает, только выдает предупреждение о несоответствии.
- Удаляю кэши. В обоих папках: \Roaming\1C\1Cv82, \Local\1C\1Cv82. Затем, вставляю (копирую) кэши (оба) из работоспособной базы, как и рекомендует автор.
- Ан нет! Сразу при запуске Конф.опять Сообщение.

Но статья все-же натолкнула на мысль:
- Просто очистил кэш
- Конф. открылся, без дерева, т.е. конфигурация закрыта.
- Пункт меню: Конфигурация/ Конфигурация БД/ Вернуться к конф-ии БД вернула к жизни.

Выводы:
1) Наверное не получилось из-за отсутствия гарантированной идентичности с конфигурацией "древнего бэкапа".
2) Причина возникновения проблемы в моем случае - "битый" файл на флэшке. Другую базу испортил так-же. Как "неприличную болезнь" передал.
3) Отсюда и третий вывод, про архивы. Про них много сказали. Согласен со всеми. Как факт скажу: за последние 10 лет сотни/тысячи обновлений, своими руками и коллег, и всегда только после сохранения БД. Даже если торопишься, даже если недавно обновляли и т.п. Сегодняшний случай подтверждение правильности правила. Моя БД была отладочная, интерес представляла сама борьба с проблемой.

Осталось только прочувствовать ситуацию "на будущее". У меня пока мало статистики о самопроизвольной порче баз просто в ходе работы. Помню, портились файловые БД первых релизов 8.2 (до 15-го) просто гарантированно, за 1-2 месяца. Сейчас, на 17-19 за год ни одного случая. С SQL проработал 1,5 года - нет вопросов. И, выходит, обновление - самый вероятный вариант появления проблемы. Если у кого есть информация по порче БД - поделитесь.
Serg3141; Kotyara; +2 Ответить
20. Дмитрий Кабашов (dnk-71) 30.11.14 00:40
А почему про chdbfl.exe забыли?
Утилита предназначена для автономной проверки и исправления файлов базы данных.
Бывает, вызывают на ремонт БД.
После сбоев всяких (в т.ч. и после неудачного обновления) обычно помогает:
1. Переиндексация
2. Данная утилита
21. ООО ЛИКА (olenaNT) 02.12.14 14:21
(20) dnk-71,
Это статья как раз для таких случаев что ничего не помогает тем более chdbfl.exe.
Каждый специалист даже новичок знает об этом файле в платформе 1С, это первый инструмент после Тестирования и Исправления ошибок (ТИО).
22. Семён Павлюков (7OH) 02.12.14 16:19
Спасибо огромное.
Пользовательсикй кеш менял, когда отчеты скд вылетали, а вот до этого догадаться - ммм- класс.
Помогла загрузка конфигурации целиком.
23. Kostya Zhurov (It-developer) 11.12.14 17:32
прикольно. а я знаю как 3-мя строками убить все конфигурации подчиненных узлов :)))))
24. Виталий Онянов (Tavalik) 16.12.14 12:19
Мне, к сожалению, трюк с подменой кэша не помог, как и не помогло тестирование и исправление ИБ.
А помогло следующее:

1. "Конфигурация" - "Конфигурация базы данных" - "Вернуться к конфигурации БД"
2. "Конфигурация" - "Обновить конфигурацию баз данных"
perepetulichka; Kotyara; +2 Ответить 1
25. Василий Маракулин (Kotyara) 13.01.15 22:17
(24) Tavalik, Да, тоже выручил именно этот способ. Подмену кэша даже не пробовал. Но надо сразу заметить, что:
1. Необходимо очистить кеш.- смотри выше. 2. Зайти в конфигуратор и выполнить ваши 2 пункта:
1. "Конфигурация" - "Конфигурация базы данных" - "Вернуться к конфигурации БД"
2. "Конфигурация" - "Обновить конфигурацию баз данных"
Большое спасибо.
26. Андрей Анищенко (CERBER) 22.01.15 11:15
В моем случае, произошла такая ошибка при перепрыгивании через 3 обновления в базе "Бухгалтерия предприятия, ред 2.0", сразу после объединения, при запуске получил такую же ошибку.
База крутится на линуксе Цент ОСь + Постгрии SQL 9.1
С бекапами все плохо, не люблю я их делать, лениво. Потому еще год назад поставил какую-то прогу, делает ночами сама выгрузки всех конфигураций.
И так как это делается каждую ночь, то полез очистил кеш, открыл конфигуратор и не задумываясь, загрузил вчерашний ночной бекап. Бухи у меня не активные, потому с утра доков не успели наделать.
Ошибка произошла на релизе платформы 8.2.17.153. Может на более новых что-то подправили, но пока не могу обновиться. Сервак линуксовый лениво переустанавливать. Сносить старую версию 1С-ки серверной и ставить новую, потом еще 30 машин без домена обеги обнови платформу. Жуть.

Спасибо автору за подробный пошаговый вариант спасения данных.
27. Елена Пименова (Bukaska) 22.01.15 13:46
(26) CERBER, 8.2.17.153 - не древнюю ли вы платформу юзаете?))))
28. Денис Лопато (Terve!R) 31.07.15 12:21
(26) CERBER,
- бэкапы не делает перед обновлением.
- перепрыгивает через несколько релизов, не понимая что творит.
- не задумываясь, загружает в рабочую базу неизвестный бэкап.
- использует старючую платформу от 19.12.2012г, на которой последняя Бухгалтерия 2.0 работать не должна.
- слово "лениво" в каждом предложении :)

Как можно настолько безответственно относиться к своей работе? Жуть :)
29. Chaotic 12.08.15 01:23
Еще можно попробовать удалить базу из списка баз и добавить в список, например, с другим названием... Мне как-то помогло...
---
По поводу бэкапов вообще - бэкапы делаются, люди работают. Сие недоразумение возникло во время очередного обновления, во время текущей работы людей никак не проявлялось. А находить ту копию, на которую обновление бы нормально установилось - это терять наработанную за это время информацию...
30. Денис Лопато (Terve!R) 14.08.15 11:30
(29) Chaotic, удалить базу из списка и добавить заново - это фактически очистка кэша получается :)
31. Slava (ss4ss) 16.01.16 23:22
Чего мудрить, удаляешь базу из списка, и заново добавляешь, открываешь все норм. Старый и давно известный баг! Все прекрасно работает.
rhtr; apostal86; +2 Ответить 1
32. Александр Журавлев (apostal86) 02.03.16 10:15
(31) ss4ss, да, мне помогло в подобной ситуации. Ошибка возникала при обновлении не типовой конфигурации КА
33. Серый Брежнев (vevd) 27.05.16 11:02
Мне помогло:
1. Очистка кеша;
2. Переименование каталога БД;
3. Переименование базы данных в выборе баз данных.
34. andr bat (zoytsa) 01.06.16 15:41
Для клиент-серверной базы, которая установлена на SQL сервере можно попробовать воспользоватся запросом «delete * from configsave»
35. Анастасия Сталович (Новичок1с) 09.07.16 12:22
Добрый день.
Ошибка такая же возникает.
пробовала:
-очистить кэш- (не помогло)
-переименовать папку с базой- переименовала, подкинула 2.0.65.35 версию- в итоге запускаю из папки- при входе- оновление на версию 2.0.65.29 и далее при входе других пользователей- такая же ошибка.
-тестировала базу данных- не помогло
удалила/ создала профиль пользователя системы.
36. Анастасия Сталович (Новичок1с) 09.07.16 12:29
Всё же помогло- удалить базу из списка, а потом заного добавить..
(не ту базы вставляла в список баз)
+тестирование,
+очистка кэша
Благодарю за нужную и полезную информацию.
37. Юрий Чертоляс (juricher) 22.07.16 10:06
Не помогло. Конфигурация чуть изменена, а значит включено разрешение изменения конфигурации
38. Ирина progr-2008 Санкт-Петербург (progr-2008) 23.07.16 17:22
Несколько раз помогало удалить из списка, добавить в список.
39. Ирина progr-2008 Санкт-Петербург (progr-2008) 23.07.16 17:23
И все-таки, в чем причина нарушения структуры?
40. Михаил Кончаренко (Anchoret) 20.09.16 16:20
У меня такая ошибка возникла после того, как перезагрузился комп во время обновления.
Так как это была копия базы, не задумываясь накатил бэкап, но, к моему удивлению, конфигуратор так и не запустился.
Помогла очистка кэша.
41. Надежда Климова (semina-2016) 07.11.16 14:06
Спасибо, база в работе. Просто очистка кэша и перерегистрация базы не помогли. Помогла именно подмена кэша на рабочий.
42. Максим Рябов (M-Mark-76) 08.11.16 11:50
Сработало, спасибо за статью, все остальные варианты были бесполезны, единственное что от себя - снятие с поддержки вызывало ошибку, так что пришлось грузить конфу сразу
Для написания сообщения необходимо авторизоваться
Прикрепить файл
Дополнительные параметры ответа