Setting up Windows Server Shared Folder
Moving a large amount of data into Microsoft SQL Server is most performant by bulk loading via a shared folder. This document describes the steps required to setup a shared folder in Windows Server 2019.
PREREQUISITE:
You can also install a Microsoft SQL Agent to improve INSERT performance.
Example Specifications:
- SQL Windows Server : Windows Server 2019 Standard (Desktop Experience)
- MI Application 6.2.0: Debian 10 / Ubuntu 18.04 / CentOS 7 / CentOS 8
Open Shared folder on Windows Server
- Right click on Shared Folder → Properties → Sharing tab → Share
2. Add user for Shared folder
data:image/s3,"s3://crabby-images/1af3b/1af3b0fb186eea79e994eb8a410c49058d4be2e3" alt=""
3. Turn on Network Discovery for all public networks
data:image/s3,"s3://crabby-images/82ec6/82ec655497a1df9c0f93a05c9667696c03ffc5c4" alt=""
data:image/s3,"s3://crabby-images/895ef/895efe2313f52f320ab65b0e915a8e22733ea861" alt=""
4. Make sure that SMB ports (139 and 445) on Windows Server is opened and you have access to SMB from Linux Instance
data:image/s3,"s3://crabby-images/6a46d/6a46d12955aa74dc6de6c610acdd4e9cc714193c" alt=""
Mount Shared folder from Windows to Linux instance
Make sure that your Linux Instance have access to Windows Server.
- Create Shared folder
$ mkdir -p /opt/mi/shared
2. Install required package
Via Debian or similar OS:
$ apt-get install cifs-utils
Via RedHat or similar OS:
$ yum install cifs-utils
3. Mount Shared folder from Windows Server to Linux Instance
root@mi61:/opt/mi# sudo mount -t cifs //192.168.33.59/mi-shared /opt/mi/shared -o user=Administrator
Password for Administrator@//192.168.33.59/mi-shared: *******
Where:
- 192.168.33.59 - IP of Windows Server with opened Shared Folder
- mi-shared - Opened folder on Windows Server
- /opt/mi/shared - folder for mount on Linux Instance
- user=Administrator - Windows Server user for access to shared folder
4. Confirm that mounting was successful
data:image/s3,"s3://crabby-images/02699/0269900674d2bf80ddcb34688984d2bfc208f07d" alt=""
Mount Shared folder to Docker Container
To add the shared folder to Docker container, add a mount point from Linux Instance to Docker container.
1. Edit docker-compose yml file of docker container
$ vi /opt/mi/config/deployment/docker-compose.dataprocessor.yml
2. Add mount point
data:image/s3,"s3://crabby-images/2b179/2b1791744fef2304dcbee28e1ce171624027a0a9" alt=""
Where:
- /opt/mi/shared:/opt/mi/shared:rw - shared folder on Linux Instance and inside Docker container, with read/write permissions
3. Launch the dataprocessor via root user
$ vi /opt/mi/config/deployment/credentials/dataprocessor.env
And set variable USER=root
data:image/s3,"s3://crabby-images/f9277/f92778779bc506dcdefedb2bed3c8d7a5a4c0de9" alt=""
Variable USER=root need to set possibility for running dataprocessor by root user with access to shared folder
4. Recreate the Docker container
$ mi-control up -d dataprocessor
Recreating mi_dataprocessor_1 ... done
5. Check Shared folder inside docker container
$ docker exec -it mi_dataprocessor_1 bash
$ cd /opt/mi/shared
$ touch file_from_container