Performing Garbage Collection on an AEM instance. Which is Automated using cURL and Jenkins. In this post, we are focusing on AEM deployed on a Windows Server. So, PowerShell script will be used to trigger the Garbage Collection.
PRE-REQUISITES:
AEM – it is assumed that the AEM instance is up and running
cURL – it is assumed that cURL is already installed and configured on the windows server
Jenkins – it is assumed that the Jenkins server is up and running and also assumed that you already know how to create a Job on Jenkins
LIMITATIONS:
The script will be modified in upcoming updates to accommodate the respective AEM version.
As of Now, the script will run on AEM 6.3 ONLY
SYNOPSIS:
We shall check if we are running Garbage Collection on Author/Publish and based on that we shall set the CQ_PORT to 4502/4503 appropriately
we shall check the OAK Version of the AEM instance and based on the OAK version we shall determine which AEM version we are running
Based on the AEM version we shall trigger the appropriate Garbage Collection command.
GUIDE:
Step-01: Add the Project Description
data:image/s3,"s3://crabby-images/82a91/82a91c5f0ab9beb4a900fadb7b98e14f04f7c1b7" alt=""
Description of the Jenkins Job
Step-02: Setup House Keeping to minimise the no# of buildsdata:image/s3,"s3://crabby-images/20d94/20d94fc8721b6be610b210dc7a35b24192a7999e" alt=""
Step-03: Define Parameters for the Build – Remote Host Parameterdata:image/s3,"s3://crabby-images/5b412/5b412edab1e48d18a448805361617a6cba86f88a" alt=""
data:image/s3,"s3://crabby-images/384b5/384b5815d883c5ab664c91e7f3368bb34c89a1ac" alt=""
data:image/s3,"s3://crabby-images/a1efc/a1efc830c2681f0b2def45827bf29c3dba4698b4" alt=""
data:image/s3,"s3://crabby-images/fc27d/fc27dcc47020e8fffcddf2bf6582d7450714a2e7" alt=""
data:image/s3,"s3://crabby-images/f3ad4/f3ad46021102a5fde395280c11f73109cbd6372b" alt=""
data:image/s3,"s3://crabby-images/8861f/8861f2950b2206cf15f9bfb6fa4412e3ae859d8d" alt=""
Step-04: Build step PowerShell Script
[code lang=powershell]
# stopping the job if it encounters error
$ErrorActionPreference = ‘Stop’
# Credentials are stored in env and dynamic variables
$SecurePassword = $env:Password | ConvertTo-SecureString -AsPlainText -Force
$cred = New-Object System.Management.Automation.PSCredential -ArgumentList $env:User, $SecurePassword
# Parameters that are dynamically injected during runtime
$HOSTNAME=$env:Computer
$AEMENV=$env:AEMINST
$CQ_USER=$env:cquser
$CQ_PASS=$env:cqpass
# Invoke a command on the remote machine.
Invoke-Command -ComputerName $env:Computer -Credential $cred -ScriptBlock {
# calling Dynamically injected Parameters
param($HOSTNAME,$AEMENV,$CQ_USER,$CQ_PASS)
# Path of the executable cURL
$CURLEXE = ‘C:\Program Files\curl76\bin\curl.exe’
# Checking AEM Instance Type and seting appropriate PORT
switch ( $AEMENV )
{
Publish { “We are running Garbage Collection on $AEMENV at $HOSTNAME”
$CQ_PORT=4503
}
Author { “We are running Garbage Collection on $AEMENV at $HOSTNAME”
$CQ_PORT=4502
}
AuthorMongo { “We are running Garbage Collection on $AEMENV at $HOSTNAME”
$CQ_PORT=4502
}
}
# Checking the AEM OAK Version to determine the AEM version
$url = “http://${HOSTNAME}:${CQ_PORT}/crx/explorer/index.jsp”
$webContent = Invoke-WebRequest -Uri $url -UseBasicParsing
$webContent.Content -match “(?.*)” | out-null
$OAK_VERSION = $matches[‘title’] | %{ $_.Split(‘ ‘)[3]; }
$NEW_OAKVER = $OAK_VERSION | %{ $_.Split(‘.’)[1]; }
# Setting the AEM version
switch ( [int]$NEW_OAKVER )
{
0 {“$HOSTNAME is running Oak $OAK_VERSION on AEM 6.0”}
2 {“$HOSTNAME is running Oak $OAK_VERSION on AEM 6.1”}
4 {“$HOSTNAME is running Oak $OAK_VERSION on AEM 6.2”}
6 {“$HOSTNAME is running Oak $OAK_VERSION on AEM 6.3”}
default {“Can not determine OAK Version. Aborting..”
break
}
}
# Needs some work to be done here to add other AEM versions, as of now works on AEM 6.3
# cURL command to trigger the AEM Garbage Collection
$GCURL= “http://${HOSTNAME}:${CQ_PORT}/system/console/jmx/org.apache.jackrabbit.oak:name=Segment+node+store+blob+garbage+collection,type=BlobGarbageCollection/op/startBlobGC/boolean,boolean”
$CurlArgument = ‘-s’, ‘-o’, ‘/dev/null’,
‘–user’, “${CQ_USER}:${CQ_PASS}”,
‘-w’, “%{http_code}”,
‘-X’, ‘POST’,
“$GCURL”,
‘–data’, “markOnly=true&forceBlobIdRetrieve=false”
$HTTP_RES_CODE = & $CURLEXE @CurlArgument
$HTTPRESCODE_SW = $HTTP_RES_CODE.subString(0,2)
switch ( $HTTPRESCODE_SW )
{
20 {“BlobGC Successfully Triggered.”}
40 {“That didn’t work. HTTP $HTTP_RES_CODE received.”
break
}
50 {“Server error. Result code $HTTP_RES_CODE received; fix the server then try again.”
break
}
default {“$HTTP_RES_CODE received; I have no idea how I got here. Aborting.”
break
}
}
} -ArgumentList $HOSTNAME,$AEMENV,$CQ_USER,$CQ_PASS
[/code]
Step-05: Jenkins Build Options to trigger the Builddata:image/s3,"s3://crabby-images/ae3b5/ae3b5d3772bd0ee49ea982f809a1e8a8c9e5377b" alt=""
Step-06: Console Output of Build Jobdata:image/s3,"s3://crabby-images/b36d1/b36d15ffcab4df8e8d846c661984cc6c7b241d85" alt=""
Step-02: Setup House Keeping to minimise the no# of builds
data:image/s3,"s3://crabby-images/20d94/20d94fc8721b6be610b210dc7a35b24192a7999e" alt=""
House keeping Jenkins by restricting the max # of build and retention
Step-03: Define Parameters for the Build – Remote Host Parameter
data:image/s3,"s3://crabby-images/5b412/5b412edab1e48d18a448805361617a6cba86f88a" alt=""
Remote Host on which the Garbage Collection will be Triggered
data:image/s3,"s3://crabby-images/384b5/384b5815d883c5ab664c91e7f3368bb34c89a1ac" alt=""
Username for logging-in to Remote Host
data:image/s3,"s3://crabby-images/a1efc/a1efc830c2681f0b2def45827bf29c3dba4698b4" alt=""
Password for logging-in to Remote Host
data:image/s3,"s3://crabby-images/fc27d/fc27dcc47020e8fffcddf2bf6582d7450714a2e7" alt=""
Type of AEM instance – Author/Publish
data:image/s3,"s3://crabby-images/f3ad4/f3ad46021102a5fde395280c11f73109cbd6372b" alt=""
Username of the AEM instance
data:image/s3,"s3://crabby-images/8861f/8861f2950b2206cf15f9bfb6fa4412e3ae859d8d" alt=""
The password of the AEM instance
Step-04: Build step PowerShell Script
[code lang=powershell]
# stopping the job if it encounters error
$ErrorActionPreference = ‘Stop’
# Credentials are stored in env and dynamic variables
$SecurePassword = $env:Password | ConvertTo-SecureString -AsPlainText -Force
$cred = New-Object System.Management.Automation.PSCredential -ArgumentList $env:User, $SecurePassword
# Parameters that are dynamically injected during runtime
$HOSTNAME=$env:Computer
$AEMENV=$env:AEMINST
$CQ_USER=$env:cquser
$CQ_PASS=$env:cqpass
# Invoke a command on the remote machine.
Invoke-Command -ComputerName $env:Computer -Credential $cred -ScriptBlock {
# calling Dynamically injected Parameters
param($HOSTNAME,$AEMENV,$CQ_USER,$CQ_PASS)
# Path of the executable cURL
$CURLEXE = ‘C:\Program Files\curl76\bin\curl.exe’
# Checking AEM Instance Type and seting appropriate PORT
switch ( $AEMENV )
{
Publish { “We are running Garbage Collection on $AEMENV at $HOSTNAME”
$CQ_PORT=4503
}
Author { “We are running Garbage Collection on $AEMENV at $HOSTNAME”
$CQ_PORT=4502
}
AuthorMongo { “We are running Garbage Collection on $AEMENV at $HOSTNAME”
$CQ_PORT=4502
}
}
# Checking the AEM OAK Version to determine the AEM version
$url = “http://${HOSTNAME}:${CQ_PORT}/crx/explorer/index.jsp”
$webContent = Invoke-WebRequest -Uri $url -UseBasicParsing
$webContent.Content -match “(?.*)” | out-null
$OAK_VERSION = $matches[‘title’] | %{ $_.Split(‘ ‘)[3]; }
$NEW_OAKVER = $OAK_VERSION | %{ $_.Split(‘.’)[1]; }
# Setting the AEM version
switch ( [int]$NEW_OAKVER )
{
0 {“$HOSTNAME is running Oak $OAK_VERSION on AEM 6.0”}
2 {“$HOSTNAME is running Oak $OAK_VERSION on AEM 6.1”}
4 {“$HOSTNAME is running Oak $OAK_VERSION on AEM 6.2”}
6 {“$HOSTNAME is running Oak $OAK_VERSION on AEM 6.3”}
default {“Can not determine OAK Version. Aborting..”
break
}
}
# Needs some work to be done here to add other AEM versions, as of now works on AEM 6.3
# cURL command to trigger the AEM Garbage Collection
$GCURL= “http://${HOSTNAME}:${CQ_PORT}/system/console/jmx/org.apache.jackrabbit.oak:name=Segment+node+store+blob+garbage+collection,type=BlobGarbageCollection/op/startBlobGC/boolean,boolean”
$CurlArgument = ‘-s’, ‘-o’, ‘/dev/null’,
‘–user’, “${CQ_USER}:${CQ_PASS}”,
‘-w’, “%{http_code}”,
‘-X’, ‘POST’,
“$GCURL”,
‘–data’, “markOnly=true&forceBlobIdRetrieve=false”
$HTTP_RES_CODE = & $CURLEXE @CurlArgument
$HTTPRESCODE_SW = $HTTP_RES_CODE.subString(0,2)
switch ( $HTTPRESCODE_SW )
{
20 {“BlobGC Successfully Triggered.”}
40 {“That didn’t work. HTTP $HTTP_RES_CODE received.”
break
}
50 {“Server error. Result code $HTTP_RES_CODE received; fix the server then try again.”
break
}
default {“$HTTP_RES_CODE received; I have no idea how I got here. Aborting.”
break
}
}
} -ArgumentList $HOSTNAME,$AEMENV,$CQ_USER,$CQ_PASS
[/code]
Step-05: Jenkins Build Options to trigger the Build
data:image/s3,"s3://crabby-images/ae3b5/ae3b5d3772bd0ee49ea982f809a1e8a8c9e5377b" alt=""
Jenkins Build Options
Step-06: Console Output of Build Job
data:image/s3,"s3://crabby-images/b36d1/b36d15ffcab4df8e8d846c661984cc6c7b241d85" alt=""
Console Output – Job well done.
No comments:
Post a Comment
If you have any doubts or questions, please let us know.