Выгрузка информационной базы с возможностью копирования - внешняя утилита (BackupCripo v.1.2)

01.09.15

Разработка - Инструментарий разработчика

Приложение позволяет создавать архивную копию ИБД средствами 1С, может также использоваться просто для разрыва и блокировки соединений пользователей с БД , с дальнейщей разблокировкой. К особенностям данной утилиты можно отнести возможность создания определенного количества (задается в настройках) уникальных копий. Т. е., например, четыре дня создается новая порция архива, на
пятый затирается самая старая. Есть возможность шифровать Логин и Пароль пользователя, под которым будет происходить операция выгрузки. Можно вести логирование операций. Максимум комфорта ))

Скачать файлы

Наименование Файл Версия Размер
BackupTsg
.zip 8,20Kb
7
.zip 8,20Kb 7 Скачать
BackupCripo
.zip 15,14Kb
2
.zip 15,14Kb 2 Скачать

Приложение используется в трех режимах, что определяется параметром командной строки:

 - /LOCK - Прерывает соединения пользователей с БД и блокирует все дальнейшие попытки входа.

 - /BACKUP - Выгружает ИБД.

 - /RESET - Снимает блокировку БД

Запуск утилиты возможен только с одним из параметров!  Можно вывести справку, используя ключ /? .

  В конфигурационном файле (*.exe.config) имеются дополнительные параметры, для настройки работы:

 - PathApp - Путь и имя исполняемого файла 1С

 - DbName - Задает БД. Синтаксис:

                   /F <Путь к каталогу БД> - Файловый вариант

                  /S <Сервер\Имя БД> - Серверный 

 - PathBk - Каталог, куда будет выгружаться БД

 - KeyDb - Идентификатор архива, соответствующий определенной БД. Я использую 1 символ.

 - Options - Дополнительные параметры командной строки 1С. В конфиге указаны необходимые, вы можете дописать свои. Не надо дописывать опцию /Out - при работе в режиме  /BACKUP задается автоматически.

- KeyModeBackup - Задает режим создания архивных копий. Имеет два значения:

                               - Limited - Имя архива соответствует определенной маске  и содержит счетчик итераций,                                                                      который задается параметром MaxOrder.

                               - Unique - Имя архива каждый раз Уникально.

 - MaxOrder - Задает макисмальное количество порций архива в режиме Limited, допустимые значения 1 - 9 .

 - UseCrpPass - Определяет, использовать ли шифрование данных пользователя. (True / False).

 - Login - Задается Имя Пользователя (если используется режим без шифрования).

 - Password - Задается Пароль Пользователя (если используется режим без шифрования) .

- UseLogging - Вести лог обращений к БД    (True / False)

  Предполагается следующий порядок работы с утилитой.  Приложение запускается с параметром /Lock, прерывает все  коннекты и устанавливает блокировку соединений с БД. При этом инициализируется параметр разблокировки (ПР), который задается в процедуре общего модуля 1С, по умолчанию он имеет значение "КодРазрешения". Данное  значение и  задано в конфиг. файле приложения в параметре /Options, измените его, если необходимо.   Далее, при запуске приложения с параметром /Backup создается архивная копия и последний вариант запуска с параметром /Reset снимает блокировку БД. Если вы будете использовать /Lock , то запуск /Backup и /Reset не отработает без правильного указания ПР. При запуске в режиме /Lock ПР вроде как бы и не нужен, но абсолютно не  мешает, поэтому он прописывается на постоянной основе в Options. Если блокировка БД вам не нужна, используйте  приложение только в режиме /Backup. Можно использовать утилиту только для блокировки и разблокировки без  режима /Backup. При создании заданий в планировщике заданий (удобно использовать ночью) интервал запуска  между /Lock и /Backup лучше делать не менее 15 мин., в этом случае /Lock гарантированно отработает.

    Имеется две редакции приложения  BackupTsg и BackupCripo. Во второй ко всем возможностям добавляется ещё шифрование Логина и Пароля. В редакции BackupCripo параметры Login и Password не заполняются, для задания этих параметров используется дополнительная утилита RegApplet.exe.

