Setup Analytics for Cluster Setup
When using a cluster setup in SearchBlox, we recommend setting an external database using Postgres for Analytics to store the data related to Analytics in a central database.
Setting up Analytics for Cluster in Linux
It is required to first install Postgres in any of the servers, preferably in the index server or any other server accessible to all the servers in the cluster.
Steps to Install Postgresql in Centos
- Install Postgres using the command:
sudo yum install postgresql-server postgresql-contrib
Using the above command in Centos7 9.x version of PostgreSQL would be installed.
data:image/s3,"s3://crabby-images/89f9a/89f9ac7653b1d4bf036dab49de559b1e4538fe82" alt="install postgres1.png 607"
- Initialize database using the command:
sudo postgresql-setup initdb
data:image/s3,"s3://crabby-images/ff46d/ff46dc0f6471eef28b5a1e1cd18e72aa621085d3" alt="install postgres2.png 650"
- Set password for postgres database
sudo passwd postgres
Enter and reenter the password.
data:image/s3,"s3://crabby-images/3413f/3413f3d33c6360f71de8f145ae6018a2676934ed" alt="install post5.png 486"
-
Edit
vi /var/lib/pgsql/data/postgresql.conf
and make sure you set the parameter value as listen_addresses = '*'. -
Edit
vi /var/lib/pgsql/data/pg_hba.conf
and give trust to local and host connections. For host connection please specify 0.0.0.0/0 to listen to all addresses, if you want more security give the specific address in which postgres runs i.e., the host address
Modify the local and host entries as below:# "local" is for Unix domain socket connections only local all all trust # IPv4 local connections: host all all 0.0.0.0/0 trust # IPv6 local connections: host all all ::1/128 trust
data:image/s3,"s3://crabby-images/3a1b7/3a1b77f823da741706a416bc32cbc0f4918e336f" alt="install post6.png 611"
data:image/s3,"s3://crabby-images/629c1/629c1b5541a288e6d4a8f8d6e40cebbf0dd046b2" alt="install post7.png 647"
- Start database using the command:
sudo systemctl start postgresql
data:image/s3,"s3://crabby-images/21be7/21be70d3b7fcbc08c61b9676685e85d3b47db8ba" alt="install post3.png 353"
- To automatically restart postgresql with system reboot
sudo systemctl enable postgresql
data:image/s3,"s3://crabby-images/39f8d/39f8d253deb7271196d52995607f187f0b1b1150" alt="install post4.png 635"
- To restart Postgres use the commands:
sudo systemctl stop postgresql
sudo systemctl start postgresql
data:image/s3,"s3://crabby-images/c254e/c254ecf444fb2f4399fb8427ced7d5ab3162dabd" alt="install post8.png 308"
Postgres Access
Please make sure that the host is pointing to localhost in /etc/hosts file so that Postgres
http://localhost:5432
is accessible ashttps://<IP or DNS>:5432
in index server and is accessible in search servers.
Access Postgresql and create Database
-
Use the command below to go to Postgres console
sudo -u postgres psql
-
To check the version of Postgres
psql --version
-
To list the database use
\l
-
Create a database using the command
CREATE DATABASE analytics;
-
Check the created database from the list of databases
\l
-
To quit give
\q
data:image/s3,"s3://crabby-images/3c009/3c009c386f15905b0397a54eecd752599ce4dec9" alt="postgres create command.png 817"
Configure Postgres for Analytics in All Three SearchBlox Servers
The following changes should be made in all three servers i.e., index and 2 search servers. Please ensure the steps are repeated in all three servers in the cluster.
-
Go to /opt/searchblox/analytics/.env file
vi /opt/searchblox/analytics/.env
-
Give the appropriate values for the following five parameters i.e., from Step 4 to Step 8
-
Please give the IP address of the host where Postgres is accessible.
CUBEJS_DB_HOST=<IP Address>
Note: Please make sure that the host is pointing to localhost in /etc/hosts file so that Postgres http://localhost:5432 is accessible ashttps://<IP or DNS>:5432
across index and search servers. -
As we have created a database named analytics please give the same as value here
CUBEJS_DB_NAME=analytics
-
We are using a default user Postgres, if you have created another user for the analytics database specify the same here
CUBEJS_DB_USER=postgres
-
Specify the configured password
CUBEJS_DB_PASS=password
-
The database type is postgres
CUBEJS_DB_TYPE=postgres
-
The content of the .env file with above values would be as below:
CUBEJS_DB_HOST=<IP or DNS> CUBEJS_DB_NAME=analytics CUBEJS_DB_USER=postgres CUBEJS_DB_PASS=searchblox CUBEJS_WEB_SOCKETS=true CUBEJS_DB_TYPE=postgres NODE_ENV=production CUBEJS_CACHE_AND_QUEUE_DRIVER=memory CUBEJS_API_SECRET= b4a2056bb6fb30cb02d11e0878115bb2cb27262791766641ceda1e5b105478d321c3c8e26e46ad1b766b5c69b624f6a0d72abe6d541f7d15c095c487bb650ba9
Please ensure that all the above parameters are available in the file.
data:image/s3,"s3://crabby-images/79be5/79be560c0a5dea4141870d1fb90056e38c05fee5" alt="vi env.png 1225"
-
Go to /opt/searchblox/webapps/searchblox/WEB-INF/searchblox.yml
-
Give the appropriate values for the following fields
analytics.db.type: postgres analytics.db.url: <IP or DNS>:5432 analytics.db.username: postgres analytics.db.pasword: searchblox analytics.db.name: sbanalytics
data:image/s3,"s3://crabby-images/8d6e3/8d6e3ce63f14d475ba2680a1aee2c79742ce4dab" alt="searchbloxyml.png 450"
-
Stop and Start SearchBlox service
systemctl stop searchblox
systemctl start searchblox
-
After few seconds stop and start Analytics Service
systemctl stop sbanalytics
systemctl start sbanalytics
data:image/s3,"s3://crabby-images/7daff/7dafff7f9ad567249c9d441739042edeb99ef603" alt="install post9.png 385"
- After starting the analytics service, make few searches in the plugin and check analytics from the Admin Dashboard of Index and Search Servers.
data:image/s3,"s3://crabby-images/4704d/4704d0c2dca293e88a7c8c4a736ae9c566d59fc3" alt="analytics display.png 940"
Checking Postgresql database
To check whether data is available in the Postgres database
-
Use the command below to go to Postgres console
sudo -u postgres psql
-
To list the database use
\l
-
Connect to the analytics database
\connect analytics
-
List tables
\d
-
You will see 3 tables within the database - autosuggest_click_logs, click_logs, query_logs.
-
Fetching data from querylogs table
data:image/s3,"s3://crabby-images/00b10/00b1038319c38612ee0b53ce46c867dbad41e559" alt="postgres commands.png 1155"
SSL Configuration for SearchBlox Analytics in Cluster
By default, the Analytics server will run on SSL port 8444. If you need to update the Analytics server port, we have to edit the below 2 files:
-
Open the file
C:\SearchBloxServer\analytics\.env
or/opt/searchblox/analytics/.env
and change the port as required finding the line below:
TLS_PORT=8444
-
Open the file
C:\SearchBloxServer\webapps\searchblox\analytics\index.html
or/opt/searchblox/webapps/searchblox/analytics/index.html
and change the port number to custom port as required:
<input type="hidden" value="8444" id="connection_port">
data:image/s3,"s3://crabby-images/1355b/1355b5829b30793fdfefba1fc662d60d410ecd82" alt="analytics indexfile.png 611"
-
Stop and Start SearchBlox
systemctl stop searchblox
systemctl start searchblox
-
Stop and Start Analytics
systemctl stop sbanalytics
systemctl start sbanalytics
Note:
- Any SSL configuration for Analytics in cluster setup given changes should be made in all three servers, i.e., index and two search servers.
- When SearchBlox runs on TLS/SSL, we need to place SSL files(cert.pem and key.pem) into
/opt/searchblox/analytics
to run SearchBlox Analytics.
Setting up Analytics for Cluster in Windows
In Windows, PostgreSQL can be installed using the installation wizard. We recommend installing the 9.x version of Postgres in one of the three servers in the cluster preferably in the indexing server.
Steps to Install PostgreSQL in Windows
-
Download the installer for Postgres version 9.6 using the link below:
https://get.enterprisedb.com/postgresql/postgresql-9.6.19-1-windows-x64.exe
You can also download the version based on your OS compatibility at the link below:
https://www.enterprisedb.com/downloads/postgres-postgresql-downloads -
Run the executable and follow the installer wizard to install Postgres
data:image/s3,"s3://crabby-images/b5254/b525461db07da94f1e6ead56fd226273e534cad8" alt="installer1.png 558"
- Please give the password and note the same down for later use
data:image/s3,"s3://crabby-images/1fcee/1fcee02f75c25249e441f63698ed680859e70cdd" alt="installerpswd.png 552"
- Note down the port number for further use in SearchBlox
data:image/s3,"s3://crabby-images/ac53c/ac53c9950b1d1f95771442dcd9e5691a846d94f0" alt="installerport.png 547"
- Finally uncheck the "Launch Stack Builder at exit?" and Finish the installation
data:image/s3,"s3://crabby-images/b8075/b80751d28a4d87d165caec42c5bf4fff69fb67bb" alt="Finish installation.png 553"
-
Open the file C:\Program Files\PostgreSQL\9.x\data\postgresql.conf and make sure you set the parameter value as listen_addresses = '*'.
-
For host connection please specify 0.0.0.0/0 to listen to all addresses, if you want more security give the specific address in which postgres runs i.e., the host address. Open the file C:\Program Files\PostgreSQL\9.x\data\pg_hba.conf and allow the cluster servers to trust postgres access using their IPs. Modify the local and host entries as below:
# Allow Postgres connection to Index server IP: host all all 13.54.234.241/24 trust # Allow Postgres connection to Search server1 IP: host all all 13.239.55.148/24 trust # Allow Postgres connection to Search server2 IP: host all all 3.25.193.78/24 trust
-
Restart the PostgreSQL service.
-
In addition to above some Windows machines might also require incoming TCP traffic to be allowed on the port 5432.
To do this in Index Server, you would need to open Windows Firewall and add an inbound rule for the port 5432.
Head to Control Panel\System and Security\Windows Defender Firewall > Advanced Settings > Actions (right tab) > Inbound Rules > New Rule… > Port > Specific local ports and type in the port your using, 5432.
Access Postgresql using pgadmin4 and create Database
pgadmin4 tool is a GUI tool that comes with PostgreSQL installation in Windows. Using pgadmin4, database for SearchBlox analytics can be easily created using the following steps:
- Ensure that Google Chrome is installed in the Windows instance and is enabled as a default program/browser. pgadmin4 works with Chrome and Firefox browsers, however not compatible with Internet Explorer.
To make Google Chrome as default go to -> Control Panel -> Programs->Default Programs->Set your default programs -> Select Google Chrome and set it as default program.
data:image/s3,"s3://crabby-images/99c8d/99c8d25c1d8470f9b4b641432ebec6821517f608" alt="setdefaultbrowser.png 790"
- Select pgadmin4 from the PostgreSQL menu from the start menu
data:image/s3,"s3://crabby-images/6f276/6f276e856db2bae34eecc6fc8ac2d6c03fe49b1a" alt="pgadmin4.png 310"
- Postgres9.6 would be available as a server in the dropdown as in the screenshot below. By default, Postgres9.6 would be connected.
data:image/s3,"s3://crabby-images/526c4/526c400ed760ef587834268d6d169215780932fe" alt="pgadmin4connect.png 425"
Otherwise, connect to the database by providing the password configured while installing.
data:image/s3,"s3://crabby-images/ad490/ad490973c92a169f4f5b23c4a820864accb6e224" alt="pgadmin4pass.png 949"
- Create a database named analytics
data:image/s3,"s3://crabby-images/8ac59/8ac592d17c64ca1062405e19e83450840de5a545" alt="createdatabase2.png 918"
Expand the database as below and view:
data:image/s3,"s3://crabby-images/d72b9/d72b91b0f2d838035cbcf0b2f441d843332228b1" alt="analyticsdb2.png 535"
Alternatively, you can also use SQL Shell to access PostgreSQL and create a database.
data:image/s3,"s3://crabby-images/5d4e1/5d4e1ad12f2a430a63bef78f366a61fdb28734f4" alt="SQLshell.png 289"
data:image/s3,"s3://crabby-images/d8737/d87378eedc1a30193ffe7241548a386df6e80de1" alt="sqlshell2.png 674"
data:image/s3,"s3://crabby-images/0ca0c/0ca0c99b9ca1178401d8c0c12bd8015694dd8a49" alt="sqlshell3.png 845"
Configure Postgres for Analytics in the Server
-
Stop SearchBlox and analytics server if running.
-
Go to
<SEARCHBLOX INSTALLATION PATH>\analytics\.env
file -
Give the appropriate values for the first five parameters
-
Please give the localhost or IP address of the host where Postgres is accessible.
CUBEJS_DB_HOST=<IP Address>
Note: Please make sure that Postgres in http://localhost:5432 is accessible ashttps://<IP or DNS>:5432
across index and search servers. -
As we have created a database named analytics please give the same as the value shown here
CUBEJS_DB_NAME=analytics
-
We are using a default user Postgres if you have created another user for the analytics database specify the same here
CUBEJS_DB_USER=postgres
-
Specify the configured password
CUBEJS_DB_PASS=password
-
The database type is Postgres
CUBEJS_DB_TYPE=postgres
The content of the .env file with above values would be as below:CUBEJS_CACHE_AND_QUEUE_DRIVER=memory CUBEJS_DB_HOST=<IP> CUBEJS_DB_NAME=analytics CUBEJS_DB_USER=postgres CUBEJS_DB_PASS=searchblox CUBEJS_WEB_SOCKETS=true CUBEJS_DB_TYPE=postgres NODE_ENV=production CUBEJS_API_SECRET=b4a2056bb6fb3d72abe6d549999jjel01f7d15c095c487bb650ba9
Please ensure that all the above parameters are available in the file.
-
Go to \searchblox\webapps\searchblox\WEB-INF\searchblox.yml
-
Give the appropriate values for the following fields
analytics.db.type: postgres analytics.db.url: localhost:5432 analytics.db.username: postgres analytics.db.pasword: searchblox analytics.db.name: analytics
-
Start SearchBlox
-
Start Analytics
-
After starting the analytics service, make few searches in the plugin and check analytics from the Admin Dashboard.
data:image/s3,"s3://crabby-images/dcc7d/dcc7df06248632efff3539f63b403be0363d2748" alt="analytics display.png 940"
Updated almost 4 years ago