Скрипт удаления локального кэша 1С 8.0-8.3

17.07.15

База данных - Инструменты администратора БД

После динамического обновления часто возникает ситуация, когда при перезапуске клиента он подхватывает не актуальную версию конфигурации с сервера, в результате чего могут появляться совершенно непредсказуемые глюки.
Данный скрипт очищает локальный кэш 1С и при следующем запуске 1С подхватывает актуальную версию конфигурации. Скрипт настроен на удаление кешей 8.0-8.2 платформ. Работает только если на локали нет ни одного запущенного процесса 1С 8.

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

Данный скрипт очищает локальный кэш 1С и при следующем запуске 1С подхватывает актуальную версию конфигурации. Скрипт настроен на удаление кешей 8.0-8.2 платформ. Работает только если на локали нет ни одного запущенного процесса 1С 8.

Причиной написания данного скрипта послужило то, что параметр /ClearCache часто не решает проблему.

Для использования необходимо создать текстовый файл, скопировать в него текст скрипта и изменить его расширение с *.txt на *.js.

 

Реализовано на  VBScript:

Текст скрипта:

 

Dim FSO 

Set FSO = WScript.CreateObject("Scripting.FileSystemObject")

Set WshShell = WScript.CreateObject("WScript.Shell")

Set colEnvVars = WshShell.Environment("Process")

 

FolderName1 = "\Local Settings\Application Data\1C\1Cv82"

FolderName2 = "\Local Settings\Application Data\1C\1Cv81"

FolderName3 = "\Local Settings\Application Data\1C\1Cv80"

FolderName4 = "\Local Settings\Application Data\1C\1Cv8"

 

If FSO.FolderExists(colEnvVars("userprofile") & FolderName1) Then

    GoSubFolders colEnvVars("userprofile") & FolderName1

End If

If FSO.FolderExists(colEnvVars("userprofile") & FolderName2) Then

GoSubFolders colEnvVars("userprofile") & FolderName2

End If

If FSO.FolderExists(colEnvVars("userprofile") & FolderName3) Then

    GoSubFolders colEnvVars("userprofile") & FolderName3

End If

If FSO.FolderExists(colEnvVars("userprofile") & FolderName4) Then

    GoSubFolders colEnvVars("userprofile") & FolderName4

End If

WScript.Echo "OK"

 

Sub DelFile(sFILE)

    On Error Resume Next

    FSO.DeleteFile sFILE, True

    If Err.Number <> 0 Then

        Wscript.Echo "Error deleting file: " & sFILE

    End If

End sub

 

Function GetFolder(sFOLDER)

    On Error Resume Next

    Set GetFolder = FSO.GetFolder(sFOLDER)

    If Err.Number <> 0 Then

        Wscript.Echo "Error connecting to folder:" & sFOLDER & VBlf & "[" & Err.Number & "]" & Err.Description

        Wscript.Quit Err.Number

    End If

End Function

 

Sub GoSubFolders (objDIR)

    ProcessFilesInFolder objDIR

    Set sFolder = GetFolder(objDIR)

    For Each eFolder in sFolder.SubFolders

        GoSubFolders eFolder

    Next

    FSO.DeleteFolder sFolder, True

End Sub

 

Sub ProcessFilesInFolder (objDIR)

    Set sFolder = GetFolder(objDIR)

    For Each objFile in sFolder.Files

        DelFile objFile

    Next

End Sub

 

Реализовано на JScript. 

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

Текст скрипта:

 

var FSO = new ActiveXObject("Scripting.FileSystemObject");

var WshShell = new ActiveXObject("WScript.Shell");

var colEnvVars = WshShell.Environment("Process");

 

var sErrors = false;

 

var FolderName1 = "\\Local Settings\\Application Data\\1C\\1Cv82";

var FolderName2 = "\\Local Settings\\Application Data\\1C\\1Cv81";

var FolderName3 = "\\Local Settings\\Application Data\\1C\\1Cv80";

var FolderName4 = "\\Local Settings\\Application Data\\1C\\1Cv8";

 

 

if (FSO.FolderExists(colEnvVars("userprofile") + FolderName1))

    GoSubFolders(colEnvVars("userprofile") + FolderName1);

if (FSO.FolderExists(colEnvVars("userprofile") + FolderName2))

    GoSubFolders(colEnvVars("userprofile") + FolderName2);

if (FSO.FolderExists(colEnvVars("userprofile") + FolderName3))

    GoSubFolders(colEnvVars("userprofile") + FolderName3);

