Setting up a Microsoft SQL Database¶
Follow the steps given below to set up the required MSSQL databases for your Micro Integrator.
Tip
WSO2 Micro Integrator requires databases for the following scenarios:
Enable TCP/IP¶
- In the start menu, click Programs and launch Microsoft SQL Server 2012.
- Click Configuration Tools , and then click SQL Server Configuration Manager .
- Enable TCP/IP and disable Named Pipes from protocols of your Microsoft SQL server.
- Double click TCP/IP to open the TCP/IP properties window and set Listen All to
Yes
on the Protocol tab. - On the IP Address tab, disable TCP Dynamic Ports by leaving it blank and give a valid TCP port, so that Microsoft SQL server will listen on that port. The best practice is to use port 1433, because you can use it in order processing services.
- Similarly, enable TCP/IP from SQL Native Client Configuration and disable Named Pipes. Also, check whether the port is set correctly to 1433.
- Restart Microsoft SQL server.
Create the database and user¶
The following MSSQL scripts are stored in the <MI_HOME>/dbscripts/mssql
directory of your Micro Integrator. First, select the scripts that are required for your deployment.
You can run the scripts on one database instance or set up separate instances for each requirement. For convenience, it is recommended to set up separate databases for each use case.
Script | Description |
---|---|
mssql_cluster.sql | This script creates the database tables that are required for cluster coordination (i.e., coordinating the server nodes in your VM deployment).This is only applicable if you have stateful integration artifacts deployed in a clustered setup. |
mssql_user.sql | This script creates the database tables that are required for storing users and roles. This is only required if you have configured an RDBMS user store. |
mssql_transaction_count.sql | This script creates the database tables that are required for storing the transaction counts. This is only required if you want to monitor transaction counts in your deployment. |
Create the databases and then create the DB tables by pointing to the relevant script in the <MI_HOME>/dbscripts/mssql
directory.
- Open the Microsoft SQL Management Studio to create a database and user.
- Click New Database from the Database menu and specify all the options to create a new database.
- Click New Login from the Logins menu, and specify all the necessary options.
Grant permissions¶
Assign newly created users the required grants/permissions to log in and create tables, to insert, index, select, update and delete data in tables in the newly created database. These are the minimum set of SQL server permissions.
Setting up the JDBC driver¶
Download and copy the sqljdbc4
Microsoft SQL JDBC driver file to the MI_HOME/lib/
directory. Use com.microsoft.sqlserver.jdbc.SQLServerDriver
as the
Connecting the database to the server¶
Open the deployment.toml
file in the <MI_HOME>/conf
directory and add the following sections to create the connection between the Micro Integrator and the relevant database. Note that you need separate configurations corresponding to the separate databases (clusterdb
, userdb
, and transactiondb
).
[[datasource]]
id = "WSO2_COORDINATION_DB"
url= "jdbc:sqlserver://<IP>:1433;databaseName=clusterdb;SendStringParametersAsUnicode=false"
username="root"
password="root"
driver="com.microsoft.sqlserver.jdbc.SQLServerDriver"
pool_options.maxActive=50
pool_options.maxWait = 60000
pool_options.testOnBorrow = true
[[datasource]]
id = "WSO2CarbonDB"
url= "jdbc:sqlserver://<IP>:1433;databaseName=userdb;SendStringParametersAsUnicode=false"
username="root"
password="root"
driver="com.microsoft.sqlserver.jdbc.SQLServerDriver"
pool_options.maxActive=50
pool_options.maxWait = 60000
pool_options.testOnBorrow = true
[[datasource]]
id = "WSO2_TRANSACTION_DB"
url= "jdbc:sqlserver://<IP>:1433;databaseName=transactiondb;SendStringParametersAsUnicode=false"
username="root"
password="root"
driver="com.microsoft.sqlserver.jdbc.SQLServerDriver"
pool_options.maxActive=50
pool_options.maxWait = 60000
pool_options.testOnBorrow = true
[transaction_counter]
enable = true
data_source = "WSO2_TRANSACTION_DB"
update_interval = 2
About User DB
If you replace 'WSO2CarbonDB' with a different id in the user DB configuration, you also need to list the id as a datasource under the [realm_manager]
section in the deployment.toml
file as shown below.
[realm_manager]
data_source = "new_id"
Otherwise the user store database id defaults to 'WSO2CarbonDB' in the realm manager configurations..
See the descriptions of database connection parameters.