Every WSO2 product require a DB to persist different data. If we take WSO2 API Manager there are multiple DBs used to store different sets of data, for example, APIM DB, Registry DB, User DB etc. By default these databases are pointed to a H2 Database which resides in the file system. For production deployments these databases should be externalised by pointing it to a production grade Databases like MSSQL, MYSQL, Oracle etc.
In this post I will discuss how WSO2 servers can be connected to MSSQL using Windows Authentication. For this post I will take API Manager 3.2.0 to demo the configurations.
When it comes to different authentication methods for MSSQL there are mainly following two methods.
- SQL Server Authentication
- Windows Authentication
When it comes to Windows Authentication there are again two methods of authentication. Kerberos based authentication and local authentication. In this post I will be explaining about local authentication. Inorder for this to work your WSO2 server needs to run on a Windows server. In this method the Server will simply use the local windows authentication to connect to the MSSQL Server.
So let’s get Started!!
First make sure you have enabled Windows authentication in your MSSQL Server. After this you are ready to configure the WSO2 server. Follow the steps below inorder to confiure Windows authentication.
Step 01
Download the MSSQL driver. You can download the relevant driver from https://www.microsoft.com/en-us/download
In my case I will be using the following driver version. https://download.microsoft.com/download/4/c/3/4c31fbc1-62cc-4a0b-932a-b38ca31cd410/sqljdbc_9.2.1.0_enu.zip
Step 02
Then unzip this driver archive. The content will look like something similar to below. From here on I will refer this directory as
Step 03
Now copy the mssql driver jar from the unziped directory to APIM_HOME/repository/components/lib directory. Make sure you select the correct driver which matches the Java runtime version you have in the VM.
Step 04
Next in the
Step 05
Now we need to configure the path so that JDBC driver can find the above dll file. Inorder to do that open
After adding the following line the batch file will look something similar to below.
Step 05
Now in the
Step 06
Now start the WSO2 server by running the wso2server.bat file. If everything is in place the server should start without any errors.
That’s about it, drop a comment if you have any questions.