Синтаксис RegApplet.exe /SL<Логин> /SP<Пароль> . В результате выполнения формируется файл User1c.dat, в котором хранятся логин и пароль пользователя, при работе BackupCripo использует данные из этого файла для соединения с БД.

Т е RegApplet.exe используется единоразово.  Если вы хотите убедиться, какие данные хранятся в User1c.dat, необходимо запустить RegApplet.exe /DS.   При этом User1c.dat должен находиться в одном каталоге с RegApplet.exe. Если при использовании версии  BackupCripo и установленном в True  UseCrpPass, вы зададите значения параметров Login или  Password то будут использоваться именно эти значения, а не те что хранятся в  User1c.dat.

В состав архива BackupTsg входят два файла - исполняемый файл и *.config .

В состав архива BackupCripo входят четыре файла:

 - BackupCripo.exe   - исполняемый файл и *.config

- BackupCripo.exe.config - файл настроек

- ManageCripto.dll - библиотека шифрования

- RegApplet.exe - утилита создания файла User1c.dat.

 User1c.dat создается в каталоге, где запускается RegApplet.exe, после этого его надо переложить в каталог, который прописан в параметре PathBk.  Далее RegApplet.exe можно убрать в шкаф )) В остальном принцип работы BackupCripo полностью совпадает с BackupTsg.  Для BackupTsg параметр UseCrpPass не имеет значения.

Для работы необходим установленый Microsoft .NET Framework 4.6.  Скачать можно здесь https://www.visualstudio.com/downloads/download-visual-studio-vs  Обычно устанавливается при установке Windows.

