diff --git a/_data/product_version.yml b/_data/product_version.yml index 4996766..553f70e 100644 --- a/_data/product_version.yml +++ b/_data/product_version.yml @@ -1,3 +1,4 @@ version_info_list: - latest version + - 2.4.1 - 2.2.19 \ No newline at end of file diff --git a/selfhosting-v2.4.1/DLSonLinux.md b/selfhosting-v2.4.1/DLSonLinux.md new file mode 100644 index 0000000..a053053 --- /dev/null +++ b/selfhosting-v2.4.1/DLSonLinux.md @@ -0,0 +1,142 @@ +--- +layout: default-layout +title: Install Dynamsoft Dynamsoft License Server on Linux +keywords: Install, Dynamsoft License Server, Linux +description: Steps and information about how to install Dynamsoft Dynamsoft License Server on Linux +breadcrumbText: Install DLS on Linux +needAutoGenerateSidebar: true +--- + +# Install Dynamsoft License Server on Linux + +## Example Environment + +* CPU: 2 Core +* Memory:2 GB +* Disk Space + * System: 8 GB + * Data: 20 GB +* OS:CentOs7.4 + +## Installation + +The following shows all the commands and steps required to set up the Dynamsoft License Server + + + +### Download the Dynamsoft License Server v2.4.1 installer, or just copy it over to a proper location + +``` shell +cd /a-proper-location +wget https://tst.dynamsoft.com/public/download/dls/2.4.1/dynamsoft_dls-linux_x64-v2.4.1.tar.gz +``` + +### Unzip and start the Dynamsoft License Server + +``` shell +# Unzip the installer +tar zxvf dynamsoft_dls-linux_x64-v2.4.1.tar.gz +# Set permissions +chmod -R 755 ./dls-linux +# Start the server +cd ./dls-linux +./startup.sh +``` + +If you use Ubuntu, to start the server, try the following instead. + +``` shell +# [optional] Install net-tools if it is not available (Ubuntu 20.04 may not come with it) +sudo apt install net-tools +./startup.sh +``` + +### Check the status to make sure the server is up + +``` shell +ps -ef |grep dynamsoft +``` + +Now, if you visit [http://127.0.0.1:48080/page/index.html#/](http://127.0.0.1:48080/page/index.html#/) in the browser, you should be able to see the management portal of the Dynamsoft License Server. + +> You can edit startup.sh to change the listening ports. + +Upon the first visit, you will be asked to set an admin password. A few things to note: + +> 1. The default password is empty; +> 2. The user name is admin and it can not be changed; +> 3. **Currently, there isn't a way to retrieve the password should it get lost. Therefore, please keep the password secure**. + +After that, you will land on the home page where you can find the UUID of this DLS . + +> This UUID is require when [activating your licenses]({{site.selfhosted}}index.html#activate-the-license). + +![DLS-HomePage-001]({{site.assets}}imgs/dls-homepage.png) + +If you see the above page, DLS is installed correctly and is ready to process requests. In order to better integrate with your original service, and make the service more secure on the Internet, the next step is to configure the network environment - (set up a reverse proxy) - for it with the help of `nginx`. See [Configure Reverse Proxy Using Nginx]({{site.selfhosted}}configurereverseproxyusingnginx.html) on how to redirect requests for `https://www.yoursite.com/dls/*` to `https://127.0.0.1:48080/*`. + +> NOTE +> +> 1. "proxy" and "https" are only required if you use one of the following products: +> +> * SDKs for Javascript without a local service (like Dynamsoft BarcodeReader Javascript Edition). +> * SDKs for iOS (unless the user makes an exception for the application). ![dls iOS allow http]({{site.assets}}imgs/dls-iOS-allow-http.png) (Reference: https://stackoverflow.com/questions/31254725/transport-security-has-blocked-a-cleartext-http#answer-33712228) +> +> If "proxy" and "https" are not configured, please use `http://ip:port/` in the following steps. +> +> 2. For Docker Users +> +> DLS binds the physical information of a machine. After DLS runs for the first time, you can not change the host machine. Since it is difficult to ensure that a service is deployed on a fixed physical machine on k8s, we do not recommend deploying DLS on k8s. +> +> Some data in the DLS installation directory requires persistent storage. One way is to use the container like a virtual machine. If `docker stop ` was executed, use `docker restart ` to restart. +> Another way is to use [volume mounts](https://docs.docker.com/get-started/05_persisting_data/) or [bind mounts](https://docs.docker.com/get-started/06_bind_mounts/). + +## Configuration + +With the above steps, DLS will be listening on requests sent to this URL `https://www.yoursite.com/dls/`. You can set up another DLS on another machine as the standby server just in case the main server is temporarily unavailable due to network and other reasons. + +### Configure a Standby DLS + +For maximum up time, a standby DLS is necessary. Assume you have installed two copies of DLS, the following are the steps to configure them + +* Find the file `dls.json.sample` in the DLS directory, copy and rename it to `dls.json` + +* In the configuration, there are two settings: "serverMode" and "servers". We only need to change "servers". It accepts two values, the first specifies the main DLS URL and the second, the standby URL. + + * For the main DLS: `"servers": ["self", "https://standby.yoursite.com/dls/"]` + + * For the standby DLS: `"servers": ["https://www.yoursite.com/dls/", "self"]` + +> NOTE that you need to configure both the main DLS and the standby DLS separately. + +### Configure Server URLs + +In order for the license client to know where to find DLS, the server URLs need to be embedded in the license string. + +By default, when you first import a license and create a project, the license string for the project will already contain a server URL which is simply the host of the website. For example, if DLS is being visited like shown in the following image, then the license string will contain server URL as `http://127.0.0.1:48080/`. + +![dls-url-001]({{site.assets}}imgs/dls-url-config-001.png) + +Since the client devices may visit the DLS through a proxy, the automatically detected URL can be incorrect. We can click the button "Set Server URL" and correct it: + +![dls-url-002]({{site.assets}}imgs/dls-url-config-002.png) + +Input the actual server URLs and save: + +![dls-url-003]({{site.assets}}imgs/dls-url-config-003.png) + +Once saved, all license strings will be updated to contain the server URLs. diff --git a/selfhosting-v2.4.1/DLSonWindows.md b/selfhosting-v2.4.1/DLSonWindows.md new file mode 100644 index 0000000..ad40479 --- /dev/null +++ b/selfhosting-v2.4.1/DLSonWindows.md @@ -0,0 +1,126 @@ +--- +layout: default-layout +title: Install Dynamsoft Dynamsoft License Server on Windows +keywords: Install, Dynamsoft License Server, Windows +description: Steps and information about how to install Dynamsoft Dynamsoft License Server on Windows +breadcrumbText: Install DLS on Windows +needAutoGenerateSidebar: true +--- + +# Install Dynamsoft License Server on Windows Server + +## Example Environment + +* CPU: Intel Core 2 Duo or AMD Athlon 64 X2 5600+ +* Memory: 2G +* OS: Windows Server 2016 +* Disk Space + * System: 30 GB + * Data: 20 GB + +## Installation + +### Run DLS as a service + +* Download the installer from [Dynamsoft-Licensing-Tracking-Server v2.4.1](https://tst.dynamsoft.com/public/download/dls/2.4.1/dynamsoft_dls-win_x64-v2.4.1.zip) and unzip it to a proper location. In our case, it's unzipped to **"E:\dynamsoft_dls-win_x64-v2.4.1"**. + +* Download [NSSM](https://nssm.cc/ci/nssm-2.24-101-g897c7ad.zip) and unzip, in our case, it's unzipped to **"E:\nssm-2.24"**. + +* Open cmd, navigate to the directory **"E:\nssm-2.24\win64"** and run the following command + +```cmd +nssm install dynamsoft-dls +``` + +* A GUI will open, fill the parameters for the application like this (change the values according to where you put the files, and change ports if ports are occupied) + + * **Path**: `E:\dynamsoft_dls-win_x64-v2.4.1\win\bin\dynamsoftdlsx.exe` + * **Startup directory**: `E:\dynamsoft_dls-win_x64-v2.4.1` + * **Arguments**: `".\win\jre\bin\dynamsoftdls" -Duser.language=en -Duser.region=CA -Djavax.net.ssl.trustStoreType=WINDOWS-ROOT --add-opens java.base/jdk.internal.loader=ALL-UNNAMED -jar ".\dls-2.4.1.jar" --server.port=48080 --data.port=30201` + +![nssm-001]({{site.assets}}imgs/nssm-001.png) + +* Switch to the last tab "Hooks" and choose "Application exit" as the Event and specify the parameter as + + * **Command**: `E:\dynamsoft_dls-win_x64-v2.4.1\shutdown.bat` + +![nssm-002]({{site.assets}}imgs/nssm-002.png) + +* Press the button "Install Service" and you should be able to find dynamsoft-dls as one of the services in the services GUI or in **Task Manager -> Service**. If it is not started, start it. + +> NOTE +> +> It usually takes a few seconds for the service to start. Sometimes it might take longer. + +### Test the service + +Once the server is running, you can test it via the URL [http://127.0.0.1:48080/page/index.html](http://127.0.0.1:48080/page/index.html). + +> If you changed the port during installation, you should use that port instead. + +Upon the first visit, you will be asked to set an admin password. A few things to note: + +> 1. The default password is empty; +> 2. The user name is admin and it can not be changed; +> 3. **Currently, there isn't a way to retrieve the password should it get lost. Therefore, please keep the password secure**. + +After that, you will land on the home page where you can find the UUID of this DLS . + +> This UUID is required when [activating your licenses]({{site.selfhosted}}index.html#activate-the-license). + +![DLS-HomePage-001]({{site.assets}}imgs/dls-homepage.png) + +If the above page shows up, then the server is installed correctly and is ready to process requests. In order to better integrate with your original service, and make the service more secure on the Internet, the next step is to configure the network environment - (set up a reverse proxy) - for it with the help of `IIS` . See [Configure Reverse Proxy Using IIS]({{site.selfhosted}}configurereverseproxyusingiis.html) on how to redirect requests sent to `https://www.yoursite.com/dls/*` to `https://127.0.0.1:48080/*`. + +> Notes +> +> 1. About `PsExec64.exe` +> +> `PsExec64.exe` is a powerful tool on windows, but it is also considered risky by antivirus software. +> +> Normally, DLS does not allow "start as administrator". However, in order to meet some specific needs, we allow "administrator" to create another user to start DLS, which requires the use of `PsExec64.exe`. +> +> When using `NSSM` as described in this article, the startup user is `Local System Account`, which means you can safely remove `win/bin/PsExec64.exe`. +> +> 2. "proxy" and "https" are only required if you use one of the following products: +> +> * SDKs for Javascript without a local service (like Dynamsoft BarcodeReader Javascript Edition). +> * SDKs for iOS (unless the user makes an exception for the application). ![dls iOS allow http]({{site.assets}}imgs/dls-iOS-allow-http.png) (Reference: https://stackoverflow.com/questions/31254725/transport-security-has-blocked-a-cleartext-http#answer-33712228) +> +> If "proxy" and "https" are not configured, please use `http://ip:port/` in the following steps. + +## Configuration + +With the above steps, DLS will be listening on requests sent to this URL "https://www.yoursite.com/dls/". You can set up another DLS on another machine as the standby server just in case the main server is temporarily unavailable due to network and other reasons. + +### Configure a Standby DLS + +For maximum up time, a standby DLS is necessary. Assume you have installed two copies of DLS, the following are the steps to configure them + +* Find the file `dls.json.sample` in the DLS directory, copy and rename it to `dls.json` + +* In the configuration, there are two settings: "serverMode" and "servers". We only need to change "servers". It accepts two values, the first specifies the main DLS URL and the second, the standby URL. + + * For the main DLS: `"servers": ["self", "https://standby.yoursite.com/dls/"]` + + * For the standby DLS: `"servers": ["https://www.yoursite.com/dls/", "self"]` + +> NOTE that you need to configure both the main DLS and the standby DLS separately. + +### Configure Server URLs + +In order for the license client to know where to find DLS, the server URLs need to be embedded in the license string. + +By default, when you first import a license and create a project, the license string for the project will already contain a server URL which is simply the host of the website. For example, if DLS is being visited like shown in the following image, then the license string will contain server URL as `http://127.0.0.1:48080/`. + +![dls-url-001]({{site.assets}}imgs/dls-url-config-001.png) + +Since the client devices may visit the DLS through a proxy, the automatically detected URL can be incorrect. We can click the button "Set Server URL" and correct it: + +![dls-url-002]({{site.assets}}imgs/dls-url-config-002.png) + +Input the actual server URLs and save: + +![dls-url-003]({{site.assets}}imgs/dls-url-config-003.png) + +Once saved, all license strings will be updated to contain the server URLs. diff --git a/selfhosting/DLSonLinux.md b/selfhosting/DLSonLinux.md index a053053..067df2d 100644 --- a/selfhosting/DLSonLinux.md +++ b/selfhosting/DLSonLinux.md @@ -38,18 +38,18 @@ mount -a ``` --> -### Download the Dynamsoft License Server v2.4.1 installer, or just copy it over to a proper location +### Download the Dynamsoft License Server v2.4.11 installer, or just copy it over to a proper location ``` shell cd /a-proper-location -wget https://tst.dynamsoft.com/public/download/dls/2.4.1/dynamsoft_dls-linux_x64-v2.4.1.tar.gz +wget https://tst.dynamsoft.com/public/download/dls/2.4.11/dynamsoft_dls-linux_x64-v2.4.11.tar.gz ``` ### Unzip and start the Dynamsoft License Server ``` shell # Unzip the installer -tar zxvf dynamsoft_dls-linux_x64-v2.4.1.tar.gz +tar zxvf dynamsoft_dls-linux_x64-v2.4.11.tar.gz # Set permissions chmod -R 755 ./dls-linux # Start the server diff --git a/selfhosting/DLSonWindows.md b/selfhosting/DLSonWindows.md index ad40479..de3beff 100644 --- a/selfhosting/DLSonWindows.md +++ b/selfhosting/DLSonWindows.md @@ -22,7 +22,7 @@ needAutoGenerateSidebar: true ### Run DLS as a service -* Download the installer from [Dynamsoft-Licensing-Tracking-Server v2.4.1](https://tst.dynamsoft.com/public/download/dls/2.4.1/dynamsoft_dls-win_x64-v2.4.1.zip) and unzip it to a proper location. In our case, it's unzipped to **"E:\dynamsoft_dls-win_x64-v2.4.1"**. +* Download the installer from [Dynamsoft-Licensing-Tracking-Server v2.4.11](https://tst.dynamsoft.com/public/download/dls/2.4.11/dynamsoft_dls-win_x64-v2.4.11.zip) and unzip it to a proper location. In our case, it's unzipped to **"E:\dynamsoft_dls-win_x64-v2.4.11"**. * Download [NSSM](https://nssm.cc/ci/nssm-2.24-101-g897c7ad.zip) and unzip, in our case, it's unzipped to **"E:\nssm-2.24"**. @@ -34,15 +34,15 @@ nssm install dynamsoft-dls * A GUI will open, fill the parameters for the application like this (change the values according to where you put the files, and change ports if ports are occupied) - * **Path**: `E:\dynamsoft_dls-win_x64-v2.4.1\win\bin\dynamsoftdlsx.exe` - * **Startup directory**: `E:\dynamsoft_dls-win_x64-v2.4.1` - * **Arguments**: `".\win\jre\bin\dynamsoftdls" -Duser.language=en -Duser.region=CA -Djavax.net.ssl.trustStoreType=WINDOWS-ROOT --add-opens java.base/jdk.internal.loader=ALL-UNNAMED -jar ".\dls-2.4.1.jar" --server.port=48080 --data.port=30201` + * **Path**: `E:\dynamsoft_dls-win_x64-v2.4.11\win\bin\dynamsoftdlsx.exe` + * **Startup directory**: `E:\dynamsoft_dls-win_x64-v2.4.11` + * **Arguments**: `".\win\jre\bin\dynamsoftdls" -Duser.language=en -Duser.region=CA -Djavax.net.ssl.trustStoreType=WINDOWS-ROOT --add-opens java.base/jdk.internal.loader=ALL-UNNAMED -jar ".\dls-2.4.11.jar" --server.port=48080 --data.port=30201` ![nssm-001]({{site.assets}}imgs/nssm-001.png) * Switch to the last tab "Hooks" and choose "Application exit" as the Event and specify the parameter as - * **Command**: `E:\dynamsoft_dls-win_x64-v2.4.1\shutdown.bat` + * **Command**: `E:\dynamsoft_dls-win_x64-v2.4.11\shutdown.bat` ![nssm-002]({{site.assets}}imgs/nssm-002.png)