Open棟梁 wiki

目次

問題点

https://github.com/OpenTouryoProject/OpenTouryo/issues/164

概要

非同期処理サービス構築のチュートリアル作成前段階のメモ

準備

環境を準備する。

検証は、

を使用した。

手順

インストール

以下をインストール

Open棟梁のテンプレート

データベース

作成

セキュリティ設定

サービス・アカウントからSQL Serverにログインする。

なので、以下の手順に従って、
ローカル・システム・アカウントのログインと権限付与をする。

テーブルの作成

非同期処理サービス

設定

app.configファイルの接続文字列を設定する。

 <connectionStrings>
   <!-- SQL Server / SQL Client用 -->
   <add name="ConnectionString_SQL" connectionString="Data Source=localhost\sqlexpress;Integrated Security=SSPI;Initial Catalog=AsyncProcessingServiceDB;"/>
 </connectionStrings>

ビルド

AsyncProcessingService?をビルドする。
Visual Studioからソリューション・ファイルを開いてビルドする。

インストール

ビルド出力(*.exe)をWindowsサービスとしてインストールする。

非同期処理の開発

非同期処理のクライアントとサーバを開発する。

以下のソリューションファイルを開くと、2つのプロジェクトが開く。

"C:\root\programs\C#\Samples\AsyncSvc_sample\AsyncSvc_sample.sln"

非同期処理のクライアント

TestAsyncSvc_Sample

非同期処理をキューに登録するプログラム。

設定

app.configファイルの接続文字列を設定する。

 <connectionStrings>
   <!-- SQL Server / SQL Client用 -->
   <add name="ConnectionString_SQL" connectionString="Data Source=localhost\sqlexpress;Integrated Security=SSPI;Initial Catalog=AsyncProcessingServiceDB;"/>
 </connectionStrings>

ビルド

普通にビルドする。

非同期処理のサーバ

AsyncSvc_sample

登録された非同期処理を取り出しディスバッチする先のビジネスロジック。

ビルド

普通にビルドする。

ビルドが完了したら、非同期処理サービスのプロジェクト出力フォルダにコピーする。

"C:\root\programs\C#\Frameworks\Infrastructure\ServiceInterface\AsyncProcessingService\bin\Debug"

非同期処理サービスの実行

非同期処理のサーバの開発方法

Dam

DamKeyforABT

業務テーブルにアクセスする場合に使用するDam

DamKeyforAMT

非同期処理管理テーブルにアクセスする場合に使用するDam

接続文字列

UOC_Start(UOC_XXXX)

処理の流れ

SerializeToBase64Stringメソッド

DeserializeFromBase64Stringメソッドで、
userParameterValue?.Dataの業務データを
バイナリデータからオブジェクトへ復元する。

GetCommandValue?メソッド

非同期処理管理テーブルから
本非同期タスクのTaskIDに対応するCommandIDを取得する。

ResumeProcessing?メソッド

非同期処理管理テーブルの
本非同期タスクのTaskIDに対応するCommandIDを「0」クリアする。

Updateメソッド(業務処理)

業務処理を実行する。 必要に応じてループで実装する。

UpdateProgressRate?メソッド

非同期処理管理テーブルの
本非同期タスクのTaskIDに対応する進捗率をアップデートする。


トップ   新規 一覧 単語検索 最終更新   ヘルプ   最終更新のRSS