if (FSO.FolderExists(colEnvVars("userprofile") + FolderName4))

    GoSubFolders(colEnvVars("userprofile") + FolderName4);

 

 

if (!sErrors)

    WScript.Echo("Обновление кэша прошло успешно");

else

    WScript.Echo("Возникли ошибки. Возможно запущена 1С");

 

function DelFile(sFILE)

{

    try

    {

        FSO.DeleteFile(sFILE, True);

    }

    catch(e)

    {

        sErrors = true;

    }

}

 

function GetFolder(sFOLDER)

{

    try

    {

        return FSO.GetFolder(sFOLDER);

    }

    catch(e)

    {

        sErrors = true;

    }

}

 

function GoSubFolders(objDIR)

{

    ProcessFilesInFolder(objDIR);

    var sFolder = GetFolder(objDIR);

    var subFlds = new Enumerator(sFolder.SubFolders);

    for (; !subFlds.atEnd(); subFlds.moveNext())

    {

        GoSubFolders(subFlds.item());

    }

    try

    {

        FSO.DeleteFolder(sFolder, true);

    }

    catch(e)

    {

        sErrors = true;

    }

}

 

function ProcessFilesInFolder(objDIR)

{

    var sFolder = GetFolder(objDIR);

    var subFiles = new Enumerator(sFolder.Files);

    for (; !subFiles.atEnd(); subFiles.moveNext())

    {

        DelFile(subFiles.item());

    }

}

 

См. также

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

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

8400 руб.

20.08.2024    13096    100    46    

104

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

Роли… Вы тратите много времени и сил на подбор ролей среди около 2400 в ERP или 1500 в Рознице 2, пытаясь понять какими правами они обладают? Вы все время смотрите права в конфигураторе или отчетах чтоб создать нормальные профили доступа? Вы хотите наглядно видеть какие права дает профиль и редактировать все в простом виде? А может хотите просто указать подсистему и дать права на просмотр и добавление на объекты и не лезть в дебри прав и чтоб обработка сама подобрала нужные роли? Все это теперь стало возможно! Обновление от 18.09.2024, версия 1.2

18000 руб.

06.12.2023    10139    47    5    

78

SALE! %

Инструментарий разработчика Инструменты администратора БД Системный администратор Программист Платформа 1С v8.3 Управляемые формы Конфигурации 1cv8 Россия Платные (руб)

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

4800 3840 руб.

14.01.2013    190721    1151    0    

918

Инструменты администратора БД Инструментарий разработчика Роли и права Программист Платформа 1С v8.3 Конфигурации 1cv8 Россия Платные (руб)

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

15000 руб.

10.11.2023    11459    40    27    

66

Закрытие периода Инструменты администратора БД Корректировка данных Бухгалтер Пользователь Бухгалтерский учет 1С:Бухгалтерия 3.0 Россия Бухгалтерский учет Платные (руб)

Расширение «Оперативное проведение» в 4 раза уменьшает время проведения документов и закрытия месяца. Является комплексным решением проблем 62 и 60 счетов. Оптимизирует проведение при включенной функциональной опции «Раздельный учет НДС». Используется в более 10 организациях уже 2 года. Совместимо с конфигурацией Бухгалтерия 3.0 (+КОРП).

14400 руб.

29.04.2020    33663    109    152    

75

Инструменты администратора БД Системный администратор Программист Платформа 1С v8.3 Конфигурации 1cv8 Платные (руб)

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

3600 руб.

06.02.2017    32524    145    18    

51

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

Данная разработка позволит решить вопрос с резервным копированием Ваших баз в автоматическом режиме, расположенных на сервере 1С. Система умеет ставить блокировки на вход, блокировать фоновые задания, принудительно отключать сеансы пользователей. И все это система делает в автоматически при создании бэкапа (или через команду). Выгрузка происходит в родной формат 1С - .dt. Так же система умеет архивировать данные выгрузки с установкой пароля. Умеет менять расширение файла zip или dt на любое указанное вами, что позволит сохранить выгрузки от шифровальщика. Может удалять старые копии выгрузок, оставляя указанное количество резервных копий, начиная с самой поздней. Только для WINDOWS!

6000 руб.

06.11.2012    73596    629    45    

88

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