При редактировании файла *.exe.config необходимо соблюдать условие, чтобы после редактирования кодировка файла сохранилась UTF-8 . При использовании Notepad необходимо открывать файла непосредственно из Блокнота, перед этим установив кодировку  UTF-8 ,  а не из контекстного меню Рабочего стола Windows. Также удобно пользоваться     для этих целей редактором PSPad (http://www.pspad.com/ru/).

Обратите внимание, в файле *.exe.config  заполненное значение хранится в виде: <value>Значение</value> , а пустое    <value />. 

Update:

 - v.1.2 (07.09.2015)

   - Добавлен параметр TypeAction - значения: Upload - выгрузка данных; Copy - копирование файла *.1CD для файловой БД. Т е появилась возможность копирования. Копирование файла данных 1С происходит даже в том случае, если с базой работают пользователи, что согласно рекомендациям 1С недопустимо. Поэтому данная утилита также может пригодится   и для данного варианта сохранения данных.

 - Улучшенно логирование операций.

 Приятной работы ...

Архивация

См. также

SALE! 20%

Infostart Toolkit: Инструменты разработчика 1С 8.3 на управляемых формах

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

Набор инструментов программиста и специалиста 1С для всех конфигураций на управляемых формах. В состав входят инструменты: Консоль запросов, Консоль СКД, Консоль кода, Редактор объекта, Анализ прав доступа, Метаданные, Поиск ссылок, Сравнение объектов, Все функции, Подписки на события и др. Редактор запросов и кода с раскраской и контекстной подсказкой. Доработанный конструктор запросов тонкого клиента. Продукт хорошо оптимизирован и обладает самым широким функционалом среди всех инструментов, представленных на рынке.

13000 10400 руб.

02.09.2020    122177    670    389    

714

SALE! 25%

Infostart PrintWizard

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

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

18000 15300 руб.

06.10.2023    7297    21    6    

39

SALE! 20%

Infostart УДиФ: Управление данными и формами

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

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

10000 8000 руб.

10.11.2023    3544    11    1    

34

SALE! 30%

PowerTools

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

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

3600 2520 руб.

14.01.2013    177758    1073    0    

849

Многопоточность. Универсальный «Менеджер потоков» 2.1

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

Восстановление партий или взаиморасчетов, расчет зарплаты, пакетное формирование документов или отчетов - теперь все это стало доступнее. * Есть желание повысить скорость работы медленных алгоритмов! Но... * Нет времени думать о реализации многопоточности? * о запуске и остановке потоков? * о поддержании потоков в рабочем состоянии? * о передаче данных в потоки и как получить ответ из потока? * об организации последовательности? Тогда ЭТО - то что надо!!!

5000 руб.

07.02.2018    99348    239    97    

296

[ЕХТ] Фреймворк для Расширений 1С

Инструментарий разработчика Платформа 1С v8.3 Управляемые формы Платные (руб)

"Фреймворк для Расширений 1С" это универсальное и многофункциональное решение, упрощающее разработку и поддержку создаваемых Расширений. Поставляется в виде комплекта из нескольких Расширений с открытым исходным кодом. Работает в любых Конфигурациях в режиме Управляемого приложения с режимом совместимости 8.3.12 и выше без необходимости внесения изменений в Конфигурацию.

3000 руб.

27.08.2019    18116    6    8    

39

1С HTML Шаблоны / HTML Templates

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

Быстрая и удобная обработка для работы с шаблонами HTML. Позволяет легко и быстро формировать код HTML.

2040 руб.

27.12.2017    28111    3    10    

15

Выполнение произвольного кода или запроса с параметрами через Web-сервис (замена COM-подключений)

Инструментарий разработчика Обмен между базами 1C Платформа 1С v8.3 Платные (руб)

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

2400 руб.

24.09.2019    23605    15    15    

32
Комментарии
В избранное Подписаться на ответы Сортировка: Древо развёрнутое
Свернуть все
1. Созинов 01.09.15 17:15 Сейчас в теме
Исходники будут или это коммерческая обработка в будущем?
2. Serggray 14 01.09.15 17:32 Сейчас в теме
Исходники на C# и да хотелось бы в будущем ..)
3. ZOMI 444 01.09.15 23:15 Сейчас в теме
4. TODD22 18 02.09.15 05:07 Сейчас в теме
И выгружает в *.dt файл?
5. Serggray 14 02.09.15 11:02 Сейчас в теме
6. TODD22 18 02.09.15 11:09 Сейчас в теме
(5) Крайне вредная разработка и способ создания резервных копий.
7. Serggray 14 02.09.15 11:17 Сейчас в теме
to TODD22 так не пользуйтесь, я пока вреда не наблюдаю
8. TODD22 18 02.09.15 11:20 Сейчас в теме
(7) Это вы не наблюдаете и пока не наблюдаете.... Так вы же другим советуете ;)
Да и вообще за создание резервных копий выгрузкой *.dt файла надо по рукам давать.
9. Serggray 14 02.09.15 11:23 Сейчас в теме
кому вы собираетесь давать по рукам 1с ? Если у вас есть что-то конкретное говорите ..
10. TODD22 18 02.09.15 11:43 Сейчас в теме
(9) что вам конкретно сказать?
Я вам уже конкретнее некуда сказал что нужно давать по руками за то что делают бэкапы выгрузкой в *.dt. Собственно то же самое написано и в документации 1С.

Пример из практики. У меня 120+ баз в розничных точках все они в РИБе.
Каждый день происходят разные невероятные вещи. За несколько месяцев упало 3 узла. Разрушились какие то таблицы. Восстановить не получится.
Но из копии каталога(кстати как и рекомендует делать фирма 1С в документации) ещё можно попробовать восстановить базу. Или хотя бы выгрузить из неё данные.

Выгрузка в *.dt файл может пройти. Но выгрузится может битая база которая потом назад уже не загружается. Загрузка падает с "ошибкой формата потока".

