Как урезать / очистить базу данных 1С средствами MS-SQL
Эта статья для тех, кто хоть раз сталкивался с необходимостью очистить базу 1С , за период с устаревшими данными. Речь пойдет об удалении данных в ненужном периоде напрямую, средствами SQL -сервера. Также следует уточнить, что речь идет о конфигурациях, использующих компоненту «Оперативный учет». На бухгалтерских и расчетных базах данный метод не тестировался.
Для начала рассмотрим, как происходит резка периода. На определенную дату, чаще всего не конец года, скажем « 31.12.2003 », вычисляются конечные остатки по всем регистрам. Далее, на начало года, на « 01.01.2004 », вводятся эти остатки документами ввода начальных остатков. При этом в новом году в документах не должно быть ссылок на документы прошлого года – так называемых документов, введенных на основании, иначе удаление средствами 1С не сможет удалить документы, на которые есть ссылки. Также следует уделить внимания периодическим реквизитам, введенных документами, так как в момент отмены проведения документа эти периодические реквизиты перестанут существовать. Чтобы не было казусов, все периодические реквизиты, устанавливаемые документами нужно перед удалением выставить заново с начала года.
Теперь рассмотрим, как обычно происходит очистка базы средствами 1С . Запускается какая-то обработка проведения, которая помечает на удаление все документы. Это достаточно длительный процесс, так как при проведении каждого из документов 1С :Предприятие очищает все движения документов, в том числе периодические реквизиты, введенные документом. Это достаточно длительный процесс с учетом большого количества документов. Далее через пункт меню «Операции -> Удаление помеченных объектов» выполняется окончательное удаление.
В совокупности – это достаточно длительный процесс, особенно для больших баз с большим количеством документов в удаляемом периоде.
Альтернативный вариант очистки базы 1С – воспользоваться имеющимися в нашем распоряжении средствами MS-SQL . Из вышеуказанной последовательности мы можем ускорить последние два пункта, а именно пометку на удаление и окончательное удаление документов.
Что требуется сделать? Просто запустить скрипт, например из SQL Query Analizer ’а. Текст скрипта представлен ниже:
USE MyTestBase
Go
CREATE TABLE ##ID
(IDDOC char(9) primary key clustered)
Go
INSERT INTO ##ID
SELECT DISTINCT IDDOC
FROM _1SJOURN
WHERE (DATE_TIME_IDDOC < '20040101')
Go
BEGIN TRANSACTION
DECLARE Mycur cursor for
SELECT sysobjects.name,syscolumns.name
FROM syscolumns INNER JOIN
sysobjects ON syscolumns.id = sysobjects.id
WHERE (syscolumns.name = N’iddoc’) OR
(syscolumns.name = N’docid’)
OPEN MyCur
DECLARE @TableName varchar(20)
DECLARE @ColName varchar(20)
FETCH NEXT FROM MyCur INTO @TableName, @ColName
WHILE @@FETCH_STATUS = 0
BEGIN
EXEC (‘Delete from ‘+@TableName+’ with (tablock) where ‘+@ColName+’ IN (Select IDDOC FROM ##ID)’)
FETCH NEXT FROM MyCur INTO @TableName, @ColName
END
CLOSE MyCur
DEALLOCATE MyCur
COMMIT TRANSACTION
DROP TABLE ##ID
Сначала из таблицы журналов документов выбираются в отдельную временную таблицу все идентификаторы документов с датой меньше заданной. Теперь о том, что делает этот скрипт. Он проходится по метаданным и удаляет из всех таблиц, где есть колонка IDDOC или DOCID , строки с идентификатором документа, входящим в таблицу удаляемых. Таким образом чистятся таблицы документов, регистров и периодических реквизитов.
После выполнения данного скрипта остается только войти в режим конфигуратора и сделать пересчет служебных данных и пересчет итогов. На случай, если вы не избавились от ссылок на старые документы, то необходимо сделать еще и проверку логической целостности. В настройках поставить « Очищать ссылки ».
Наверное, не лишним окажется напоминание, что сначала перед тем, как осуществлять очистку базы 1С , следует провести проверку на копии. Действия скрипта соответствуют тому, как если бы мы выбрали программно все документы за удаляемый период и удалили их без контроля ссылочной целостности.
Теперь о производительности. Я проверил оба варианта очистки базы 1С — удаление в 1С методом выбора всех документов и удаления их без контроля ссылочной целостности, и удаление путем выполнения данного скрипта. В базе данных содержалась информация за период с « 01.09.2001 » по « 15.06.2004 ». Удалялся период по 2003 год включительно. Конфигурация самописная, но в данном случае, думаю, это никакого значения не имеет. Данные сравнения указаны в таблице:
| Время, минут:секунд. | Удаление средствами 1C | Удаление средствами MS-SQL |
|---|---|---|
| 53:41 | 5:39 |
Как видно по результатам сравнения, удаление средствами MS-SQL фактически ровно в 10 раз быстрее. Это соотношение действительно с учетом того, что для обоих вариантов будет запущен полный пересчет итогов из конфигуратора. Хотя в случае с 1C его выполнять желательно, но не обязательно (почему — читайте здесь и здесь), а в случае с MS-SQL — обязательно. Так что, если вы не будете выполнять пересчет итогов в случае удаления в 1С , то для полноценного сравнения времени работы нужно к времени работы скрипта ( 5:39 ), добавить время пересчета итогов в конфигураторе ( 2:00 ).
Если нужно обрезать, почистить, сделать резервную копию вашей базы данных или даже вынести часть учета вообще в другую БД, при этом размер БД или непрерывность работы таковы, что штатные средства становятся малопригодными для этой задачи, то такое решение тоже есть — DB REPLICATION .
Не определен режим работы файлового хранилища
Такая ошибка может возникнуть при попытке удаления базы данных в консоли кластера сервера 1С.
В нашем случае ошибка возникла в следствие удаления в SQL Server информационной базы и обратного ее добавления в SQL Server с таким же именем.
Первоначально задача состояла просто в удалении базы из кластера сервера 1С. После того как это сделать не удалось был удален файл базы SQL.
РЕШЕНИЕ ПРОБЛЕМЫ УДАЛЕНИЯ
Ситуации могут быть разные, а решение проблемы оказалось не сложным.
Опытным путем найден способ решения проблемы. Необходимо в консоли кластера 1С нажать правой кнопкой мыши на информационной базе, затем нажать удалить и во всплывающем окне выбрать «Оставить без изменений».
После этого база данных исчезнет из консоли. В SQL базу данных можно удалить после этого также без проблем.

- Ошибки программы 1С (8.1 / 8.2) и как их исправить
- Закрытие заказов покупателей 1С. Ошибки программы
- Не работает 1С. Что делать?
- Поле объекта не обнаружено RMngrPortDefault
- Оптимизация базы данных 1С
- Ошибка формата потока
- Восстановление файловой базы данных после ошибки СУБД
- Как завалить обмен данными 1С в РИБ
- Не печатаются документы из программы 1С
- Чистка кэша 1С. Удалить нельзя оставить
- Ошибка SDBL Ожидается имя таблицы (pos=11)
Как создать базу 1С на SQL сервере в Windows
Добавить новую пустую базу данных на сервере 1С SQL
Если у Вас на сервере 1С взятом в аренду или установленном в офисе стоит SQL Server от Microsoft и вы хотите создать пустую базу данных, данная статья поможет вам в этом.
Для начала необходимо открыть оснастку «Администрирование серверов 1С Предприятия». Чаще всего ярлык на данную консоль можно найти в меню Пуск, в разделе с 1С Предприятие. Конечно, если данный компонент был установлен при настройке системы.

Выберите в разделе «Локальный кластер» — «Информационные базы» и нажав правой кнопкой мыши нажмите на пункт Создать — Информационная база.

В появившемся окне, заполните все поля для создания базы данных 1С.
В поле имя введите в двух местах имя вашей информационной базы, это имя одновременно для никнейм вашей базы, и название базы оснастке SQL сервер и по этому же имени можно будет обращаться к базе данных и добавлять ее пользователям.
Выберите тип баз данных, в нашем случае MS SQL Server, и адрес кластера серверов, в большинстве случаев если SQL находить на той же физической машине, что и установлен Агент сервера 1С, то кластером будет выступать адрес localhost.
В поле пользователь сервера БД для создание информационной базы, чаще всего используют учетную запись администратора SQL сервера — sa.
Если мы добавляем пустую базу, а не уже существующие на сервере баз данных, то необходимо поставить галочку «Создать базу данных в случае ее отсутствия».
Именно в этом случае будет создана пустая база, готовая для того, что б вы могли зайти в нее через Конфигуратор 1С и залить свою ранее сохраненную «Выгрузку».
Saved searches
Use saved searches to filter your results more quickly
Cancel Create saved search
You signed in with another tab or window. Reload to refresh your session. You signed out in another tab or window. Reload to refresh your session. You switched accounts on another tab or window. Reload to refresh your session.
arkuznetsov / cpdb Public
Приложение oscript для копирования баз данных 1C / MS SQL и развертывания на целевой системе.
License
arkuznetsov/cpdb
This commit does not belong to any branch on this repository, and may belong to a fork outside of the repository.
Switch branches/tags
Branches Tags
Could not load branches
Nothing to show
Could not load tags
Nothing to show
Name already in use
A tag already exists with the provided branch name. Many Git commands accept both tag and branch names, so creating this branch may cause unexpected behavior. Are you sure you want to create this branch?
Cancel Create
- Local
- Codespaces
HTTPS GitHub CLI
Use Git or checkout with SVN using the web URL.
Work fast with our official CLI. Learn more about the CLI.
Sign In Required
Please sign in to use Codespaces.
Launching GitHub Desktop
If nothing happens, download GitHub Desktop and try again.
Launching GitHub Desktop
If nothing happens, download GitHub Desktop and try again.
Launching Xcode
If nothing happens, download Xcode and try again.
Launching Visual Studio Code
Your codespace will open once ready.
There was a problem preparing your codespace, please try again.
Latest commit
Git stats
Files
Failed to load latest commit information.
Latest commit message
Commit time
README.md

1C Database copier (cpdb)
Библиотека и приложение для получения информации о базах 1С, копирования баз 1C и развертывания на целевой системе.
- Зависимости
- Команды приложения
- database
- infobase
- file
- yadisk
- nextcloud
- sftp
- batch
- Использование c Jenkins
- Класс РаботаССУБД
- Модуль РаботаСИБ
- Модуль РаботаСФайлами
- Класс РаботаСЯндексДиск
- Класс РаботаСNextCloud
- Класс РаботаСSFTP
- Класс СтруктураХраненияИБ
Требуются следующие библиотеки и инструменты
Типичный сценарий работы
- Сформировать резервную копию базы
- Передать резервную копию на целевую систему
- Через общую папку / С использованием Yandex-Диск
- Возможно разбиение больших файлов на части (используется 7-zip)
- Восстановить резервную копию в новую или существующую базу
- Подключить базу к хранилищу конфигурации
Для подсказки по конкретной команде наберите —help
database — Группа команд работы с СУБД
Общие параметры для команд группы: —srvr — Адрес сервера MS SQL —user — Пользователь сервера —pwd — Пароль пользователя сервера create — Создание базы MS SQL
Параметры: —params — Файлы JSON содержащие значения параметров, могут быть указаны несколько файлов разделенные «;» (параметры командной строки имеют более высокий приоритет) —db — Имя базы для восстановления —db-recovery — Установить модель восстановления (RECOVERY MODEL), возможные значения «FULL», «SIMPLE», «BULK_LOGGED» cpdb database --srvr MySQLName --user sa --pwd 12345 create --db MyDatabase --db-recovery SIMPLEbackup — Создание резервной копии базы MS SQL
Параметры: —params — Файлы JSON содержащие значения параметров, могут быть указаны несколько файлов разделенные «;» (параметры командной строки имеют более высокий приоритет) —db — Имя базы для восстановления —bak-path — Путь к резервной копии cpdb database --srvr MySQLName --user sa --pwd 12345 backup --db MyDatabase --bak-path "d:\MSSQL\Backup\MyDatabase_copy.bak"
restore — Восстановление базы MS SQL из резервной копии
Параметры: —params — Файлы JSON содержащие значения параметров, могут быть указаны несколько файлов разделенные «;» (параметры командной строки имеют более высокий приоритет) —db — Имя базы для восстановления —bak-path — Путь к резервной копии —create-db — Создать базу в случае отсутствия —db-owner — Имя владельца базы после восстановления —compress-db — Включить компрессию страниц таблиц и индексов после восстановления —shrink-db — Сжать файлы данных после восстановления —shrink-log — Сжать файлы журнала транзакций после восстановления —db-path — Путь к каталогу файлов данных базы после восстановления —db-logpath — Путь к каталогу файлов журнала после восстановления —db-recovery — Установить модель восстановления (RECOVERY MODEL), возможные значения «FULL», «SIMPLE», «BULK_LOGGED» —db-changelfn — Изменить логические имена файлов (LFN) базы, в соответствии с именем базы —delsrc — Удалить файл резервной копии после восстановления cpdb database --srvr MyNewSQLServer --user SQLUser --pwd 123456 restore --db MyDatabase_copy --bak-path "d:\data\MyBackUpfile.bak" --create-db --shrink-db --db-owner SQLdbo --db-path "d:\MSSQL\data" --db-logpath "e:\MSSQL\logs" --db-recovery SIMPLE --delsrc
compress — Выполнить компрессию страниц таблиц и индекстов в базе MS SQL
Параметры: —params — Файлы JSON содержащие значения параметров, могут быть указаны несколько файлов разделенные «;» (параметры командной строки имеют более высокий приоритет) —db — Имя базы для восстановления —shrink-db — Сжать базу после выполнения компрессии —shrink-log — Сжать файлы журнала транзакций после восстановления cpdb database --srvr MyNewSQLServer --user SQLUser --pwd 123456 compress --db MyDatabase_copy --shrink-dbdrop — Удаление базы MS SQL
Параметры: —params — Файлы JSON содержащие значения параметров, могут быть указаны несколько файлов разделенные «;» (параметры командной строки имеют более высокий приоритет) —db — Имя базы для восстановления cpdb database --srvr MySQLName --user sa --pwd 12345 drop --db MyDatabasescript — Выполнить скрипты из файла(ов)
Параметры: —params — Файлы JSON содержащие значения параметров, могут быть указаны несколько файлов разделенные «;» (параметры командной строки имеют более высокий приоритет) —files — Файлы SQL, содержащие текст скрипта, могут быть указаны несколько файлов, разделённые «;» —vars — Строка значений переменных (без пробелов) для скриптов SQL в виде «=», разделенные «;» cpdb database --srvr MyNewSQLServer --user SQLUser --pwd 123456 script --params "./JSON/cpdb_env.json" --files "./tools/config_error.sql;./tools/print_message.sql" --vars "varBase=MyDB;message=\"Hello world\""
use $(varBase) go truncate table [dbo].[ConfigSave] go UPDATE SchemaStorage SET Status = 100
PRINT N'$(message)'infobase — Группа команд работы с информационной базой 1С
Общие параметры для команд группы: —v8version — маска версии платформы 1С (например: 8.3.8, 8.3.17.1851) create-srv-ib — Создать информационную базу на сервере 1С
Параметры: —params — Файлы JSON содержащие значения параметров, могут быть указаны несколько файлов разделенные «;» (параметры командной строки имеют более высокий приоритет) —ib-srvr — Адрес кластера серверов 1С ([://][:]) —ib-ref — Имя базы в кластере 1С —err-if-exist — Сообщить об ошибке если ИБ в кластере 1С существует —dbms — Тип сервера СУБД (MSSQLServer ; PostgreSQL; IBMDB2; OracleDatabase) —db-srvr — Адрес/имя сервера СУБД —db-user — Пользователь сервера СУБД» —db-pwd — Пароль пользователя сервера СУБД» —db-name — Имя базы на сервере СУБД (если не указано, используется имя базы 1С)» —sql-offs — Смещение дат на сервере MS SQL (0; 2000 ) —create-db — Создавать базу данных в случае отсутствия —allow-sch-job — Разрешить регламентные задания —allow-lic-dstr — Разрешить выдачу лицензий сервером 1С —cadm-user — Имя администратора кластера —cadm-pwd — Пароль администратора кластера —name-in-list — Имя в списке баз пользователя (если не задано, то ИБ в список не добавляется) —tmplt-path — Путь к шаблону для создания информационной базы (*.cf; *.dt). Если шаблон не указан, то будет создана пустая ИБ cpdb infobase --v8version 8.3.8 create-srv-ib --ib-srvr My1CServer --ib-ref TST_DB_MyDomain --db-srvr MySQLServer --db-user _1CSrvUsr1 --db-pwd p@ssw0rd --db-name TST_DB_MyDomain --createdb --nameinlist "My test base" --errifexist
create-file-ib — Создать файловую информационную базу 1С
Параметры: —params — Файлы JSON содержащие значения параметров, могут быть указаны несколько файлов разделенные «;» (параметры командной строки имеют более высокий приоритет) —ib-path — Путь к каталогу базы 1С —err-if-exist — Сообщить об ошибке если ИБ в кластере 1С существует —name-in-list — Имя в списке баз пользователя (если не задано, то ИБ в список не добавляется) —tmplt-path — Путь к шаблону для создания информационной базы (*.cf; *.dt). Если шаблон не указан, то будет создана пустая ИБ cpdb infobase --v8version 8.3.8 create-file-ib --ib-path "D:\1cbases\My1CBase" --name-in-list "My test base" --err-if-exist
dump — Выгрузить информационную базу в файл
Параметры: —params — Файлы JSON содержащие значения параметров, могут быть указаны несколько файлов разделенные «;» (параметры командной строки имеют более высокий приоритет) —ib-path — Строка подключения к ИБ —ib-user — Пользователь ИБ —ib-pwd — Пароль пользователя ИБ —dt-path — Путь к файлу для выгрузки ИБ —uccode — Ключ разрешения запуска ИБ cpdb infobase --v8version 8.3.8 dump --ib-path "/FD:/data/MyDatabase" --dt-path "d:\data\1Cv8.dt" --ib-user Администратор --ib-pwd 123456 --uccode 1234
restore — Загрузить информационную базу из файла
Параметры: —params — Файлы JSON содержащие значения параметров, могут быть указаны несколько файлов разделенные «;» (параметры командной строки имеют более высокий приоритет) —ib-path — Строка подключения к ИБ —ib-user — Пользователь ИБ —ib-pwd — Пароль пользователя ИБ —dt-path — Путь к файлу для загрузки в ИБ —jobs-count — Количество заданий загрузки файла (для клиент-серверной базы, начиная с версии платформы 8.3.19) —uccode — Ключ разрешения запуска ИБ —delsrc — Удалить файл после загрузки cpdb infobase --v8version 8.3.8 restore --ib-path "/FD:/data/MyDatabase" --dt-path "d:\data\1Cv8.dt" --ib-user Администратор --ib-pwd 123456 --uccode 1234 -delsrc
clearcache — Очистить локальный кэш информационных баз 1С
Параметры: —params — Файлы JSON содержащие значения параметров, могут быть указаны несколько файлов разделенные «;» (параметры командной строки имеют более высокий приоритет) —ib-path — Строка подключения к ИБ (если не указан то удаляются локальные кэши всех информационных баз) cpdb infobase clearcache --ib-path "/FD:/data/MyDatabase"uconstorage — Отключить информационную базу от хранилища конфигурации
Параметры: —params — Файлы JSON содержащие значения параметров, могут быть указаны несколько файлов разделенные «;» (параметры командной строки имеют более высокий приоритет) —ib-path — Строка подключения к ИБ»); —ib-user — Пользователь ИБ»); —ib-pwd — Пароль пользователя ИБ»); —extension — Имя отключаемого расширения конфигурации —uccode — Ключ разрешения запуска ИБ»); cpdb infobase --v8version 8.3.8 uconstorage --ib-path "/FD:/data/MyDatabase" --ib-user Администратор --ib-pwd 123456 --uccode 1234
constorage — Подключить информационую базу к хранилищу конфигурации
Параметры: —params — Файлы JSON содержащие значения параметров, могут быть указаны несколько файлов разделенные «;» (параметры командной строки имеют более высокий приоритет) —ib-path — Строка подключения к ИБ —ib-user — Пользователь ИБ —ib-pwd — Пароль пользователя ИБ —extension — Имя подключаемого расширения конфигурации —storage-path — Адрес хранилища конфигурации —storage-user — Пользователь хранилища конфигурации —storage-pwd — Пароль пользователя хранилища конфигурации —update-ib — Выполнить обновление ИБ (применить полученную из хранилища конфигурацию к ИБ) —uccode — Ключ разрешения запуска ИБ cpdb infobase --v8version 8.3. constorage --ib-path "/FD:/data/MyDatabase" --ib-user Администратор --ib-pwd 123456 --storage-path "tcp://MyServer/MyRepository" --storage-user MyDatabase_usr1 --storage-pwd 123456 --uccode 12348
file — Группа команд работы с файлами
copy — Скопировать/переместить файлы
Параметры: —params — Файлы JSON содержащие значения параметров, могут быть указаны несколько файлов разделенные «;» (параметры командной строки имеют более высокий приоритет) —src — Файл источник —dst — Файл/каталог приемник (если оканчивается на «», то каталог) —move — Выполнить перемещение файлов (удалить источник после копирования) —lastonly — Копирование файлов, измененных не ранее текущей даты Простой пример. Копирование файла в каталог
cpdb file copy --src "d:\MSSQL\Backup\MyDatabase_copy.bak" --dst "N:\NewDestination\" --replace --move
Сложный пример. В каталоге-источнике имеется несколько резервных копий с датой в имени файла. Необходимо скопировать только свежий файл (созданный сегодня). Новое имя файла не должно содержать дату
cpdb file copy --src "d:\MSSQL\Backup\MyDatabase_copy*.bak" --dst "N:\NewDestination\MyDatabase_copy.bak*" --replace --move --lastonly
split — Архивировать файл с разбиением на части указанного размера
Параметры: —params — Файлы JSON содержащие значения параметров, могут быть указаны несколько файлов разделенные «;» (параметры командной строки имеют более высокий приоритет) —src — Путь к исходному локальному файлу для разбиения —arch — Имя файла архива (не обязательный, по умолчанию .7z) —list — Имя файла, списка томов архива (не обязательный, по умолчанию .split) —vol-size — Размер части , , > (по умолчанию 50m) —compress-level — Уровень сжатия частей архива (по умолчанию 0 — не сжимать) —delsrc — Удалить исходный файл после выполнения операции cpdb file split "d:\MSSQL\Backup\MyDatabase_copy.bak" --list "d:\MSSQL\Backup\MyDatabase_copy.split" --vol-size 40m --delsrc
merge — Разархивировать файл
Параметры: —params — Файлы JSON содержащие значения параметров, могут быть указаны несколько файлов разделенные «;» (параметры командной строки имеют более высокий приоритет) —arch — Имя первого файла архива —list — Имя файла, списка файлов архива (параметр -arch игнорируется) —delsrc — Удалить исходные файлы после выполнения операции cpdb file merge --file "d:\MSSQL\Backup\MyDatabase_copy.7z.001" --delsrccpdb file merge --list "d:\MSSQL\Backup\MyDatabase_copy.split" --delsrcmapdrive — Подключить сетевой диск
Параметры: —params — Файлы JSON содержащие значения параметров, могут быть указаны несколько файлов разделенные «;» (параметры командной строки имеют более высокий приоритет) —drive — Имя устройства (буква диска) —res — Путь к подключаемому ресурсу —user — Пользователь для подключения —pwd — Пароль для подключения cpdb file mapdrive --drive N --res "\\MyServer\MyFolder" --user superuser --pwd P@$$w0rd
umapdrive — Отключить сетевой диск
Параметры: —params — Файлы JSON содержащие значения параметров, могут быть указаны несколько файлов разделенные «;» (параметры командной строки имеют более высокий приоритет) —drive — Имя устройства (буква диска) cpdb file umapdrive --drive N
yadisk — Группа команд работы с сервисом Yandex-Диск
Общие параметры для команд группы: —token — Token авторизации put — Помещение файла на Yandex-Диск
Параметры: —params — Файлы JSON содержащие значения параметров, могут быть указаны несколько файлов разделенные «;» (параметры командной строки имеют более высокий приоритет) —file — Путь к локальному файлу для помещения на Yandex-Диск —list — Путь к локальному файлу со списком файлов, которые будут помещены на Yandex-Диск (параметр —file игнорируется) —path — Путь к каталогу на Yandex-Диск, куда помещать загружаемые файлы —replace — Перезаписать файл на Yandex-диске при загрузке —delsrc — Удалить исходные файлы после отправки // Помещает файл "MyDatabase_copy.bak" на Yandex-диск cpdb yadisk --token XXXXXXXXXXXXXXXXXXXXXXXXXXXXX put --file "d:\MSSQL\Backup\MyDatabase_copy.bak" --path "/transfer" --delsrc
// Помещает файлы, указанные в списке "MyDatabase_copy.split" на Yandex-диск cpdb yadisk --token XXXXXXXXXXXXXXXXXXXXXXXXXXXXX put --list "d:\MSSQL\Backup\MyDatabase_copy.split" --path "/transfer" --delsrc
get — Получение файла из Yandex-Диска
Параметры: —params — Файлы JSON содержащие значения параметров, могут быть указаны несколько файлов разделенные «;» (параметры командной строки имеют более высокий приоритет) —path — Путь к локальному каталогу для сохранения загруженных файлов —file — Путь к файлу на Yandex-Диск для загрузки —list — Путь к файлу на Yandex-Диск со списком файлов, которые будут загружены (параметр —file игнорируется) —delsrc — Удалить файлы из Yandex-Диск после получения // Получает файл "MyDatabase_copy.bak" из Yandex-диска cpdb yadisk --token XXXXXXXXXXXXXXXXXXXXXXXXXXXXX get --path "d:\MSSQL\Backup\MyDatabase_copy.bak" --file "/transfer/MyDatabase_copy.bak" --delsrc
// Получает файлы, указанные в списке "MyDatabase_copy.split" из Yandex-диска cpdb yadisk --token XXXXXXXXXXXXXXXXXXXXXXXXXXXXX get --path "d:\MSSQL\Backup\" --list "/transfer/MyDatabase_copy.split" -delsrc
Для получения токена авторизации Яндекс-диска
- Зарегистрировать приложение: https://oauth.yandex.ru/client/new
- Название приложения, например «OScript.YaDisk»
- Платформы «Веб-сервисы»
- Callback URI #1: https://oauth.yandex.ru/verification_code
- Сервис Яндекс.Диск REST API
- Запись в любом месте на Диске
- Чтение всего Диска
- Доступ к информации о Диске
nextcloud — Группа команд работы с сервисом NextCloud
Общие параметры для команд группы: —srvr — Адрес сервиса NextCloud —user — Имя пользователя сервиса NextCloud —pwd — Пароль пользователя сервиса NextCloud put — Помещение файла в сервис NextCloud
Параметры: —params — Файлы JSON содержащие значения параметров, могут быть указаны несколько файлов разделенные «;» (параметры командной строки имеют более высокий приоритет) —file — Путь к локальному файлу для помещения в сервис NextCloud —list — Путь к локальному файлу со списком файлов, которые будут помещены в сервис NextCloud (параметр —file игнорируется) —path — Путь к каталогу в сервисе NextCloud, куда помещать загружаемые файлы —replace — Перезаписать файл в сервисе NextCloud при загрузке —delsrc — Удалить исходные файлы после отправки // Помещает файл "MyDatabase_copy.bak" в сервис NextCloud cpdb nextcloud --service "http://MyNextCloud" --user "admin" --pwd "P@$$w0rd" put --file "d:\MSSQL\Backup\MyDatabase_copy.bak" --path "/transfer" --delsrc
// Помещает файлы, указанные в списке "MyDatabase_copy.split" в сервис NextCloud cpdb nextcloud --service "http://MyNextCloud" --user "admin" --pwd "P@$$w0rd" put --list "d:\MSSQL\Backup\MyDatabase_copy.split" --path "/transfer" --delsrc
get — Получение файла из сервиса NextCloud
Параметры: —params — Файлы JSON содержащие значения параметров, могут быть указаны несколько файлов разделенные «;» (параметры командной строки имеют более высокий приоритет) —path — Путь к локальному каталогу для сохранения загруженных файлов —file — Путь к файлу в сервисе NextCloud для загрузки —list — Путь к файлу в сервисе NextCloud со списком файлов, которые будут загружены (параметр —file игнорируется) —delsrc — Удалить файлы из сервиса NextCloud после получения // Получает файл "MyDatabase_copy.bak" из сервиса NextCloud cpdb nextcloud --service "http://MyNextCloud" --user "admin" --pwd "P@$$w0rd" get --path "d:\MSSQL\Backup\MyDatabase_copy.bak" --file "/transfer/MyDatabase_copy.bak" --delsrc
// Получает файлы, указанные в списке "MyDatabase_copy.split" из сервиса NextCloud cpdb nextcloud --service "http://MyNextCloud" --user "admin" --pwd "P@$$w0rd" get --path "d:\MSSQL\Backup\" --list "/transfer/MyDatabase_copy.split" -delsrc
sftp — Группа команд работы с SFTP-сервером
Общие параметры для команд группы: —srvr — Адрес сервера SFTP в виде : —port — Порт сервера SFTP —user — Имя пользователя сервера SFTP —pwd — Пароль пользователя сервера SFTP, если указан параметр —key-file, то используется как пароль для доступа к закрытому ключу —key-file — Путь к файлу закрытого ключа, если указано, то параметр —pwd интерпретируется как пароль к закрытому ключу put — Помещение файла на сервер SFTP
Параметры: —params — Файлы JSON содержащие значения параметров, могут быть указаны несколько файлов разделенные «;» (параметры командной строки имеют более высокий приоритет) —file — Путь к локальному файлу для помещения на сервер SFTP —list — Путь к локальному файлу со списком файлов, которые будут помещены на сервер SFTP (параметр —file игнорируется) —path — Путь к каталогу на сервере SFTP, куда помещать загружаемые файлы —replace — Перезаписать файл на сервере SFTP при загрузке —delsrc — Удалить исходные файлы после отправки // Помещает файл "MyDatabase_copy.bak" на сервере SFTP cpdb sftp --server "sftp.myServer.org" --port 22 --user "admin" --pwd "P@$$w0rd" put --file "d:\MSSQL\Backup\MyDatabase_copy.bak" --path "/transfer" --delsrc
// Помещает файлы, указанные в списке "MyDatabase_copy.split" на сервере SFTP cpdb sftp --server "sftp.myServer.org" --port 22 --user "admin" --pwd "P@$$w0rd" put --list "d:\MSSQL\Backup\MyDatabase_copy.split" --path "/transfer" --delsrc
get — Получение файла с сервера SFTP
Параметры: —params — Файлы JSON содержащие значения параметров, могут быть указаны несколько файлов разделенные «;» (параметры командной строки имеют более высокий приоритет) —path — Путь к локальному каталогу для сохранения загруженных файлов —file — Путь к файлу на сервере SFTP для загрузки —list — Путь к файлу на сервере SFTP со списком файлов, которые будут загружены (параметр —file игнорируется) —delsrc — Удалить файлы с сервера SFTP после получения // Получает файл "MyDatabase_copy.bak" с сервера SFTP cpdb sftp --server "sftp.myServer.org" --port 22 --user "user" --pwd "P@$$w0rd" get --path "d:\MSSQL\Backup\MyDatabase_copy.bak" --file "/transfer/MyDatabase_copy.bak" --delsrc
// Получает файлы, указанные в списке "MyDatabase_copy.split" с сервера SFTP cpdb sftp --server "sftp.myServer.org" --port 22 --user "user" --pwd "P@$$w0rd" get --path "d:\MSSQL\Backup\" --list "/transfer/MyDatabase_copy.split" -delsrc
batch — Выполнить сценарий
Последовательно выполняет команды указнные в файле JSON
Параметры: — Файлы JSON содержащие команды и значения параметров, могут быть указаны несколько файлов разделенные «»;»» (обработка файлов выполняется в порядке следования) cpdb batch "./rest_TST_DB_MyDomain.json"< "params": <>, "stages": < "Восстановление": < "description": "Восстановление из резервной копии", "command": "database restore", "params": < "srvr": "MySQLServer", "user": "_1CSrvUsr1", "pwd": "p@ssw0rd", "bak-path": "d:\\tmp\\PRD_DB_MyDomain.bak", "db": "TST_DB_MyDomain", "db-owner": "_1CSrvUsr1", "db-path": "D:\\sqldata", "db-logpath": "D:\\sqldata", "db-recovery": "SIMPLE", "db-changelfn": true > >, "Отключение": < "description": "Отключение от хранилища", "command": "infobase uconstorage", "params": < "ib-path": "/SSport1\\TST_DB_MyDomain", "ib-user": "\"1C User\"", "ib-pwd": "p@ssw0rd" > >, "Сжатие": < "description": "Сжатие базы данных", "command": "database compress", "params": < "srvr": "Sport1", "user": "_1CSrvUsr1", "pwd": "p@ssw0rd", "db": "TST_DB_MyDomain", "shrink-db": true > > > >
Использование c Jenkins
В jenkinsfile описан конвейер, выполняющий следующий сценарий:
- Создание резервной копии указанной базы на системе-источнике
- Разбиение резервной копии на части (используется 7-Zip)
- Копирование частей файла на Yandex-Диск (в указанный каталог)
- Получение файла резервной копии из Yandex-Диск на системе-приемнике
- Восстановление указанной базы из резервной копии
- Подключает базу к хранилищу конфигурации
Прграммный интерфейс библиотеки (API)
Подключение = Новый ПодключениеMSSQL("MyServer", "user", "P@ssw0rd); РаботаССУБД = Новый РаботаССУБД(Подключение);
Функция БазаСуществует() — проверяет существование базу на сервере СУБД
Параметры: База Строка имя базы данных Возвращаемое значение: Булево — Истина — база существует
Функция СписокБаз() — получает список баз с сервера СУБД
Параметры: ФильтрБазПоИмени Строка имя базы данных ФильтрПоТаблице Строка имя таблицы базы данных ВключаяСистемные Строка имя таблицы базы данных Возвращаемое значение: Соответствие Из Структура — список баз на сервере СУБД
* Имя - Строка - имя базы данных * Ид - Число - идентификатор базы данных * ИдСоздателя - Число - идентификатор пользователя, создавшего базу * Статус1 - Число - флаги состояния базы данных * Статус2 - Число - флаги состояния базы данных * ДатаСоздания - Дата - дата создания базы данных * РежимСовместимости - Число - версия режима совместимости базы * ФайлДанных - Строка - путь к файлу данных
Функция ТаблицаСуществует() — проверяет существование таблицы в базе на сервере СУБД
Параметры: База Строка имя базы данных Таблица Строка имя таблицы базы данных Возвращаемое значение: Булево — Истина — таблица существует в базе данных
Процедура СоздатьБазуДанных() — создает базу данных
Параметры: База Строка имя базы данных МодельВосстановления Строка модель восстановления (FULL, SIMPLE, BULK_LOGGED) ПутьККаталогу Строка путь к каталогу для размещения файлов базы данных если не указан, то файлы размещаются в каталоге по умолчанию SQL Server Процедура УдалитьБазуДанных() — удаляет базу данных
Параметры: База Строка имя базы данных Процедура ВыполнитьрезервноеКопирование() — выполняет резервное копирование базы
Параметры: База Строка имя базы данных ПутьКРезервнойКопии Строка путь к файлу резервной копии Процедура ВыполнитьВосстановление() — выполняет восстановление базы из резервной копии
Параметры: База Строка имя базы данных ПутьКРезервнойКопии Строка путь к файлу резервной копии ПутьКФайлуДанных Строка путь к файлу данных базы ПутьКФайлуЖурнала Строка путь к файлу журнала транзакций базы СоздаватьБазу Булево Истина — создать базу в случае отсутствия Функция ПолучитьОписание() — получает описание базы данных
Параметры: База Структура описание базы данных Возвращаемое значение: Структура — описание базы данных
* Имя - Строка - имя базы данных (name) * Ид - Число - числовой идентификатор базы (database_id) * ФизическоеИмя - Строка - физическое имя базы (physical_database_name) * Владелец - Строка - пользователь - владелец базы (db owner) * ДатаСоздания - Дата - дата создания базы (create_date) * РежимСовместимости - Число - режим совместимости базы (версия MS SQL) (compatibility_level) * ЯзыковыеУстановки - Строка - используемые языковые установки (collation_name) * РежимДоступа - Булево - режим пользовательского доступа к базе (SINGLE_USER, MULTI_USER) (user_access_desc) * ТолькоДляЧтения - Булево - флаг режима только для чтения (is_read_only) * Состояние - Строка - состояние базы (ONLINE, OFFLINE) (state_desc) * РежимОжидания - Булево - флаг нахождения базы в режиме ожидания (is_in_standby) * РежимИзоляцииСнимков - Булево - флаг использования режима изоляции снимков (snapshot_isolation_state) * РежимФиксированногоЧтенияСнимков - Булево - флаг использования фиксированного чтения снимков (is_read_committed_snapshot_on) * МодельВосстановления - Строка - модель восстановления базы (FULL, SIMPLE, BULK_LOGGED) (recovery_model_desc) * АвтоСозданиеСтатистики - Булево - флаг автоматического создания статистики (is_auto_create_stats_on) * АвтоСозданиеСтатистикиИнкрементально - Булево - флаг автоматического инкрементального создания статистики (is_auto_create_stats_incremental_on) * АвтоОбновлениеСтатистики - Булево - флаг автоматического обновления статистики (is_auto_update_stats_on) * АвтоОбновлениеСтатистикиАсинх - Булево - флаг автоматического асинхронного обновления статистики (is_auto_update_stats_async_on) * ПолнотекстовыйПоиск - Булево - флаг использования полнотекстового поиска (is_fulltext_enabled) * Шифрование - Булево - флаг использования шифрования базы (is_encrypted)
Процедура УстановитьОднопользовательскийРежимБазы() — переводит базу данных в однопользовательский режим
Параметры: База Строка имя базы данных Процедура УстановитьМногопользовательскийРежимБазы() — переводит базу данных в многопользовательский режим
Параметры: База Строка имя базы данных Функция ПолучитьВладельца() — получает текущего владельца базы
Параметры: База Строка имя базы данных Возвращаемое значение: Строка — имя текущего владельца базы
Процедура ИзменитьВладельца() — устанавливает нового владельца базы
Параметры: База Строка имя базы данных ВладелецБазы Строка новый владелец базы Процедура ПолучитьМодельВосстановления() — получает модель восстановления базы (FULL, SIMPLE, BULK_LOGGED)
Параметры: База Строка имя базы данных Возвращаемое значение: Строка — текущая модель восстановления базы
Процедура ИзменитьМодельВосстановления() — устанавливает модель восстановления базы (FULL, SIMPLE, BULK_LOGGED)
Параметры: База Строка имя базы данных МодельВосстановления Строка новая модель восстановления (FULL, SIMPLE, BULK_LOGGED) Функция ПолучитьЛогическоеИмяФайла() — получает логическое имя файла в базе
Параметры: База Строка имя базы данных ТипФайла Строка ROWS — файл базы; LOG — файл журнала транзакций Возвращаемое значение: Строка — логическое имя файла в базе данных
Процедура ИзменитьЛогическоеИмяФайла() — устанавливает новое логическое имя файла базы
Параметры: База Строка имя базы данных Имя Строка логическое имя файла для изменения НовоеИмя Строка новое логическое имя файла Процедура УстановитьЛогическиеИменаФайлов() — устанавливает логические имена файлов в формате
— для файла данных
_log — для файла журнала транзакций
Параметры: База Строка имя базы данных НовоеИмя Строка новое имя файлов, если не указано, то используется имя базы Процедура ВключитьКомпрессию() — включает компрессию данных базы на уровне страниц
Параметры: База Строка имя базы данных Процедура СжатьБазу() — выполняет сжатие базы (shrink)
Параметры: База Строка имя базы данных Процедура СжатьФайлЖурналаТранзакций() — выполняет сжатие файла журнала транзакций (shrink)
Параметры: База Строка имя базы данных Функция ВыполнитьСкрипты() — выполняет указанные скрипты
Параметры: СкриптыВыполнения Строка пути к файлам скриптов, разделенные «;» СтрокаПеременных Строка набор значений переменных в виде «=», разделенные «;» Возвращаемое значение: Строка — результат выполнения скриптов
Функция ВыполнитьЗапрос() — выполняет запрос к СУБД
Параметры: ТекстЗапроса Строка текст исполняемого запроса Разделитель Строка символ — разделитель колонок результата УбратьПробелы Булево Истина — будут убраны выравнивающие пробелы из результата Возвращаемое значение: Строка — результат выполнения запроса
Процедура ВыгрузитьИнформационнуюБазуВФайл() — выполняет выгрузку информационной базы в DT-файл
Параметры: ПараметрыИБ Структура параметры подключения к базе 1С *СтрокаПодключения Строка строка подключения к базе 1С *Пользователь Строка имя пользователя базы 1С *Пароль Строка пароль пользователя базы 1С ПутьКФайлу Строка путь к DT-файлу для выгрузки базы 1С ИспользуемаяВерсияПлатформы Строка маска версии 1С КлючРазрешения Строка ключ разрешения входа в заблоrированную серверную базу 1С (/UC) Процедура ЗагрузитьИнформационнуюБазуИзФайла() — выполняет загрузку информационной базы из DT-файла
Параметры: ПараметрыИБ Структура параметры подключения к базе 1С *СтрокаПодключения Строка строка подключения к базе 1С *Пользователь Строка имя пользователя базы 1С *Пароль Строка пароль пользователя базы 1С ПутьКФайлу Строка путь к DT-файлу для загрузки в базу 1С КоличествоЗаданий Число количество заданий загрузки файла (для клиент-серверной базы, начиная с версии платформы 8.3.19)) ИспользуемаяВерсияПлатформы Строка маска версии 1С КлючРазрешения Строка ключ разрешения входа в заблоrированную серверную базу 1С (/UC) Процедура ОчиститьЛокальныйКэшИнформационнойБазы() — выполняет очистку локального кэша информационной базы 1С
Параметры: СтрокаПодключения Строка строка подключения к базе 1С Процедура ОчиститьВсеЛокальныеКэшиИнформационныхБаз() — выполняет очистку всех локальных кэшей информационных баз 1С
Параметры: нет Процедура ОтключитьОтХранилища() — выполняет отключение информационной базы от хранилища конфигурации
Параметры: ПараметрыИБ Структура параметры подключения к базе 1С *СтрокаПодключения Строка строка подключения к базе 1С *Пользователь Строка имя пользователя базы 1С *Пароль Строка пароль пользователя базы 1С ИспользуемаяВерсияПлатформы Строка маска версии 1С ИмяРасширения Строка имя расширения, отключаемого от хранилища (если не указано, отключается основная конфигурация) КлючРазрешения Строка ключ разрешения входа в заблоrированную серверную базу 1С (/UC) Процедура ПодключитьКХранилищу() — выполняет подключение информационной базы к хранилищу конфигурации
Параметры: ПараметрыИБ Структура параметры подключения к базе 1С *СтрокаПодключения Строка строка подключения к базе 1С *Пользователь Строка имя пользователя базы 1С *Пароль Строка пароль пользователя базы 1С ПараметрыХранилища Структура параметры подключения к хранилищу конфигурации *Адрес Строка адрес хранилища конфигурации *Пользователь Строка имя пользователя хранилища конфигурации *Пароль Строка пароль пользователя хранилища конфигурации ИспользуемаяВерсияПлатформы Строка маска версии 1С ИмяРасширения Строка имя расширения, отключаемого от хранилища (если не указано, отключается основная конфигурация) ОбновитьИБ Булево Истина — после обновления обновить конфигурацию базы данных КлючРазрешения Строка ключ разрешения входа в заблоrированную серверную базу 1С (/UC) Процедура СоздатьСервернуюБазу() — создание серверной информационной базы 1С
Параметры: Параметры1С Структура параметры создания базы 1С *Сервер1С Строка адрес кластера серверов 1С ([://][:]) *ИмяИБ Строка имя информационной базы на сервере 1С *РазрешитьВыдачуЛицензий Булево Истина — разрешить выдачу лицензий сервером 1С (по умолчанию: Истина) *РазрешитьРегЗадания Булево Истина — разрешить запуск рег. заданий (по умолчанию: Ложь) ПараметрыСУБД Структура параметры подключения к СУБД *ТипСУБД Строка тип сервера СУБД («MSSQLServer» , «PostgreSQL», «IBMDB2», «OracleDatabase») *СерверСУБД Строка адрес сервера СУБД *ПользовательСУБД Строка пользователь сервера СУБД *ПарольСУБД Строка пароль пользователя сервера СУБД *ИмяБД Строка имя базы на сервере СУБД (если не указано будет использовано имя ИБ 1С) *СмещениеДат Число смещение дат на сервере MS SQL (0; 2000 ) *СоздаватьБД Булево Истина — будет создана база на сервере СУБД в случае отсутствия АвторизацияВКластере Структура параметры авторизации в кластере 1С *Имя Строка имя администратора кластера 1С *Пароль Строка пароль администратора кластера 1С ИспользуемаяВерсияПлатформы Строка маска версии 1С ОшибкаЕслиСуществует Булево Истина — вызвать исключение если ИБ в кластере 1С существует (по умолчанию: Ложь) ПутьКШаблону Строка путь к шаблону для создания информационной базы (*.cf; *.dt). Если шаблон не указан, то будет создана пустая ИБ ИмяВСпискеБаз Строка имя в списке баз пользователя (если не задано, то ИБ в список не добавляется) Процедура СоздатьФайловуюБазу() — создание файловой информационной базы 1С
Параметры: ПутьКБазе Строка путь к каталогу базы 1С ИспользуемаяВерсияПлатформы Строка маска версии 1С ПутьКШаблону Строка путь к шаблону для создания информационной базы (*.cf; *.dt). Если шаблон не указан, то будет создана пустая ИБ ИмяВСпискеБаз Строка имя в списке баз пользователя (если не задано, то ИБ в список не добавляется) Процедура КомандаСистемыКопироватьФайл() — выполняет копирование/перемещение указанных файлов с использованием команд системы (xcopy)
Параметры: Источник Строка копируемые файлы Приемник Строка назначение копирования, каталог или файл Перемещение Булево выполнить перемещение файлов (удалить источник после копирования) ТолькоСегодня Булево копирование файлов, измененных не ранее текущей даты (параметр /D для xcopy) Процедура КомандаСистемыУдалитьФайл() — выполняет удаление указанных файлов с использованием команды системы (del)
Параметры: ПутьКФайлу Строка путь к удаляемому файлу ИсключениеПриОшибке Булево Истина — вызывать исключение при ошибке удаления Функция ПрочитатьСписокФайлов() — читает список файлов из файла
Параметры: ПутьКСписку Строка путь к удаляемому файлу ДобавитьПутьКИсходномуФайлу Булево Истина — при чтении добавлять к результату путь к исходному файлу списка ДобавитьИсходныйФайл Булево Истина — добавить исходный файл в список Возвращаемое значение: Массив из Строка — прочитанный список файлов
Процедура ЗапаковатьВАрхив() — выполняет архиваци указанного файла с разбитием на части указанного размера
Параметры: ПутьКФайлу Строка путь к файлу, который будет архивироваться ИмяАрхива Строка имя файла-архива ИмяСпискаФайлов Строка имя файла-списка (содержащего все чати архива) РазмерТома Строка размер части > (по умолчанию 50m) СтепеньСжатия Число уровень сжатия частей архива (по умолчанию 0 — не сжимать) УдалитьИсточник Булево Истина — после архивации исходный файл будет удален Процедура РаспаковатьАрхив() — выполняет выполняет распаковку архива
Параметры: ПутьКАрхиву Строка путь к файлу архива, который будет распаковываться ЭтоСписокФайлов Булево Истина — передан список файлов; Ложь — передан первый том архива УдалитьИсточник Булево Истина — после распаковки исходный файл будет удален Процедура ПодключитьДиск() — подключает указанный сетевой диск
Параметры: ИмяУстройства Строка имя (буква) подключаемого диска ИмяРесурса Строка сетевой путь к подключаемому ресурсу Пользователь Строка пользователь от имени которого выполняется подключение ПарольПользователя Строка пароль пользователя от имени которого выполняется подключение Процедура ОтключитьДиск() — отключает указанный сетевой диск
Параметры: ИмяУстройства Строка имя (буква) отключаемого диска РаботаСЯндексДиск = Новый РаботаСЯндексДиск(Токен>);
Параметры: _Токен Строка токен авторизации Yandex-диска Функция Соединение() — возвращает соединение с Yandex-диском
Параметры: нет Возвращаемое значение: ЯндексДиск — соединение с Yandex-диском
Процедура УстановитьПараметрыСоединения() — создает соединение с Yandex-диском с указанными параметрами
Параметры: _Токен Строка токен авторизации Yandex-диска Процедура СоздатьКаталог() — создает каталог на Yandex-диске
Параметры: ЦелевойПуть Строка путь на yandex-диске к создаваемому каталогу Процедура ОтправитьФайл() — отправляет файл на Yandex-Диск
Параметры: ПутьКФайлу Строка путь к отправляемому файлу ЦелевойПуть Строка путь на yandex-диске, куда будет загружен файл Перезаписывать Булево перезаписать файл на Яндекс-диске при загрузке Функция ПолучитьФайл() — получает файл из Yandex-Диска
Параметры: ПутьКФайлу Строка расположение файла на yandex-диске ЦелевойПуть Строка путь, куда будет загружен файл УдалитьИсточник Булево Истина — удалить файл после загрузки Возвращаемое значение: Число — код возврата команды
Функция Существует() — проверка существования файла / каталога на Yandex-Диске
Не реализовано
Параметры: ПутьКФайлу Строка расположение файла на yandex-диске Возвращаемое значение: Булево — Истина — файл / каталог существует
Процедура Удалить() — удаляет файл из Yandex-Диска
Параметры: ПутьКФайлу Строка расположение файла на yandex-диске РаботаСNextCloud = Новый РаботаСNextCloud("http://MyNextCloudServer:8080", "user", "P@ssw0rd");
Функция Адрес() — возвращает адрес сервера NextCloud
Возвращаемое значение: Строка — адрес сервера NextCloud
Функция Пользователь() — возвращает имя пользователя сервера NextCloud
Возвращаемое значение: Строка — имя пользователя сервера NextCloud
Функция Соединение() — возвращает соединение с сервером NextCloud
Возвращаемое значение: ПодключениеNextCloud — соединение с сервером NextCloud
Процедура УстановитьПараметрыСоединения() — создает соединение с сервером NextCloud с указанными параметрами
Параметры: _Адрес Строка адрес сервера NextCloud _Пользователь Строка имя пользователя сервера NextCloud Пароль Строка пароль пользователя сервера NextCloud Процедура СоздатьКаталог() — создает каталог в сервисе NextCloud
Параметры: ЦелевойПуть Строка путь к создаваемому каталогу Процедура ОтправитьФайл() — отправляет файл в сервис NextCloud
Параметры: ПутьКФайлу Строка путь к отправляемому файлу ЦелевойПуть Строка путь к каталогу в сервисе NextCloud, куда будет загружен файл Перезаписывать Булево перезаписать файл в сервисе NextCloud при загрузке Функция ПолучитьФайл() — получает файл из сервиса NextCloud
Параметры: ПутьКФайлу Строка расположение файла на сервисе NextCloud ЦелевойКаталог Строка путь к каталогу, куда будет загружен файл УдалитьИсточник Булево Истина — удалить файл после загрузки Возвращаемое значение: Строка — путь к полученному файлу
Функция Существует() — проверяет существование файла / каталога в сервиса NextCloud
Параметры: ПутьНаДиске Строка расположение файла на сервисе NextCloud Возвращаемое значение: Булево — Истина — файл / каталог существует
Процедура Удалить() — удаляет файл из сервиса NextCloud
Параметры: ПутьНаДиске Строка расположение файла на сервисе NextCloud РаботаСSFTP = Новый РаботаСSFTP("MySFTPServer:2222", "user", "P@ssw0rd");
Функция Адрес() — возвращает адрес сервера SSH
Возвращаемое значение: Строка — адрес сервера SSH
Функция Пользователь() — возвращает имя пользователя сервера SSH
Возвращаемое значение: Строка — имя пользователя сервера SSH
Функция Соединение() — возвращает соединение с сервером SSH
Возвращаемое значение: КлиентSSH — соединение с сервером SSH
Процедура УстановитьПараметрыСоединения() — создает соединение с сервером SSH с указанными параметрами
Параметры: _Адрес Строка адрес сервера SSH _Пользователь Строка имя пользователя сервера SSH ПутьККлючу Строка путь к файлу закрытого ключа сервера SSH Процедура СоздатьКаталог() — каталог на сервере SFTP
Параметры: ЦелевойПуть Строка путь к создаваемому каталогу Процедура ОтправитьФайл() — отправляет файл в сервис NextCloud
Параметры: ПутьКФайлу Строка путь к отправляемому файлу ЦелевойПуть Строка путь к каталогу на сервере SFTP, куда будет загружен файл Перезаписывать Булево перезаписать файл на сервере SFTP при загрузке Функция ПолучитьФайл() — получает файл с сервера SFTP
Параметры: ПутьКФайлу Строка расположение файла на сервере SFTP ЦелевойКаталог Строка путь к каталогу, куда будет загружен файл УдалитьИсточник Булево Истина — удалить файл после загрузки Возвращаемое значение: Строка — путь к полученному файлу
Функция Существует() — проверяет существование файла / каталога на сервере SFTP
Параметры: ПутьНаДиске Строка расположение файла на сервере SFTP Возвращаемое значение: Булево — Истина — файл / каталог существует
Процедура УдалитьФайл() — удаляет файл с сервера SFTP
Параметры: ПутьНаДиске Строка расположение файла на сервере SFTP Процедура УдалитьКаталог() — удаляет каталог с сервера SFTP
Параметры: ПутьНаДиске Строка расположение каталога на сервере SFTP СтруктураИБ = Новый СтруктураХраненияИБ();
Функция ВерсияФорматаКонфигурации() — возвращает версию формата конфигурации
Параметры: нет Возвращаемое значение: Структура — информация о версии формата конфигурации
* Версия - Число - номер версии формата конфигурации * ТребуемаяВерсияПлатформы - Строка - минимальная версия платформы 1С
Функция ОписаниеКонфигурации() — возвращает описание конфигурации
Параметры: нет Возвращаемое значение: Структура — описание конфигурации
* Имя - Строка - имя конфигурации * Синоним - Строка - синоним конфигурации * Версия - Строка - версия конфигурации * РежимСовместимости - Строка - версия режима совместимости конфигурации * КраткаяИнформация - Строка - краткая информация о конфигурации * ПодробнаяИнформация - Строка - подробная информация о конфигурации * Поставщик - Строка - поставщик конфигурации * АвторскиеПрава - Строка - данные об авторских правах * АдресИнформацииОПоставщике - Строка - адрес сайта с информацией о поставщике * АдресИнформацииОКонфигурации - Строка - адрес сайта с информацией о конфигурации * АдресКаталогаОбновлений - Строка - адрес сайта с каталогом обновлений
Функция ОписаниеМетаданныхОбъектаБД1С() — возвращает описание метаданных 1С для объекта СУБД по его имени
Параметры: ИмяОбъекта Строка имя таблицы или поля таблицы СУБД Возвращаемое значение: Структура — описание метаданных 1С по имени объекта СУБД
* Владелец - Структура - структура описания объекта владельца * Тип - Строка - тип объекта или коллекция (например: Справочник, Документ, ТабличнаяЧасть, Поле) * ТипАнгл - Строка - тип объекта или коллекция на английском (например: Reference, Document, TabularSection, Field) * Назначение - Строка - назначение таблицы БД (например: Основная, Итоги, Обороты) * Имя - Строка - имя объекта в БД (Префикс + Индекс) * Префикс - Строка - префикс объекта (например: Reference, Document, VT, Fld)) * Индекс - Число - числовой индекс объекта * Суффикс - Строка - дополнительный суффикс имени объекта (например: "_RRef") * Ид - Строка - UUID объекта 1С * ИмяМетаданных - Строка - имя метаданных 1С * ПолноеИмяМетаданных - Строка - имя метаданных 1С
Функция ОписаниеМетаданныхОбъектовБД1С() — возвращает описание метаданных 1С для таблиц и полей таблиц СУБД
Параметры: ДобавлятьКолонки Булево Истина — будет добавлена информация для колонок таблиц Возвращаемое значение: Соответствие — соответствия имен таблиц СУБД и полных имен метаданных 1С описаниям объектов метаданных (см. ОписаниеМетаданныхОбъектаБД1С)
Функция ЗанимаемоеМесто() — возвращает описание занимаеиого места в базе MS SQL Server
Параметры: нет Возвращаемое значение: Структура — описание занимаего места
* РазмерБазы - Число - размер текущей базы данных в байтах, включает файлы данных и журналов * Свободно - Число - место в базе данных, не зарезервированное для объектов базы данных * Зарезервировано - Число - общий объем, выделенный объектам в базе данных * Данные - Число - зарезервированный объем, используемый данными * Индексы - Число - зарезервированный объем, используемый индексами * НеИспользуется - Число - объем, зарезервированный для объектов в базе данных, но пока не используемый * ЖурналВсего - Число - полный объем журнала транзакций * ЖурналИспользуется - Число - используемый объем журнала транзакций
Функция ПоказателиИспользованияТаблицБазы() — возвращает список таблиц в базе MS SQL Server и их показатели использования
Параметры: ФильтрТаблицПоИмени Строка фильтр имен таблиц в формате для оператора «LIKE» СтатистикаОпераций Булево Истина — в результат будет включена статистика по операциям с таблицами (для больших баз — может занять много времени) Возвращаемое значение: Массив из Структура — таблицы и показатели использования
* Таблица - Строка - имя таблицы * КоличествоСтрок - Число - количество строк в таблице * ВсегоЗанято - Число - общий объем заниаемого места (байт) * Используется - Число - объем, используемый данными (байт) * НеИспользуется - Число - не используемый объем (байт) * ОперацийЧтения - Число - количество операций чтения (read) * ОперацийВыборки - Число - количество операций выборки (select) * ОперацийСканирования - Число - количество операций сканирования (scan) * ОперацийПоиска - Число - количество операций поиска (seek) * ОперацийЗаписи - Число - количество операций записи (write)
Для тестирования подключения / отключения сетевого диска требуются дополнительные настройки.
В реестре в ключе HKEY_LOCAL_MACHINE\SYSTEM\CurrentControlSet\Services\WebClient\Parameters указать:
BasicAuthLevel : 0x00000002 (2)
В реестре в ключе HKEY_LOCAL_MACHINE\System\CurrentControlSet\Control\Session Manager указать:
ProtectionMode : 0x00000000 (0)
Для тестирования работы с базами MS SQL пользователю, под которым выполняется вход на сервер необходимо назначить роль sysadmin
Запуск и остановка окружения выполняются автоматически.
- Запись в любом месте на Диске