Многие сталкиваются с проблемой когда изображения, находящиеся в базе разные по объему и размерам. Менеджеры могут добавить файлы в очень высоком разрешении, объемом свыше 20 Мегабайт. База данных становится слишком большой, выгрузка на сайт идёт медленно и требуется много место на хостинге. Как сжать картинки и уменьшить размер базы 1С? Это можно сделать с помощью данной обработки. Существует возможность выбрать различные варианты для того чтобы уменьшить картинки: в разы, в процентах от первоначального объема, а также сделать картинки одинаковой ширины. В результате размер базы 1С значительно сократится (в зависимости от количества и размера картинок), а изображения станут небольшого объема, равными по ширине, почти без потери качества. Работает на управляемых формах для УТ 11, КА, ERP.

3000 руб.

21.07.2022    10120    9    4    

17
Комментарии
Подписаться на ответы Инфостарт бот Сортировка: Древо развёрнутое
Свернуть все
1. iov 407 25.05.11 22:25 Сейчас в теме
Вот просто интересно это грабли уже мхом покрылись а разработчики как них не исправили так и не собираются. Это что? Отношение к потребителю?
EugeneMIPT; tuman777; +2 Ответить
3. markers 278 27.05.11 19:30 Сейчас в теме
(1) могу сказать, что по моим оценкам в 8.2 их стало только больше (даже без динамы)
2. sound 536 27.05.11 10:26 Сейчас в теме
Как-то сложновато, у меня 90% пользователей работают в терминалке, тоже поначалу мучился чистил кэши, потом понял, что никто баги править не будет. Написал им батник в автозагрузку (уже несколько раз упоминал на Инфостарте):


rmdir "%AppData%\1C\1Cv82" /S /Q
rmdir "%LOCALAPPDATA%\1C\1Cv82" /S /Q
del "%LOCALAPPDATA%\Temp\*.*" /F /Q


Последняя строчка необязательна, но я решил, что пускай и темп чистится.
gutentag; EugeneMIPT; Zeskord; btk61; +4 Ответить
4. Valet 56 28.05.11 16:20 Сейчас в теме
Из второго комментария строчки корректней. Т.к. в Win7 и Win2008 несколько другие пути к профилю.
5. 6есик 53 02.06.11 11:29 Сейчас в теме
Я в таких случаях просто прошу пользователей удалить и заново добавить базу в списке информационных баз, тоже помогает. Кроссплатформенный способ :D
6. DitriX 2102 02.06.11 16:34 Сейчас в теме
А можно тупой вопрос?
Для чего это надо делать? У меня вроде как 130 человек в базе 8.1 сидели, полгода назад перевел на 8.2 и не возникало необходимости их чистить, может подскажите, что это лечит? Ну так, для опыта
7. sound 536 02.06.11 16:39 Сейчас в теме
(6) У меня например бывает юзер открывает форму (любую) и она не раскрывается на экране, а сворачивается в панель окон, можно конечно в этом случае жмакнуть по свернутому окну и выбрать пункт "Восстановить положение окна", но когда это нужно объяснить 130-ти юзерам - малость надоедает ;) , поэтому 7 бед - 1 резет и все хорошо у всех.
Бывают и другие загадочные глюки, разбираться с которыми нет времени, а очистка кеша помогает.
AlexITGround; cleaner_it; +2 Ответить
8. DitriX 2102 02.06.11 20:17 Сейчас в теме
9. khan 08.06.11 16:50 Сейчас в теме
А настройки пользователя при этом не уничтожаются ?
10. sound 536 08.06.11 16:51 Сейчас в теме
(9) Еще как уничтожаются, все кроме списка баз
11. arjuna 13.06.11 11:10 Сейчас в теме
Сталкнулся с глюком. При подборе (именно через подбор) ТМЦ разные ТМЦ увеличивают количество первой строки. Т.е. имеем 1 строка "труба №1" 1шт.
после добавления любого ТМЦ
получаем 1 строка "труба №1" 2шт.
Как Вы думаете это тоже связано с динамическим обновлением?
13. arteast 100 22.07.13 05:38 Сейчас в теме
(11) arjuna, у меня было подобное у одного из клиентов - оказалось что у карточек одна единица измерения н всех) косячно завели номенклатуру)
14. arjuna 22.07.13 08:21 Сейчас в теме
(13) arteast, Этот вариант я не рассматривал. Нужно попробовать проверить.
12. 6есик 53 14.06.11 10:21 Сейчас в теме
Если при очистке кеша этот глюк исчезнет - тогда связано, если же нет то скорее всего дето в коде бок.
Оставьте свое сообщение