为什么GetEnvironmentVariable()在Windows Azure中为我的RoleRoot返回了错误的目



我正在尝试为Windows Azure创建一个Worker Role项目,该项目在启动时加载自定义EXE。我改编了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#创建了一个新的云项目,并插入了他的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 + @"approotapp";
                string myAzureAppHome = System.IO.Path.Combine(roleRoot + @"", @"approot");
                S = "myAzureAppHome is: " + myAzureAppHome;
                Trace.TraceInformation(S);

                // string jreHome = roleRoot + @"approotappjre6";
                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返回的目录与我的"应用程序"支持文件显示的位置不匹配。"应用程序"文件夹最终位于我通过搜索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

当然,这会导致一个文件未找到处理时出现异常。之所以调用Start((,是因为自定义EXE文件位于前一个目录中,而不是后者。

有人能告诉我为什么roleRoot路径看起来很糟糕吗?我能做些什么来解决这个问题吗?注意,我知道在我分配给proc的EXE之前有双反斜杠问题。StartInfo.FileName(Visual Web Developer C#与Visual Studio Pro C#不同吗?(,但修复它不会改变我遇到的路径问题,因为GetEnvironmentVariable("RoleRoot"(直接返回的目录不包含我的"app"目录。

更新:在阅读了更多内容后,我发现真正发生的事情是"approt"目录没有被创建,我的"应用程序"文件夹文件也没有被复制。我仍然不明白为什么。

--roschler

看起来您没有将应用程序目录中的文件添加到Visual Studio项目中。确保添加了它们,并将其"复制到输出目录"属性设置为"始终复制"(或"更新时复制"(。然后,它们应该会像您所期望的那样,最终位于%RoleRoot%之下。

最新更新