What's the difference between “Web” website an

2019-01-19 06:56发布

问题:

When defining a web role I can specify sites under <WebRole><Sites> element. One of the sites can have a name "Web" and then I'm not required to specify physicalDirectory for it - instead the site contents will be copied into sitesroot folder and duplicate the contents of approot and inflate the service package.

So it looks like it's a no-brainer - I should name my site any other name than "Web" and specify physicalDirectory and it will work just fine and without duplication hence a smaller package.

Is there anything I gain by naming my site "Web"? Why would I want to name it "Web" given the negative consequences?

回答1:

The "Web" site is simply the new project you created or existing project you selected when adding a WebRole to your cloud project. So the WebRole's default site (Web) is directly mapped to that web project.

This simply means it will use the assembly of that project for the RoleEntryPoint (WebRole.cs). That's why the output of that project is used in the approot (this is where the RoleEntryPoint is executed) and in the sitesroot (the IIS website).

Now if you want to keep your package small, you can indeed create a dummy site that serves only for the WebRole.cs part, and have a real site besides that. This will create 3 'folders' when deploying to Azure:

  • approot => Very small directory containing the dummy site
  • sitesroot\0 => Very small directory containing the dummy site
  • sitesroot\1 => Your real site

What you'll want to do is play with the endpoints to make sure that the dummy site is not exposed by giving it an internal endpoint:

  <WebRole name="MyWebRole" vmsize="Small">
    <Sites>
      <Site name="Web">
        <Bindings>
          <Binding name="Endpoint1" endpointName="DummyEndpoint" />
        </Bindings>
      </Site>
      <Site name="RealWebApplication" physicalDirectory="..\MvcApplication1">
        <Bindings>
          <Binding name="Endpoint2" endpointName="RealEndpoint" />
        </Bindings>
      </Site>
    </Sites>
    <Endpoints>
      <InputEndpoint name="RealEndpoint" protocol="http" port="80" />
      <InternalEndpoint name="DummyEndpoint" protocol="http" />
    </Endpoints>
    ...
  </WebRole>

And your dummy web application will look like this:



回答2:

Many months later I can't find any problems with changing the site name to anything except Web and explicitly specifying the physicalDirectory. It just works.

It just looks like Azure tools defaults are unreasonable. My .cspkg got smaller, so it takes less to prepare and less to unload and I waste much less time. I wish I found this earlier.



标签: azure package