{"id":17166,"date":"2022-04-14T16:39:06","date_gmt":"2022-04-14T14:39:06","guid":{"rendered":"https:\/\/www.dbi-services.com\/blog\/oracle-21c-dealing-with-faststartfailoveractiononprecalloutfailure\/"},"modified":"2023-06-20T10:14:20","modified_gmt":"2023-06-20T08:14:20","slug":"oracle-21c-dealing-with-faststartfailoveractiononprecalloutfailure","status":"publish","type":"post","link":"https:\/\/www.dbi-services.com\/blog\/oracle-21c-dealing-with-faststartfailoveractiononprecalloutfailure\/","title":{"rendered":"Oracle 21c : Dealing with FastStartFailoverActionOnPreCalloutFailure"},"content":{"rendered":"<p><strong>By Mouhamadou Diaw<\/strong><\/p>\n<p>In a previous <a href=\"https:\/\/www.dbi-services.com\/blog\/oracle-21c-broker-fast-start-failover-callout-scripts-in-action\/\" target=\"_blank\" rel=\"noopener\">blog <\/a>I talked about the FSFO callout scripts which is a new feature with Oracle 21c with the broker.<\/p>\n<p>This feature will allow to execute some tasks before and after a fast-start failover. By default, the automatic failover will not happen if the pre-script fails. Maybe it&#8217;s not what we want, sometimes we will want to continue the automatic failover even if the pre-tasks did not execute successfully.<\/p>\n<p>Oracle has a parameter for this, it is the FastStartFailoverActionOnPreCalloutFailure. This parameter has two values :<br \/>\nSTOP: the FSFO will not happen if there is not a .suc file (the pre-tasks fail)<br \/>\nCONTINUE: the FSFO will continue even if the pre-tasks fail<\/p>\n<p>In this blog I do some tests with this parameter and show the results. Below the configuration I used, the same that the one used in my previous <a href=\"https:\/\/www.dbi-services.com\/blog\/oracle-21c-broker-fast-start-failover-callout-scripts-in-action\/\" target=\"_blank\" rel=\"noopener\">blog <\/a><\/p>\n<div>\n<div id=\"highlighter_764053\" class=\"syntaxhighlighter  sql\">\n<table border=\"0\" cellspacing=\"0\" cellpadding=\"0\">\n<tbody>\n<tr>\n<td class=\"gutter\">\n<div class=\"line number1 index0 alt2\">1<\/div>\n<div class=\"line number2 index1 alt1\">2<\/div>\n<div class=\"line number3 index2 alt2\">3<\/div>\n<div class=\"line number4 index3 alt1\">4<\/div>\n<div class=\"line number5 index4 alt2\">5<\/div>\n<div class=\"line number6 index5 alt1\">6<\/div>\n<div class=\"line number7 index6 alt2\">7<\/div>\n<div class=\"line number8 index7 alt1\">8<\/div>\n<div class=\"line number9 index8 alt2\">9<\/div>\n<div class=\"line number10 index9 alt1\">10<\/div>\n<div class=\"line number11 index10 alt2\">11<\/div>\n<div class=\"line number12 index11 alt1\">12<\/div>\n<div class=\"line number13 index12 alt2\">13<\/div>\n<div class=\"line number14 index13 alt1\">14<\/div>\n<div class=\"line number15 index14 alt2\">15<\/div>\n<\/td>\n<td class=\"code\">\n<div class=\"container\">\n<div class=\"line number1 index0 alt2\"><code class=\"sql plain\">DGMGRL&gt; show configuration<\/code><\/div>\n<div class=\"line number2 index1 alt1\"><\/div>\n<div class=\"line number3 index2 alt2\"><code class=\"sql plain\">Configuration - db21<\/code><\/div>\n<div class=\"line number4 index3 alt1\"><\/div>\n<div class=\"line number5 index4 alt2\"><code class=\"sql spaces\">\u00a0\u00a0<\/code><code class=\"sql plain\">Protection Mode: MaxPerformance<\/code><\/div>\n<div class=\"line number6 index5 alt1\"><code class=\"sql spaces\">\u00a0\u00a0<\/code><code class=\"sql plain\">Members:<\/code><\/div>\n<div class=\"line number7 index6 alt2\"><code class=\"sql spaces\">\u00a0\u00a0<\/code><code class=\"sql plain\">DB21_SITE1 - <\/code><code class=\"sql keyword\">Primary<\/code> <code class=\"sql keyword\">database<\/code><\/div>\n<div class=\"line number8 index7 alt1\"><code class=\"sql spaces\">\u00a0\u00a0\u00a0\u00a0<\/code><code class=\"sql plain\">DB21_SITE2 - (*) Physical standby <\/code><code class=\"sql keyword\">database<\/code><\/div>\n<div class=\"line number9 index8 alt2\"><\/div>\n<div class=\"line number10 index9 alt1\"><code class=\"sql plain\">Fast-Start Failover: Enabled <\/code><code class=\"sql color1\">in<\/code> <code class=\"sql plain\">Potential Data Loss Mode<\/code><\/div>\n<div class=\"line number11 index10 alt2\"><\/div>\n<div class=\"line number12 index11 alt1\"><code class=\"sql plain\">Configuration Status:<\/code><\/div>\n<div class=\"line number13 index12 alt2\"><code class=\"sql plain\">SUCCESS\u00a0\u00a0 (status updated 17 seconds ago)<\/code><\/div>\n<div class=\"line number14 index13 alt1\"><\/div>\n<div class=\"line number15 index14 alt2\"><code class=\"sql plain\">DGMGRL&gt;<\/code><\/div>\n<\/div>\n<\/td>\n<\/tr>\n<\/tbody>\n<\/table>\n<\/div>\n<\/div>\n<p><strong>FastStartFailoverActionOnPreCalloutFailure=STOP<\/strong><\/p>\n<p>The first tests are done with the parameter set to STOP. Below my callout scripts<\/p>\n<p>fsfocallout.ora script with the value=STOP<\/p>\n<div>\n<div id=\"highlighter_94552\" class=\"syntaxhighlighter  bash\">\n<table border=\"0\" cellspacing=\"0\" cellpadding=\"0\">\n<tbody>\n<tr>\n<td class=\"gutter\">\n<div class=\"line number1 index0 alt2\">1<\/div>\n<div class=\"line number2 index1 alt1\">2<\/div>\n<div class=\"line number3 index2 alt2\">3<\/div>\n<div class=\"line number4 index3 alt1\">4<\/div>\n<div class=\"line number5 index4 alt2\">5<\/div>\n<div class=\"line number6 index5 alt1 highlighted\">6<\/div>\n<div class=\"line number7 index6 alt2\">7<\/div>\n<div class=\"line number8 index7 alt1\">8<\/div>\n<\/td>\n<td class=\"code\">\n<div class=\"container\">\n<div class=\"line number1 index0 alt2\"><code class=\"bash plain\">oracle@oraadserver3:<\/code><code class=\"bash plain\">\/u01\/app\/oracle\/admin\/prod20\/broker_files\/config_db21\/callout\/<\/code> <code class=\"bash plain\">[DB21 (CDB$ROOT)] <\/code><code class=\"bash functions\">cat<\/code> <code class=\"bash plain\">fsfocallout.ora | <\/code><code class=\"bash functions\">grep<\/code> <code class=\"bash plain\">-<\/code><code class=\"bash functions\">v<\/code> <code class=\"bash plain\">^<\/code><code class=\"bash comments\">#<\/code><\/div>\n<div class=\"line number2 index1 alt1\"><code class=\"bash plain\">FastStartFailoverPreCallout=fsfo_precallout<\/code><\/div>\n<div class=\"line number3 index2 alt2\"><code class=\"bash plain\">FastStartFailoverPreCalloutTimeout=25<\/code><\/div>\n<div class=\"line number4 index3 alt1\"><code class=\"bash plain\">FastStartFailoverPreCalloutSucFileName=fsfo_precallout.suc<\/code><\/div>\n<div class=\"line number5 index4 alt2\"><code class=\"bash plain\">FastStartFailoverPreCalloutErrorFileName=fsfo_precallout.err<\/code><\/div>\n<div class=\"line number6 index5 alt1 highlighted\"><code class=\"bash plain\">FastStartFailoverActionOnPreCalloutFailure=STOP<\/code><\/div>\n<div class=\"line number7 index6 alt2\"><code class=\"bash plain\">FastStartFailoverPostCallout=fsfo_postcallout<\/code><\/div>\n<div class=\"line number8 index7 alt1\"><code class=\"bash plain\">oracle@oraadserver3:<\/code><code class=\"bash plain\">\/u01\/app\/oracle\/admin\/prod20\/broker_files\/config_db21\/callout\/<\/code> <code class=\"bash plain\">[DB21 (CDB$ROOT)]<\/code><\/div>\n<\/div>\n<\/td>\n<\/tr>\n<\/tbody>\n<\/table>\n<\/div>\n<\/div>\n<p>fsfo_precallout script with errors inside<\/p>\n<div>\n<div id=\"highlighter_597086\" class=\"syntaxhighlighter  bash\">\n<table border=\"0\" cellspacing=\"0\" cellpadding=\"0\">\n<tbody>\n<tr>\n<td class=\"gutter\">\n<div class=\"line number1 index0 alt2\">1<\/div>\n<div class=\"line number2 index1 alt1\">2<\/div>\n<div class=\"line number3 index2 alt2\">3<\/div>\n<div class=\"line number4 index3 alt1\">4<\/div>\n<div class=\"line number5 index4 alt2 highlighted\">5<\/div>\n<div class=\"line number6 index5 alt1 highlighted\">6<\/div>\n<div class=\"line number7 index6 alt2 highlighted\">7<\/div>\n<div class=\"line number8 index7 alt1 highlighted\">8<\/div>\n<div class=\"line number9 index8 alt2\">9<\/div>\n<div class=\"line number10 index9 alt1\">10<\/div>\n<div class=\"line number11 index10 alt2\">11<\/div>\n<div class=\"line number12 index11 alt1\">12<\/div>\n<\/td>\n<td class=\"code\">\n<div class=\"container\">\n<div class=\"line number1 index0 alt2\"><code class=\"bash plain\">oracle@oraadserver3:<\/code><code class=\"bash plain\">\/u01\/app\/oracle\/admin\/prod20\/broker_files\/config_db21\/callout\/<\/code> <code class=\"bash plain\">[DB21 (CDB$ROOT)] <\/code><code class=\"bash functions\">cat<\/code> <code class=\"bash plain\">fsfo_precallout<\/code><\/div>\n<div class=\"line number2 index1 alt1\"><code class=\"bash preprocessor bold\">#! \/bin\/bash<\/code><\/div>\n<div class=\"line number3 index2 alt2\"><code class=\"bash keyword\">if<\/code> <code class=\"bash plain\">[ 1 -lt 100 ]<\/code><\/div>\n<div class=\"line number4 index3 alt1\"><code class=\"bash spaces\">\u00a0<\/code><code class=\"bash keyword\">then<\/code><\/div>\n<div class=\"line number5 index4 alt2 highlighted\"><code class=\"bash spaces\">\u00a0\u00a0\u00a0<\/code><code class=\"bash functions\">touch<\/code> <code class=\"bash plain\">\/temp\/test<\/code><\/div>\n<div class=\"line number6 index5 alt1 highlighted\"><code class=\"bash spaces\">\u00a0\u00a0\u00a0<\/code><code class=\"bash functions\">echo<\/code> <code class=\"bash string\">\"starting fun observer\"<\/code> <code class=\"bash plain\">&gt; <\/code><code class=\"bash plain\">\/temp\/test<\/code><\/div>\n<div class=\"line number7 index6 alt2 highlighted\"><code class=\"bash spaces\">\u00a0\u00a0\u00a0<\/code><code class=\"bash functions\">echo<\/code> <code class=\"bash string\">\"starting fun observer\"<\/code> <code class=\"bash plain\">&gt; <\/code><code class=\"bash plain\">\/temp\/test<\/code><\/div>\n<div class=\"line number8 index7 alt1 highlighted\"><code class=\"bash spaces\">\u00a0\u00a0\u00a0<\/code><code class=\"bash functions\">touch<\/code>\u00a0 <code class=\"bash plain\">\/u01\/app\/oracle\/aadmin\/prod20\/broker_files\/config_db21\/callout\/fsfo_precallout<\/code><code class=\"bash plain\">.suc<\/code><\/div>\n<div class=\"line number9 index8 alt2\"><code class=\"bash keyword\">else<\/code><\/div>\n<div class=\"line number10 index9 alt1\"><code class=\"bash spaces\">\u00a0\u00a0<\/code><code class=\"bash functions\">touch<\/code> <code class=\"bash plain\">\/u01\/app\/oracle\/admin\/prod20\/broker_files\/config_db21\/callout\/fsfo_precallout<\/code><code class=\"bash plain\">.err<\/code><\/div>\n<div class=\"line number11 index10 alt2\"><code class=\"bash keyword\">fi<\/code><\/div>\n<div class=\"line number12 index11 alt1\"><code class=\"bash plain\">oracle@oraadserver3:<\/code><code class=\"bash plain\">\/u01\/app\/oracle\/admin\/prod20\/broker_files\/config_db21\/callout\/<\/code> <code class=\"bash plain\">[DB21 (CDB$ROOT)]<\/code><\/div>\n<\/div>\n<\/td>\n<\/tr>\n<\/tbody>\n<\/table>\n<\/div>\n<\/div>\n<p>As you may see, I did some mistakes (\/temp instead of \/tmp, aadmin instead of admin) in the script so that the pre-tasks will not finish successfully.<\/p>\n<p>Now let&#8217;s simulate a Failover to validate the expected behavior<\/p>\n<div>\n<div id=\"highlighter_179670\" class=\"syntaxhighlighter  sql\">\n<table border=\"0\" cellspacing=\"0\" cellpadding=\"0\">\n<tbody>\n<tr>\n<td class=\"gutter\">\n<div class=\"line number1 index0 alt2\">1<\/div>\n<div class=\"line number2 index1 alt1\">2<\/div>\n<div class=\"line number3 index2 alt2\">3<\/div>\n<div class=\"line number4 index3 alt1\">4<\/div>\n<div class=\"line number5 index4 alt2\">5<\/div>\n<div class=\"line number6 index5 alt1\">6<\/div>\n<div class=\"line number7 index6 alt2\">7<\/div>\n<div class=\"line number8 index7 alt1\">8<\/div>\n<div class=\"line number9 index8 alt2\">9<\/div>\n<\/td>\n<td class=\"code\">\n<div class=\"container\">\n<div class=\"line number1 index0 alt2\"><code class=\"sql plain\">SQL&gt; <\/code><code class=\"sql keyword\">select<\/code> <code class=\"sql plain\">db_unique_name,open_mode <\/code><code class=\"sql keyword\">from<\/code> <code class=\"sql plain\">v$<\/code><code class=\"sql keyword\">database<\/code><code class=\"sql plain\">;<\/code><\/div>\n<div class=\"line number2 index1 alt1\"><\/div>\n<div class=\"line number3 index2 alt2\"><code class=\"sql plain\">DB_UNIQUE_NAME\u00a0\u00a0\u00a0\u00a0\u00a0\u00a0\u00a0\u00a0\u00a0\u00a0\u00a0\u00a0\u00a0\u00a0\u00a0\u00a0 OPEN_MODE<\/code><\/div>\n<div class=\"line number4 index3 alt1\"><code class=\"sql comments\">------------------------------ --------------------<\/code><\/div>\n<div class=\"line number5 index4 alt2\"><code class=\"sql plain\">db21_site1\u00a0\u00a0\u00a0\u00a0\u00a0\u00a0\u00a0\u00a0\u00a0\u00a0\u00a0\u00a0\u00a0\u00a0\u00a0\u00a0\u00a0\u00a0\u00a0\u00a0 <\/code><code class=\"sql keyword\">READ<\/code> <code class=\"sql plain\">WRITE<\/code><\/div>\n<div class=\"line number6 index5 alt1\"><\/div>\n<div class=\"line number7 index6 alt2\"><code class=\"sql plain\">SQL&gt; shut abort<\/code><\/div>\n<div class=\"line number8 index7 alt1\"><code class=\"sql plain\">ORACLE instance shut down.<\/code><\/div>\n<div class=\"line number9 index8 alt2\"><code class=\"sql plain\">SQL&gt;<\/code><\/div>\n<\/div>\n<\/td>\n<\/tr>\n<\/tbody>\n<\/table>\n<\/div>\n<\/div>\n<p>After the shutdown abort of the primary, we can see in the observer logfile, that the automatic failover did not happen because of the value of the parameter FastStartFailoverActionOnPreCalloutFailure=STOP<\/p>\n<div>\n<div id=\"highlighter_345579\" class=\"syntaxhighlighter  bash\">\n<table border=\"0\" cellspacing=\"0\" cellpadding=\"0\">\n<tbody>\n<tr>\n<td class=\"gutter\">\n<div class=\"line number1 index0 alt2\">1<\/div>\n<div class=\"line number2 index1 alt1\">2<\/div>\n<div class=\"line number3 index2 alt2\">3<\/div>\n<div class=\"line number4 index3 alt1\">4<\/div>\n<div class=\"line number5 index4 alt2\">5<\/div>\n<div class=\"line number6 index5 alt1\">6<\/div>\n<div class=\"line number7 index6 alt2\">7<\/div>\n<div class=\"line number8 index7 alt1\">8<\/div>\n<div class=\"line number9 index8 alt2\">9<\/div>\n<div class=\"line number10 index9 alt1\">10<\/div>\n<div class=\"line number11 index10 alt2\">11<\/div>\n<div class=\"line number12 index11 alt1\">12<\/div>\n<div class=\"line number13 index12 alt2\">13<\/div>\n<div class=\"line number14 index13 alt1\">14<\/div>\n<div class=\"line number15 index14 alt2\">15<\/div>\n<div class=\"line number16 index15 alt1\">16<\/div>\n<div class=\"line number17 index16 alt2\">17<\/div>\n<div class=\"line number18 index17 alt1\">18<\/div>\n<div class=\"line number19 index18 alt2\">19<\/div>\n<div class=\"line number20 index19 alt1\">20<\/div>\n<div class=\"line number21 index20 alt2\">21<\/div>\n<div class=\"line number22 index21 alt1\">22<\/div>\n<div class=\"line number23 index22 alt2 highlighted\">23<\/div>\n<div class=\"line number24 index23 alt1 highlighted\">24<\/div>\n<div class=\"line number25 index24 alt2 highlighted\">25<\/div>\n<div class=\"line number26 index25 alt1\">26<\/div>\n<div class=\"line number27 index26 alt2\">27<\/div>\n<\/td>\n<td class=\"code\">\n<div class=\"container\">\n<div class=\"line number1 index0 alt2\"><code class=\"bash plain\">[W000 2022-04-13T11:07:07.786+02:00] Fast-Start Failover is not enabled or can't be checked. Retry after 15 seconds.<\/code><\/div>\n<div class=\"line number2 index1 alt1\"><code class=\"bash plain\">[W000 2022-04-13T11:07:22.792+02:00] Standby database has changed to DB21_SITE2.<\/code><\/div>\n<div class=\"line number3 index2 alt2\"><code class=\"bash plain\">[W000 2022-04-13T11:07:22.794+02:00] Try to connect to the primary.<\/code><\/div>\n<div class=\"line number4 index3 alt1\"><code class=\"bash plain\">[W000 2022-04-13T11:07:22.794+02:00] Try to connect to the primary DB21_SITE1.<\/code><\/div>\n<div class=\"line number5 index4 alt2\"><code class=\"bash plain\">[W000 2022-04-13T11:07:24.028+02:00] Connection to the primary restored!<\/code><\/div>\n<div class=\"line number6 index5 alt1\"><code class=\"bash plain\">[W000 2022-04-13T11:07:24.034+02:00] The standby DB21_SITE2 is ready to be a FSFO target<\/code><\/div>\n<div class=\"line number7 index6 alt2\"><code class=\"bash plain\">[W000 2022-04-13T11:07:26.036+02:00] Disconnecting from database DB21_SITE1.<\/code><\/div>\n<div class=\"line number8 index7 alt1\"><code class=\"bash plain\">[W000 2022-04-13T11:24:02.493+02:00] Primary database cannot be reached.<\/code><\/div>\n<div class=\"line number9 index8 alt2\"><code class=\"bash plain\">[W000 2022-04-13T11:24:02.494+02:00] Fast-Start Failover threshold has not exceeded. Retry <\/code><code class=\"bash keyword\">for<\/code> <code class=\"bash plain\">the next 15 seconds<\/code><\/div>\n<div class=\"line number10 index9 alt1\"><code class=\"bash plain\">[W000 2022-04-13T11:24:03.496+02:00] Try to connect to the primary.<\/code><\/div>\n<div class=\"line number11 index10 alt2\"><code class=\"bash plain\">[W000 2022-04-13T11:24:05.797+02:00] Primary database cannot be reached.<\/code><\/div>\n<div class=\"line number12 index11 alt1\"><code class=\"bash plain\">[W000 2022-04-13T11:24:06.799+02:00] Try to connect to the primary.<\/code><\/div>\n<div class=\"line number13 index12 alt2\"><code class=\"bash plain\">[W000 2022-04-13T11:24:19.665+02:00] Primary database cannot be reached.<\/code><\/div>\n<div class=\"line number14 index13 alt1\"><code class=\"bash plain\">[W000 2022-04-13T11:24:19.665+02:00] Fast-Start Failover threshold has expired.<\/code><\/div>\n<div class=\"line number15 index14 alt2\"><code class=\"bash plain\">[W000 2022-04-13T11:24:19.666+02:00] Succeeded to parse FSFO callout config <\/code><code class=\"bash functions\">file<\/code> <code class=\"bash string\">'\/u01\/app\/oracle\/admin\/prod20\/broker_files\/config_db21\/callout\/fsfocallout.ora'<\/code><\/div>\n<div class=\"line number16 index15 alt1\"><code class=\"bash plain\">[W000 2022-04-13T11:24:19.666+02:00] Try to connect to the standby.<\/code><\/div>\n<div class=\"line number17 index16 alt2\"><code class=\"bash plain\">[W000 2022-04-13T11:24:19.666+02:00] Check <\/code><code class=\"bash keyword\">if<\/code> <code class=\"bash plain\">the standby is ready <\/code><code class=\"bash keyword\">for<\/code> <code class=\"bash plain\">failover.<\/code><\/div>\n<div class=\"line number18 index17 alt1\"><code class=\"bash plain\">[W000 2022-04-13T11:24:19.685+02:00] Doing pre-FSFO callout.<\/code><\/div>\n<div class=\"line number19 index18 alt2\"><code class=\"bash plain\">[W000 2022-04-13T11:24:23.746+02:00] Failed to <\/code><code class=\"bash functions\">ping<\/code> <code class=\"bash plain\">the primary.<\/code><\/div>\n<div class=\"line number20 index19 alt1\"><code class=\"bash plain\">[W000 2022-04-13T11:24:29.821+02:00] Failed to <\/code><code class=\"bash functions\">ping<\/code> <code class=\"bash plain\">the primary.<\/code><\/div>\n<div class=\"line number21 index20 alt2\"><code class=\"bash plain\">[W000 2022-04-13T11:24:36.020+02:00] Failed to <\/code><code class=\"bash functions\">ping<\/code> <code class=\"bash plain\">the primary.<\/code><\/div>\n<div class=\"line number22 index21 alt1\"><code class=\"bash plain\">[W000 2022-04-13T11:24:41.040+02:00] Failed to <\/code><code class=\"bash functions\">ping<\/code> <code class=\"bash plain\">the primary.<\/code><\/div>\n<div class=\"line number23 index22 alt2 highlighted\"><code class=\"bash plain\">[W000 2022-04-13T11:24:41.040+02:00] Failed to detect the pre-FSFO callout suc <\/code><code class=\"bash functions\">file<\/code> <code class=\"bash string\">'\/u01\/app\/oracle\/admin\/prod20\/broker_files\/config_db21\/callout\/fsfo_precallout.suc'<\/code><code class=\"bash plain\">, or error <\/code><code class=\"bash functions\">file<\/code> <code class=\"bash string\">'\/u01\/app\/oracle\/admin\/prod20\/broker_files\/config_db21\/callout\/fsfo_precallout.err'<\/code><code class=\"bash plain\">, after 25 seconds passed.<\/code><\/div>\n<div class=\"line number24 index23 alt1 highlighted\"><code class=\"bash plain\">[W000 2022-04-13T11:24:41.040+02:00] Will not <\/code><code class=\"bash keyword\">continue<\/code> <code class=\"bash plain\">Fast-Start Failover since pre-FSFO callout failure action is STOP<\/code><\/div>\n<div class=\"line number25 index24 alt2 highlighted\"><code class=\"bash plain\">[W000 2022-04-13T11:24:41.040+02:00] Returning to primary <\/code><code class=\"bash functions\">ping<\/code> <code class=\"bash plain\">state.<\/code><\/div>\n<div class=\"line number26 index25 alt1\"><code class=\"bash plain\">[W000 2022-04-13T11:24:41.040+02:00] Try to connect to the primary.<\/code><\/div>\n<div class=\"line number27 index26 alt2\"><code class=\"bash plain\">[W000 2022-04-13T11:24:43.274+02:00] Primary database cannot be reached.<\/code><\/div>\n<\/div>\n<\/td>\n<\/tr>\n<\/tbody>\n<\/table>\n<\/div>\n<\/div>\n<p><strong>FastStartFailoverActionOnPreCalloutFailure=CONTINUE<\/strong><\/p>\n<p>If for any raison I want the fsfo to happen event if the pre-tasks fail, I have to explicitly set the value to CONTINUE<\/p>\n<p>Let&#8217;s do the same tests but with the parameter to CONTINUE<\/p>\n<div>\n<div id=\"highlighter_832848\" class=\"syntaxhighlighter  bash\">\n<table border=\"0\" cellspacing=\"0\" cellpadding=\"0\">\n<tbody>\n<tr>\n<td class=\"gutter\">\n<div class=\"line number1 index0 alt2\">1<\/div>\n<div class=\"line number2 index1 alt1\">2<\/div>\n<div class=\"line number3 index2 alt2\">3<\/div>\n<div class=\"line number4 index3 alt1\">4<\/div>\n<div class=\"line number5 index4 alt2\">5<\/div>\n<div class=\"line number6 index5 alt1 highlighted\">6<\/div>\n<div class=\"line number7 index6 alt2\">7<\/div>\n<div class=\"line number8 index7 alt1\">8<\/div>\n<\/td>\n<td class=\"code\">\n<div class=\"container\">\n<div class=\"line number1 index0 alt2\"><code class=\"bash plain\">oracle@oraadserver3:<\/code><code class=\"bash plain\">\/u01\/app\/oracle\/admin\/prod20\/broker_files\/config_db21\/callout\/<\/code> <code class=\"bash plain\">[DB21 (CDB$ROOT)] <\/code><code class=\"bash functions\">cat<\/code> <code class=\"bash plain\">fsfocallout.ora | <\/code><code class=\"bash functions\">grep<\/code> <code class=\"bash plain\">-<\/code><code class=\"bash functions\">v<\/code> <code class=\"bash plain\">^<\/code><code class=\"bash comments\">#<\/code><\/div>\n<div class=\"line number2 index1 alt1\"><code class=\"bash plain\">FastStartFailoverPreCallout=fsfo_precallout<\/code><\/div>\n<div class=\"line number3 index2 alt2\"><code class=\"bash plain\">FastStartFailoverPreCalloutTimeout=25<\/code><\/div>\n<div class=\"line number4 index3 alt1\"><code class=\"bash plain\">FastStartFailoverPreCalloutSucFileName=fsfo_precallout.suc<\/code><\/div>\n<div class=\"line number5 index4 alt2\"><code class=\"bash plain\">FastStartFailoverPreCalloutErrorFileName=fsfo_precallout.err<\/code><\/div>\n<div class=\"line number6 index5 alt1 highlighted\"><code class=\"bash plain\">FastStartFailoverActionOnPreCalloutFailure=CONTINUE<\/code><\/div>\n<div class=\"line number7 index6 alt2\"><code class=\"bash plain\">FastStartFailoverPostCallout=fsfo_postcallout<\/code><\/div>\n<div class=\"line number8 index7 alt1\"><code class=\"bash plain\">oracle@oraadserver3:<\/code><code class=\"bash plain\">\/u01\/app\/oracle\/admin\/prod20\/broker_files\/config_db21\/callout\/<\/code> <code class=\"bash plain\">[DB21 (CDB$ROOT)]<\/code><\/div>\n<\/div>\n<\/td>\n<\/tr>\n<\/tbody>\n<\/table>\n<\/div>\n<\/div>\n<p>In the observer logfile, we can see that as expected the automatic failover happens because the value is CONTINUE for the parameter.<\/p>\n<div>\n<div id=\"highlighter_910066\" class=\"syntaxhighlighter  bash\">\n<table border=\"0\" cellspacing=\"0\" cellpadding=\"0\">\n<tbody>\n<tr>\n<td class=\"gutter\">\n<div class=\"line number1 index0 alt2\">1<\/div>\n<div class=\"line number2 index1 alt1\">2<\/div>\n<div class=\"line number3 index2 alt2\">3<\/div>\n<div class=\"line number4 index3 alt1\">4<\/div>\n<div class=\"line number5 index4 alt2\">5<\/div>\n<div class=\"line number6 index5 alt1\">6<\/div>\n<div class=\"line number7 index6 alt2\">7<\/div>\n<div class=\"line number8 index7 alt1\">8<\/div>\n<div class=\"line number9 index8 alt2\">9<\/div>\n<div class=\"line number10 index9 alt1\">10<\/div>\n<div class=\"line number11 index10 alt2\">11<\/div>\n<div class=\"line number12 index11 alt1\">12<\/div>\n<div class=\"line number13 index12 alt2\">13<\/div>\n<div class=\"line number14 index13 alt1\">14<\/div>\n<div class=\"line number15 index14 alt2\">15<\/div>\n<div class=\"line number16 index15 alt1 highlighted\">16<\/div>\n<div class=\"line number17 index16 alt2 highlighted\">17<\/div>\n<div class=\"line number18 index17 alt1 highlighted\">18<\/div>\n<div class=\"line number19 index18 alt2\">19<\/div>\n<div class=\"line number20 index19 alt1\">20<\/div>\n<div class=\"line number21 index20 alt2\">21<\/div>\n<div class=\"line number22 index21 alt1\">22<\/div>\n<div class=\"line number23 index22 alt2\">23<\/div>\n<div class=\"line number24 index23 alt1\">24<\/div>\n<div class=\"line number25 index24 alt2\">25<\/div>\n<div class=\"line number26 index25 alt1\">26<\/div>\n<div class=\"line number27 index26 alt2\">27<\/div>\n<div class=\"line number28 index27 alt1\">28<\/div>\n<div class=\"line number29 index28 alt2\">29<\/div>\n<div class=\"line number30 index29 alt1\">30<\/div>\n<div class=\"line number31 index30 alt2\">31<\/div>\n<div class=\"line number32 index31 alt1\">32<\/div>\n<div class=\"line number33 index32 alt2\">33<\/div>\n<div class=\"line number34 index33 alt1\">34<\/div>\n<\/td>\n<td class=\"code\">\n<div class=\"container\">\n<div class=\"line number1 index0 alt2\"><code class=\"bash plain\">[W000 2022-04-13T11:36:15.409+02:00] Primary database cannot be reached.<\/code><\/div>\n<div class=\"line number2 index1 alt1\"><code class=\"bash plain\">[W000 2022-04-13T11:36:15.410+02:00] Fast-Start Failover threshold has not exceeded. Retry <\/code><code class=\"bash keyword\">for<\/code> <code class=\"bash plain\">the next 15 seconds<\/code><\/div>\n<div class=\"line number3 index2 alt2\"><code class=\"bash plain\">[W000 2022-04-13T11:36:16.410+02:00] Try to connect to the primary.<\/code><\/div>\n<div class=\"line number4 index3 alt1\"><code class=\"bash plain\">[W000 2022-04-13T11:36:18.949+02:00] Primary database cannot be reached.<\/code><\/div>\n<div class=\"line number5 index4 alt2\"><code class=\"bash plain\">[W000 2022-04-13T11:36:19.950+02:00] Try to connect to the primary.<\/code><\/div>\n<div class=\"line number6 index5 alt1\"><code class=\"bash plain\">[W000 2022-04-13T11:36:30.063+02:00] Primary database cannot be reached.<\/code><\/div>\n<div class=\"line number7 index6 alt2\"><code class=\"bash plain\">[W000 2022-04-13T11:36:30.063+02:00] Fast-Start Failover threshold has expired.<\/code><\/div>\n<div class=\"line number8 index7 alt1\"><code class=\"bash plain\">[W000 2022-04-13T11:36:30.072+02:00] Succeeded to parse FSFO callout config <\/code><code class=\"bash functions\">file<\/code> <code class=\"bash string\">'\/u01\/app\/oracle\/admin\/prod20\/broker_files\/config_db21\/callout\/fsfocallout.ora'<\/code><\/div>\n<div class=\"line number9 index8 alt2\"><code class=\"bash plain\">[W000 2022-04-13T11:36:30.072+02:00] Try to connect to the standby.<\/code><\/div>\n<div class=\"line number10 index9 alt1\"><code class=\"bash plain\">[W000 2022-04-13T11:36:30.072+02:00] Check <\/code><code class=\"bash keyword\">if<\/code> <code class=\"bash plain\">the standby is ready <\/code><code class=\"bash keyword\">for<\/code> <code class=\"bash plain\">failover.<\/code><\/div>\n<div class=\"line number11 index10 alt2\"><code class=\"bash plain\">[W000 2022-04-13T11:36:30.087+02:00] Doing pre-FSFO callout.<\/code><\/div>\n<div class=\"line number12 index11 alt1\"><code class=\"bash plain\">[W000 2022-04-13T11:36:34.095+02:00] Failed to <\/code><code class=\"bash functions\">ping<\/code> <code class=\"bash plain\">the primary.<\/code><\/div>\n<div class=\"line number13 index12 alt2\"><code class=\"bash plain\">[W000 2022-04-13T11:36:40.146+02:00] Failed to <\/code><code class=\"bash functions\">ping<\/code> <code class=\"bash plain\">the primary.<\/code><\/div>\n<div class=\"line number14 index13 alt1\"><code class=\"bash plain\">[W000 2022-04-13T11:36:46.255+02:00] Failed to <\/code><code class=\"bash functions\">ping<\/code> <code class=\"bash plain\">the primary.<\/code><\/div>\n<div class=\"line number15 index14 alt2\"><code class=\"bash plain\">[W000 2022-04-13T11:36:52.311+02:00] Failed to <\/code><code class=\"bash functions\">ping<\/code> <code class=\"bash plain\">the primary.<\/code><\/div>\n<div class=\"line number16 index15 alt1 highlighted\"><code class=\"bash plain\">[W000 2022-04-13T11:36:55.352+02:00] Failed to detect the pre-FSFO callout suc <\/code><code class=\"bash functions\">file<\/code> <code class=\"bash string\">'\/u01\/app\/oracle\/admin\/prod20\/broker_files\/config_db21\/callout\/fsfo_precallout.suc'<\/code><code class=\"bash plain\">, or error <\/code><code class=\"bash functions\">file<\/code> <code class=\"bash string\">'\/u01\/app\/oracle\/admin\/prod20\/broker_files\/config_db21\/callout\/fsfo_precallout.err'<\/code><code class=\"bash plain\">, after 25 seconds passed.<\/code><\/div>\n<div class=\"line number17 index16 alt2 highlighted\"><code class=\"bash plain\">[W000 2022-04-13T11:36:55.352+02:00] Will <\/code><code class=\"bash keyword\">continue<\/code> <code class=\"bash plain\">Fast-Start Failover since pre-FSFO callout failure action is CONTINUE<\/code><\/div>\n<div class=\"line number18 index17 alt1 highlighted\"><code class=\"bash plain\">[S006 2022-04-13T11:36:55.352+02:00] Fast-Start Failover started...<\/code><\/div>\n<div class=\"line number19 index18 alt2\"><\/div>\n<div class=\"line number20 index19 alt1\"><code class=\"bash plain\">2022-04-13T11:36:55.352+02:00<\/code><\/div>\n<div class=\"line number21 index20 alt2\"><code class=\"bash plain\">Initiating Fast-Start Failover to database <\/code><code class=\"bash string\">\"DB21_SITE2\"<\/code><code class=\"bash plain\">...<\/code><\/div>\n<div class=\"line number22 index21 alt1\"><code class=\"bash plain\">[S006 2022-04-13T11:36:55.352+02:00] Initiating Fast-start Failover.<\/code><\/div>\n<div class=\"line number23 index22 alt2\"><code class=\"bash plain\">2022-04-13T11:36:55.362+02:00<\/code><\/div>\n<div class=\"line number24 index23 alt1\"><code class=\"bash plain\">Performing failover NOW, please wait...<\/code><\/div>\n<div class=\"line number25 index24 alt2\"><\/div>\n<div class=\"line number26 index25 alt1\"><code class=\"bash plain\">2022-04-13T11:37:18.566+02:00<\/code><\/div>\n<div class=\"line number27 index26 alt2\"><code class=\"bash plain\">Failover succeeded, new primary is <\/code><code class=\"bash string\">\"DB21_SITE2\"<\/code><code class=\"bash plain\">.<\/code><\/div>\n<div class=\"line number28 index27 alt1\"><\/div>\n<div class=\"line number29 index28 alt2\"><code class=\"bash plain\">2022-04-13T11:37:18.566+02:00<\/code><\/div>\n<div class=\"line number30 index29 alt1\"><code class=\"bash plain\">Failover processing complete, broker ready.<\/code><\/div>\n<div class=\"line number31 index30 alt2\"><code class=\"bash plain\">2022-04-13T11:37:18.566+02:00<\/code><\/div>\n<div class=\"line number32 index31 alt1\"><code class=\"bash plain\">[S006 2022-04-13T11:37:18.566+02:00] Fast-Start Failover finished...<\/code><\/div>\n<div class=\"line number33 index32 alt2\"><code class=\"bash plain\">[W000 2022-04-13T11:37:18.566+02:00] Failover succeeded. Restart pinging.<\/code><\/div>\n<div class=\"line number34 index33 alt1\"><code class=\"bash plain\">[W000 2022-04-13T11:37:18.582+02:00] Primary database has changed to DB21_SITE2.<\/code><\/div>\n<\/div>\n<\/td>\n<\/tr>\n<\/tbody>\n<\/table>\n<\/div>\n<\/div>\n<h3>Conclusion<\/h3>\n<p>We can just say that when dealing with fsfo callout scripts, be sure that the parameter FastStartFailoverActionOnPreCalloutFailure is correctly set according your wishes.<\/p>\n","protected":false},"excerpt":{"rendered":"<p>By Mouhamadou Diaw In a previous blog I talked about the FSFO callout scripts which is a new feature with Oracle 21c with the broker. This feature will allow to execute some tasks before and after a fast-start failover. By default, the automatic failover will not happen if the pre-script fails. Maybe it&#8217;s not what [&hellip;]<\/p>\n","protected":false},"author":27,"featured_media":0,"comment_status":"open","ping_status":"open","sticky":false,"template":"","format":"standard","meta":{"_acf_changed":false,"footnotes":""},"categories":[229,198,59],"tags":[2528,2512,2513,236],"type_dbi":[],"class_list":["post-17166","post","type-post","status-publish","format-standard","hentry","category-database-administration-monitoring","category-database-management","category-oracle","tag-faststartfailoveractiononprecalloutfailure","tag-fsfo-callout-scripts","tag-oracle-21c-borker-new-feature","tag-oracle-data-guard"],"acf":[],"yoast_head":"<!-- This site is optimized with the Yoast SEO Premium plugin v27.2 (Yoast SEO v27.2) - https:\/\/yoast.com\/product\/yoast-seo-premium-wordpress\/ -->\n<title>Oracle 21c : Dealing with FastStartFailoverActionOnPreCalloutFailure - dbi Blog<\/title>\n<meta name=\"robots\" content=\"index, follow, max-snippet:-1, max-image-preview:large, max-video-preview:-1\" \/>\n<link rel=\"canonical\" href=\"https:\/\/www.dbi-services.com\/blog\/oracle-21c-dealing-with-faststartfailoveractiononprecalloutfailure\/\" \/>\n<meta property=\"og:locale\" content=\"en_US\" \/>\n<meta property=\"og:type\" content=\"article\" \/>\n<meta property=\"og:title\" content=\"Oracle 21c : Dealing with FastStartFailoverActionOnPreCalloutFailure\" \/>\n<meta property=\"og:description\" content=\"By Mouhamadou Diaw In a previous blog I talked about the FSFO callout scripts which is a new feature with Oracle 21c with the broker. This feature will allow to execute some tasks before and after a fast-start failover. By default, the automatic failover will not happen if the pre-script fails. Maybe it&#8217;s not what [&hellip;]\" \/>\n<meta property=\"og:url\" content=\"https:\/\/www.dbi-services.com\/blog\/oracle-21c-dealing-with-faststartfailoveractiononprecalloutfailure\/\" \/>\n<meta property=\"og:site_name\" content=\"dbi Blog\" \/>\n<meta property=\"article:published_time\" content=\"2022-04-14T14:39:06+00:00\" \/>\n<meta property=\"article:modified_time\" content=\"2023-06-20T08:14:20+00:00\" \/>\n<meta name=\"author\" content=\"Oracle Team\" \/>\n<meta name=\"twitter:card\" content=\"summary_large_image\" \/>\n<meta name=\"twitter:label1\" content=\"Written by\" \/>\n\t<meta name=\"twitter:data1\" content=\"Oracle Team\" \/>\n\t<meta name=\"twitter:label2\" content=\"Est. reading time\" \/>\n\t<meta name=\"twitter:data2\" content=\"5 minutes\" \/>\n<script type=\"application\/ld+json\" class=\"yoast-schema-graph\">{\"@context\":\"https:\/\/schema.org\",\"@graph\":[{\"@type\":\"Article\",\"@id\":\"https:\/\/www.dbi-services.com\/blog\/oracle-21c-dealing-with-faststartfailoveractiononprecalloutfailure\/#article\",\"isPartOf\":{\"@id\":\"https:\/\/www.dbi-services.com\/blog\/oracle-21c-dealing-with-faststartfailoveractiononprecalloutfailure\/\"},\"author\":{\"name\":\"Oracle Team\",\"@id\":\"https:\/\/www.dbi-services.com\/blog\/#\/schema\/person\/66ab87129f2d357f09971bc7936a77ee\"},\"headline\":\"Oracle 21c : Dealing with FastStartFailoverActionOnPreCalloutFailure\",\"datePublished\":\"2022-04-14T14:39:06+00:00\",\"dateModified\":\"2023-06-20T08:14:20+00:00\",\"mainEntityOfPage\":{\"@id\":\"https:\/\/www.dbi-services.com\/blog\/oracle-21c-dealing-with-faststartfailoveractiononprecalloutfailure\/\"},\"wordCount\":332,\"commentCount\":0,\"keywords\":[\"FastStartFailoverActionOnPreCalloutFailure\",\"FSFO callout scripts\",\"Oracle 21c Borker New Feature\",\"Oracle Data Guard\"],\"articleSection\":[\"Database Administration &amp; Monitoring\",\"Database management\",\"Oracle\"],\"inLanguage\":\"en-US\",\"potentialAction\":[{\"@type\":\"CommentAction\",\"name\":\"Comment\",\"target\":[\"https:\/\/www.dbi-services.com\/blog\/oracle-21c-dealing-with-faststartfailoveractiononprecalloutfailure\/#respond\"]}]},{\"@type\":\"WebPage\",\"@id\":\"https:\/\/www.dbi-services.com\/blog\/oracle-21c-dealing-with-faststartfailoveractiononprecalloutfailure\/\",\"url\":\"https:\/\/www.dbi-services.com\/blog\/oracle-21c-dealing-with-faststartfailoveractiononprecalloutfailure\/\",\"name\":\"Oracle 21c : Dealing with FastStartFailoverActionOnPreCalloutFailure - dbi Blog\",\"isPartOf\":{\"@id\":\"https:\/\/www.dbi-services.com\/blog\/#website\"},\"datePublished\":\"2022-04-14T14:39:06+00:00\",\"dateModified\":\"2023-06-20T08:14:20+00:00\",\"author\":{\"@id\":\"https:\/\/www.dbi-services.com\/blog\/#\/schema\/person\/66ab87129f2d357f09971bc7936a77ee\"},\"breadcrumb\":{\"@id\":\"https:\/\/www.dbi-services.com\/blog\/oracle-21c-dealing-with-faststartfailoveractiononprecalloutfailure\/#breadcrumb\"},\"inLanguage\":\"en-US\",\"potentialAction\":[{\"@type\":\"ReadAction\",\"target\":[\"https:\/\/www.dbi-services.com\/blog\/oracle-21c-dealing-with-faststartfailoveractiononprecalloutfailure\/\"]}]},{\"@type\":\"BreadcrumbList\",\"@id\":\"https:\/\/www.dbi-services.com\/blog\/oracle-21c-dealing-with-faststartfailoveractiononprecalloutfailure\/#breadcrumb\",\"itemListElement\":[{\"@type\":\"ListItem\",\"position\":1,\"name\":\"Accueil\",\"item\":\"https:\/\/www.dbi-services.com\/blog\/\"},{\"@type\":\"ListItem\",\"position\":2,\"name\":\"Oracle 21c : Dealing with FastStartFailoverActionOnPreCalloutFailure\"}]},{\"@type\":\"WebSite\",\"@id\":\"https:\/\/www.dbi-services.com\/blog\/#website\",\"url\":\"https:\/\/www.dbi-services.com\/blog\/\",\"name\":\"dbi Blog\",\"description\":\"\",\"potentialAction\":[{\"@type\":\"SearchAction\",\"target\":{\"@type\":\"EntryPoint\",\"urlTemplate\":\"https:\/\/www.dbi-services.com\/blog\/?s={search_term_string}\"},\"query-input\":{\"@type\":\"PropertyValueSpecification\",\"valueRequired\":true,\"valueName\":\"search_term_string\"}}],\"inLanguage\":\"en-US\"},{\"@type\":\"Person\",\"@id\":\"https:\/\/www.dbi-services.com\/blog\/#\/schema\/person\/66ab87129f2d357f09971bc7936a77ee\",\"name\":\"Oracle Team\",\"image\":{\"@type\":\"ImageObject\",\"inLanguage\":\"en-US\",\"@id\":\"https:\/\/secure.gravatar.com\/avatar\/f711f7cd2c9b09bf2627133755b569fb5be0694810cfd33033bdd095fedba86d?s=96&d=mm&r=g\",\"url\":\"https:\/\/secure.gravatar.com\/avatar\/f711f7cd2c9b09bf2627133755b569fb5be0694810cfd33033bdd095fedba86d?s=96&d=mm&r=g\",\"contentUrl\":\"https:\/\/secure.gravatar.com\/avatar\/f711f7cd2c9b09bf2627133755b569fb5be0694810cfd33033bdd095fedba86d?s=96&d=mm&r=g\",\"caption\":\"Oracle Team\"},\"url\":\"https:\/\/www.dbi-services.com\/blog\/author\/oracle-team\/\"}]}<\/script>\n<!-- \/ Yoast SEO Premium plugin. -->","yoast_head_json":{"title":"Oracle 21c : Dealing with FastStartFailoverActionOnPreCalloutFailure - dbi Blog","robots":{"index":"index","follow":"follow","max-snippet":"max-snippet:-1","max-image-preview":"max-image-preview:large","max-video-preview":"max-video-preview:-1"},"canonical":"https:\/\/www.dbi-services.com\/blog\/oracle-21c-dealing-with-faststartfailoveractiononprecalloutfailure\/","og_locale":"en_US","og_type":"article","og_title":"Oracle 21c : Dealing with FastStartFailoverActionOnPreCalloutFailure","og_description":"By Mouhamadou Diaw In a previous blog I talked about the FSFO callout scripts which is a new feature with Oracle 21c with the broker. This feature will allow to execute some tasks before and after a fast-start failover. By default, the automatic failover will not happen if the pre-script fails. Maybe it&#8217;s not what [&hellip;]","og_url":"https:\/\/www.dbi-services.com\/blog\/oracle-21c-dealing-with-faststartfailoveractiononprecalloutfailure\/","og_site_name":"dbi Blog","article_published_time":"2022-04-14T14:39:06+00:00","article_modified_time":"2023-06-20T08:14:20+00:00","author":"Oracle Team","twitter_card":"summary_large_image","twitter_misc":{"Written by":"Oracle Team","Est. reading time":"5 minutes"},"schema":{"@context":"https:\/\/schema.org","@graph":[{"@type":"Article","@id":"https:\/\/www.dbi-services.com\/blog\/oracle-21c-dealing-with-faststartfailoveractiononprecalloutfailure\/#article","isPartOf":{"@id":"https:\/\/www.dbi-services.com\/blog\/oracle-21c-dealing-with-faststartfailoveractiononprecalloutfailure\/"},"author":{"name":"Oracle Team","@id":"https:\/\/www.dbi-services.com\/blog\/#\/schema\/person\/66ab87129f2d357f09971bc7936a77ee"},"headline":"Oracle 21c : Dealing with FastStartFailoverActionOnPreCalloutFailure","datePublished":"2022-04-14T14:39:06+00:00","dateModified":"2023-06-20T08:14:20+00:00","mainEntityOfPage":{"@id":"https:\/\/www.dbi-services.com\/blog\/oracle-21c-dealing-with-faststartfailoveractiononprecalloutfailure\/"},"wordCount":332,"commentCount":0,"keywords":["FastStartFailoverActionOnPreCalloutFailure","FSFO callout scripts","Oracle 21c Borker New Feature","Oracle Data Guard"],"articleSection":["Database Administration &amp; Monitoring","Database management","Oracle"],"inLanguage":"en-US","potentialAction":[{"@type":"CommentAction","name":"Comment","target":["https:\/\/www.dbi-services.com\/blog\/oracle-21c-dealing-with-faststartfailoveractiononprecalloutfailure\/#respond"]}]},{"@type":"WebPage","@id":"https:\/\/www.dbi-services.com\/blog\/oracle-21c-dealing-with-faststartfailoveractiononprecalloutfailure\/","url":"https:\/\/www.dbi-services.com\/blog\/oracle-21c-dealing-with-faststartfailoveractiononprecalloutfailure\/","name":"Oracle 21c : Dealing with FastStartFailoverActionOnPreCalloutFailure - dbi Blog","isPartOf":{"@id":"https:\/\/www.dbi-services.com\/blog\/#website"},"datePublished":"2022-04-14T14:39:06+00:00","dateModified":"2023-06-20T08:14:20+00:00","author":{"@id":"https:\/\/www.dbi-services.com\/blog\/#\/schema\/person\/66ab87129f2d357f09971bc7936a77ee"},"breadcrumb":{"@id":"https:\/\/www.dbi-services.com\/blog\/oracle-21c-dealing-with-faststartfailoveractiononprecalloutfailure\/#breadcrumb"},"inLanguage":"en-US","potentialAction":[{"@type":"ReadAction","target":["https:\/\/www.dbi-services.com\/blog\/oracle-21c-dealing-with-faststartfailoveractiononprecalloutfailure\/"]}]},{"@type":"BreadcrumbList","@id":"https:\/\/www.dbi-services.com\/blog\/oracle-21c-dealing-with-faststartfailoveractiononprecalloutfailure\/#breadcrumb","itemListElement":[{"@type":"ListItem","position":1,"name":"Accueil","item":"https:\/\/www.dbi-services.com\/blog\/"},{"@type":"ListItem","position":2,"name":"Oracle 21c : Dealing with FastStartFailoverActionOnPreCalloutFailure"}]},{"@type":"WebSite","@id":"https:\/\/www.dbi-services.com\/blog\/#website","url":"https:\/\/www.dbi-services.com\/blog\/","name":"dbi Blog","description":"","potentialAction":[{"@type":"SearchAction","target":{"@type":"EntryPoint","urlTemplate":"https:\/\/www.dbi-services.com\/blog\/?s={search_term_string}"},"query-input":{"@type":"PropertyValueSpecification","valueRequired":true,"valueName":"search_term_string"}}],"inLanguage":"en-US"},{"@type":"Person","@id":"https:\/\/www.dbi-services.com\/blog\/#\/schema\/person\/66ab87129f2d357f09971bc7936a77ee","name":"Oracle Team","image":{"@type":"ImageObject","inLanguage":"en-US","@id":"https:\/\/secure.gravatar.com\/avatar\/f711f7cd2c9b09bf2627133755b569fb5be0694810cfd33033bdd095fedba86d?s=96&d=mm&r=g","url":"https:\/\/secure.gravatar.com\/avatar\/f711f7cd2c9b09bf2627133755b569fb5be0694810cfd33033bdd095fedba86d?s=96&d=mm&r=g","contentUrl":"https:\/\/secure.gravatar.com\/avatar\/f711f7cd2c9b09bf2627133755b569fb5be0694810cfd33033bdd095fedba86d?s=96&d=mm&r=g","caption":"Oracle Team"},"url":"https:\/\/www.dbi-services.com\/blog\/author\/oracle-team\/"}]}},"_links":{"self":[{"href":"https:\/\/www.dbi-services.com\/blog\/wp-json\/wp\/v2\/posts\/17166","targetHints":{"allow":["GET"]}}],"collection":[{"href":"https:\/\/www.dbi-services.com\/blog\/wp-json\/wp\/v2\/posts"}],"about":[{"href":"https:\/\/www.dbi-services.com\/blog\/wp-json\/wp\/v2\/types\/post"}],"author":[{"embeddable":true,"href":"https:\/\/www.dbi-services.com\/blog\/wp-json\/wp\/v2\/users\/27"}],"replies":[{"embeddable":true,"href":"https:\/\/www.dbi-services.com\/blog\/wp-json\/wp\/v2\/comments?post=17166"}],"version-history":[{"count":1,"href":"https:\/\/www.dbi-services.com\/blog\/wp-json\/wp\/v2\/posts\/17166\/revisions"}],"predecessor-version":[{"id":26138,"href":"https:\/\/www.dbi-services.com\/blog\/wp-json\/wp\/v2\/posts\/17166\/revisions\/26138"}],"wp:attachment":[{"href":"https:\/\/www.dbi-services.com\/blog\/wp-json\/wp\/v2\/media?parent=17166"}],"wp:term":[{"taxonomy":"category","embeddable":true,"href":"https:\/\/www.dbi-services.com\/blog\/wp-json\/wp\/v2\/categories?post=17166"},{"taxonomy":"post_tag","embeddable":true,"href":"https:\/\/www.dbi-services.com\/blog\/wp-json\/wp\/v2\/tags?post=17166"},{"taxonomy":"type","embeddable":true,"href":"https:\/\/www.dbi-services.com\/blog\/wp-json\/wp\/v2\/type_dbi?post=17166"}],"curies":[{"name":"wp","href":"https:\/\/api.w.org\/{rel}","templated":true}]}}