Вот как пример недели 3 назад была у нас ситуация сломалась база. Я конечно же скопировал каталог с базой. Запустил восстановление базы. Оно мне сообщило что восстановило какие то таблицы. Я запускаю конфигуратор. Делаю на всякий случай выгрузку в .dt файл.(бывает что выгрузишь/загрузишь базу и начинает работать).
И запускаю ТиИ. Через 2 минуты ТиИ вылетает с ошибкой. Открываю базу. А базы больше нет. Пусто! Просто пустая конфигурация.
Пробую загрузить из *.dt файла пишет "ошибка формата потока". И вот какая польза от такого бэкапа?
Затем я открыл базу в скопированном каталоге и из неё выгрузил продажи за нужный мне период и загрузил в центральную базу. ну и создал новый узел взамен повреждённого... но это уже как бы к делу отношения не имеет.
Может нужно всё же читать документацию от фирмы 1С?
11. Bukaska 140 02.09.15 11:46 Сейчас в теме
(10) TODD22, Насколько я тоже знаю, самый оптимальный бекап, это копирование *CD файла))))
12. TODD22 18 02.09.15 11:49 Сейчас в теме
(11) Bukaska, ну да... есть хотя бы какие то возможности данные восстановить или частично выгрузить.
Ну и это рекомендация фирмы 1С. О чём и написано в документации.
16. Созинов 12.09.15 18:50 Сейчас в теме
(10) TODD22, Согласен, нужно делать норм бекап каталога если файловая база или пользоваться средствами СУБД. Мы так и делали, но я регулярное еще делал параллельно выгрузку|загрузку в свои локальные базы для доработки, было удобно (в крупной компании по хорошему нужен отдельный сервер отладки, ну а франч и так понятно имеет нормальную среду разработки). Правда все этом можно bat файлами сделать. В общем пробовал в свое время разные утилиты для бекапа - и вернулся к скриптам в маленькой компании и к нормальной настройке бекапов в крупной (тут конечно никакие утилиты не помогут). Тем не менее - отдельные функции таких программ удобны, хотя еще раз соглашусь иногда бывают фейлы (правда практики у меня не так много, и слишком запущенных случаев не встречал). Но и при бекапе каталога - результат во многих случаях не лучше, если уж база посыпалась - то дело дрянь.
13. Serggray 14 02.09.15 11:58 Сейчас в теме
... на Linux -е вы тоже будете каталоги копировать ? Если база битая то поздно уже что-то копировать, а как раз можно
воспользоваться для восстановления ранее выгруженным *.dt или backup-ом БД на уровне сервера БД. Мы пользуемся
таким механизмом уже 5 лет , за это время раза два восстанавливали базу после аварии нормально ну и много раз в стандартном режиме после перехода на новые версии ОС или БД. Извините на этом дискусию с вами заканчиваю.
14. Serggray 14 02.09.15 11:59 Сейчас в теме
15. Serggray 14 07.09.15 13:23 Сейчас в теме
По итогам дискусии в утилиту добавленна возможность Копирования файла данных 1С. Ниже представлена выдержка из рекомендаций 1С по использованию выгрузки данных


Не рекомендуется использовать данный способ для создания резервной копии информационной базы по следующим причинам:

● может возникнуть ситуация, при которой файл выгрузки будет невозможно загрузить, если в информационной базе, из которой производилась выгрузка, существовали ошибки;

● длительное время создания;

● необходимость монопольного доступа к базе данных;

● высокие требования к оперативной памяти.

Реальным противопоказанием м б пункт первый. Но выгрузка данных действительно расчитана на то что БД находится в работоспособном состоянии, с другой стороны Копирование файла не является залогом восстановления БД
на нужный момент, в случае некорректного состояния данных. Длительность при размере более 4 Гб примерно совпадает. При копировании также запрещена работа пользователей. В пользу файла *.dt играет его мобильность. Поэтому на мой взгляд наиболее удобным и надежным вариантом было бы использование обеих способов (1 порцию файла CD и несколько dt ) ) , ну а для клиент-серверного варианта - backup сервера БД и *.dt Ну а там каждый решает сам ..
Созинов; +1 Ответить
Оставьте свое сообщение