Triggering on journal rotation
To configure
Helix Core Server
to run trigger scripts when journals are rotated, use the
journal-rotate
and journal-rotate-lock
type
triggers. Journal-rotate triggers are executed after the journal is
rotated on a running server, but only if journals are rotated with the
p4 admin journal
or p4 admin
checkpoint
commands. Journal rotate triggers will not
execute when journals are rotated with the p4d -jc
or
p4d -jj
commands.
Journal-rotate triggers allow you to run maintenance routines on servers after the journal has been rotated, either while the database tables are still locked or after the locks have been released. These triggers are intended to be used on replicas or edge servers where journal rotation is triggered by journal records. The server must be running for these triggers to be invoked.
The following table describes the fields of a journal-rotate trigger:
Field | Meaning | ||||
---|---|---|---|---|---|
|
The name of the trigger. |
||||
|
Warning
While a journal-rotate-lock trigger is running, the Helix Core Server will not respond to Helix client commands. |
||||
|
The server(s) on which the triggers should be run. One of the following:
|
||||
|
The trigger for Helix Core Server
to run when the server matching Journal-rotate triggers can process two variables:
When your trigger script is stored in the depot, its path must
be specified in depot syntax, delimited by percent characters.
For example, if your script is stored in the depot as
|
Example of journal-rotate trigger
This journal-rotate trigger sends an email to the Perforce administrator on journal rotation.
#!/bin/sh # journal-rotate.sh - email Perforce administrator about journal rotation journal="$1" serverid="$2" serveraddress="$3" p4 -p $serveraddress journals -m1 | mail -s "$serveraddress - Journal Rotation to journal:$journal on server:$serverid" perforce-admin@localhost exit 0
To use the trigger, add to your triggers table:
jnlrotate journal-rotate any "/path/to/journal-rotate.sh %journal% %serverid% %serverport%"
Example of journal-rotate-lock trigger
A journal-rotate-lock
trigger that runs commands that are not Helix Core Server commands while the Helix Core Server database and journal are locked.
#!/bin/sh #journal-rotate-lock.sh - Trigger script to run actions while the database and journal are locked. #Perforce commands cannot be run against the Helix Server because the database is locked. #Add external actions and commands for this trigger as required. echo "External actions while database and journal are locked" | mail -s "Actions took place while the journal and database were locked !" perforce-admin@localhost exit 0
To use the trigger, add to your triggers table:
jnllock journal-rotate-lock any "/path/to/journal-rotate-lock.sh"