1

OS X 10.4.11 で launchd を使用して、FileMaker スクリプトの cron のようなスケジュールを取得するのに非常に苦労しています。(私は serverfault で私の初期の苦労について説明しました ) 最初、問題は FileMaker スクリプトが GUI を開くことだと思いました。次に、代わりに LaunchAgent を作成しました。これは、ウィンドウ リソースの使用を許可されていますが、まだうまくいきません。

意味のないもののリストを次に示します。

  1. 手動でタスクをロードした後に launchctl を使用してタスクを開始すると、すべて正常に動作します。

    sudo launchctl start my.script.name

  2. (将来の数時間ではなく) 数分後の StartInterval を選択して .plist をロードすると、すべてが機能します。(私は最初、これは何らかの形でスクリーンセーバーに関連している可能性があると考えていました.ss が実行されると、何かがガベージコレクションされるか、何かが発生します;しかし、ss が開始された後でもスケジュールされていれば、そうでない限り、動作するようです)あまりにも遠い未来です。)

  3. FileMaker プログラムの呼び出しをシェル スクリプト内にラップし、FileMaker プログラムを実行するだけでなく、タイムスタンプをログ ファイルに書き込みました。このログ ファイルを読むと、シェル スクリプトが適切なタイミングで launchd によって実際に呼び出されたことを確認できます。または、少なくとも、ほとんどの理由は次のとおりです。

  4. ログには奇妙なことが示されています。スクリプトを午後 8 時 8 分に起動するようにスケジュールすると、数秒間隔で 2 つの実行が行われます。

    [Tue Jan 24 20:07:57 CST 2012] スクリプトを実行しています!

    [Tue Jan 24 20:08:00 CST 2012] スクリプトを実行しています!

私はここでロープの終わりのようなものです - 関連するマンページ、Apple の技術文書、StackExchange サイトの他の記事を読みました。私はできる限り宿題を本当にやりました。私を助けることができる人は誰でも、深刻なカルマが彼らに向かっているでしょう.

繰り返しになりますが、下の .plist にはいくつかの粗雑な部分 (XML 定義、ログ情報) が編集されています。(覚えておいてください、これは手動でロードしたときに機能するので、plist 自体は問題ないことがわかっています。)

<plist version="1.0">
<dict>
    <key>Label</key>
    <string>shane.useragent.launcher</string>
    <key>ProgramArguments</key>
    <array>
            <string>/Users/shane/launchFM.sh</string>
    </array>
    <key>StartCalendarInterval</key>
    <dict>
            <key>Hour</key>
            <integer>20</integer>
            <key>Minute</key>
            <integer>8</integer>
    </dict>
</dict>
</plist>
4

1 に答える 1

0

これにはlaunchdを使用する必要がありますか?

組み込みの Cron 機能を使用します ( CronniX GUI を介してローカルの FileMaker ファイルを開き、FileMaker サーバーでスクリプトを実行します。

于 2012-01-25T17:29:43.517 に答える