起動時にカスタム EXE を読み込む Windows Azure 用のワーカー ロール プロジェクトを作成しようとしています。ここにある David Chou の Jetty サーバーの例のコードを変更しました。
http://blogs.msdn.com/b/dachou/archive/2010/03/21/run-java-with-jetty-in-windows-azure.aspx
Visual Web Developer 2010 を使用して、Visual C# 用の新しい Cloud プロジェクトを作成し、ここに示す Worker Role クラス コードに落とし込みました。
namespace WorkerRole1
{
public class WorkerRole : RoleEntryPoint
{
public override void Run()
{
string response = "";
string S = "";
try
{
System.IO.StreamReader sr;
string port = RoleEnvironment.CurrentRoleInstance.InstanceEndpoints["HttpIn"].IPEndpoint.Port.ToString();
string roleRoot = Environment.GetEnvironmentVariable("RoleRoot");
S = "roleRoot is: " + roleRoot;
Trace.TraceInformation(S);
// string myAzureAppHome = roleRoot + @"\approot\app";
string myAzureAppHome = System.IO.Path.Combine(roleRoot + @"\", @"approot\");
S = "myAzureAppHome is: " + myAzureAppHome;
Trace.TraceInformation(S);
// string jreHome = roleRoot + @"\approot\app\jre6";
Process proc = new Process();
proc.StartInfo.UseShellExecute = false;
proc.StartInfo.RedirectStandardOutput = true;
//proc.StartInfo.FileName = String.Format("\"{0}\\bin\\java.exe\"", jreHome);
// proc.StartInfo.Arguments = String.Format("-Djetty.port={0} -Djetty.home=\"{1}\" -jar \"{1}\\start.jar\"", port, myAzureAppHome);
proc.StartInfo.FileName = String.Format("\"{0}\\myAzureAppPRJ.exe\"", myAzureAppHome);
S = "Attempting to run file: " + proc.StartInfo.FileName;
Trace.TraceInformation(S);
proc.EnableRaisingEvents = false;
proc.Start();
sr = proc.StandardOutput;
response = sr.ReadToEnd();
}
catch (Exception ex)
{
response = ex.Message;
Trace.TraceError(response);
}
}
public override bool OnStart()
{
// Set the maximum number of concurrent connections
ServicePointManager.DefaultConnectionLimit = 12;
// For information on handling configuration changes
// see the MSDN topic at http://go.microsoft.com/fwlink/?LinkId=166357.
return base.OnStart();
}
}
}
問題は、RoleRoot 用に返されるディレクトリが、ストレージ エミュレーターに対してプロジェクトを実行したときに「アプリ」サポート ファイルが表示される場所と一致しないことです。"app" フォルダーは、WindowsAzureProject2 ディレクトリ ツリーを検索して見つけた次のディレクトリにあります。
C:\Users\mycomp\Documents\Visual Studio 2010\Projects\WindowsAzureProject2\WorkerRole1\app
しかし、GetEnvironmentVariable("RoleRoot") は、Trace ステートメントによってダンプされた RoleRoot ディレクトリとして次を報告します。
C:\Users\mycomp\documents\visual studio 2010\Projects\WindowsAzureProject2\WindowsAzureProject2\bin\Debug\WindowsAzureProject2.csx\roles\WorkerRole1
もちろん、カスタムEXEファイルが後者ではなく前者のディレクトリにあるため、proc.Start()が呼び出されたときにファイルが見つからないという例外が発生します。
roleRoot パスが壊れているように見える理由と、これを修正するために何ができるかを教えてもらえますか? proc.StartInfo.FileName への割り当てで EXE の前に二重のバックスラッシュの問題があることに注意してください (Visual Web Developer C# は Visual Studio Pro C# とは異なりますか?)、それを修正しても、私が抱えているパスの問題は変わりません。 GetEnvironmentVariable("RoleRoot") フラットアウトによって返されるディレクトリには、私の「アプリ」ディレクトリが含まれていないためです。
更新:さらに読んだ後、実際に起こっているのは、「approot」ディレクトリが作成されておらず、「app」フォルダーファイルもコピーされていないことです。理由はまだわかりません。
-- ロシュラー