0

私はColdFusion9を使用しており、Verityコレクション名「shopColl」を作成しています。5分ごとにこのコレクションのインデックス作成を行うためにCFMファイルを呼び出すタスクスケジュールを作成します。

しかし、コレクション内のインデックスを更新しようとすると、このエラーが見つかりました。

An error occurred while performing an operation in the Search Engine library.; DETAIL:The collection is not available.: com.verity.coll.VCollectionNotAvailableException: Collection down after opening. (10) 

これを解決する方法を教えていただけますか?プロセスは今夜まで前に正しいようです。

以下のコードは、タスクスケジュールがルーチンで呼び出すCFMファイルにあります。

<cfprocessingdirective  suppresswhitespace="true">

<cftry>
    <!--- pull the content --->
    <cfquery datasource="shop" name="shop.getContent">
        SELECT * 
        FROM shop
    </cfquery>


    <!--- update collection --->
    <cflock name="cfindex_lock" type="exclusive" timeout="30">

    <cfindex collection="shopColl"
             action="refresh" 
             type="custom"
             query="shop.getContent"
             key="id"
             title="title"
             body="title,description" >

    </cflock>

    <!--- Log information about document change --->
    <cflog file="updateStatus" application="No" 
      type="information" 
      text="MESSAGE: Eso shop collection updated; TIME: #now()#">


    <cfreturn true />

<cfcatch type="any">
    <!--- Log information about error --->
    <cflog file="updateStatus" application="No" 
      type="error" 
      text="MESSAGE: error in updating index -- #cfcatch.message#; DETAIL:#cfcatch.detail# TIME: #now()#">
    <cfreturn false />
</cfcatch>
</cftry>
</cfprocessingdirective>
4

1 に答える 1

1

タスク以外で実行して、所要時間を確認してください。5分以上かかる場合は、スケジュールされたタスクでデッドロックが発生している可能性があります。

于 2010-01-06T19:31:03.093 に答える