GitXplorerGitXplorer
g

aspnetcore-iis-ps-publish

public
14 stars
6 forks
0 issues

Commits

List of commits on branch master.
Unverified
35eca5021342e696a141343f356fc7314fed2e2a

Update instructions in script

committed 9 years ago
Unverified
7f4595bf8befcdfa643727f94e637fc86e4b47e8

Update README

committed 9 years ago
Unverified
68267ff9aadae4c3c11f8f2e21dbd9370f9a2342

Update README

committed 9 years ago
Unverified
19172273b378d0def1e5f08671a3758dee278855

React to MS Core name change

committed 9 years ago
Unverified
53a37d822ce16ba0e0860082f105d19765d08f0d

Update for dotnet cli

committed 9 years ago
Unverified
45bccebd583487a1ec48055da1ad477c1b9de54c

Update ReadMe

committed 9 years ago

README

The README file for this repository.

netcore-iis-ps-publish

Experimental script for publishing ASP.NET Core projects to one or more IIS servers.

Updated for dotnet cli!!!

Yes! dotnet cli publishing, based on a flat output structure, is radically different from what we had with DNX. This script has been updated to work with dotnet cli projects.

WARNING!

This script is highly EXPERIMENTAL! Do not use with any application publishing in a production environment without serious testing. Use at your own risk.

Requirements

The installer for WS2012R2 is Win8.1AndW2K12R2-KB3066437-x64.msu.

Notes

The chunking algorithm for sending large files in a PSSession is adapted from "Send-File" from the Windows PowerShell Cookbook ISBN: 1449320686 (O'Reilly) by Lee Holmes (http://www.leeholmes.com/guide) Code: http://poshcode.org/2216

For Azure Cloud Services, make sure the certificate for your cloud service is installed locally. For tips on doing this for Azure Cloud Services (Azure VM's), see the TechThoughts blog post.

Configuration

Provide the path to the output folder of your project, which is the folder that contains your wwwroot, refs, and any contents folders that you specified in project.json. You'll also see a number of DLL's and your application's executable (.exe), program database (.pdb), dependency (.dep), and DLL (.dll) files. For example, the path for a netcoreapp1.0 win10-x64 target platform, runtime, and payload would be in this format: C:\My_Cool_Project\My_Project_Assets_Folder\bin\Release\netcoreapp1.0\win10-x64\publish.

$sourcePathToOutput = '<PATH_TO_LOCAL_PUBLISH_FOLDER>'

Provide server data in the array.

$servers = @(
    ('<CLOUD_SERVICE>.cloudapp.net',55000,'<ADMIN_USERNAME>','<IIS_WEBSITE_NAME>','<PATH_TO_WEBSITE_FOLDER>'),
    ('<CLOUD_SERVICE>.cloudapp.net',55001,'<ADMIN_USERNAME>','<IIS_WEBSITE_NAME>','<PATH_TO_WEBSITE_FOLDER>'),
    ('<CLOUD_SERVICE>.cloudapp.net',55002,'<ADMIN_USERNAME>','<IIS_WEBSITE_NAME>','<PATH_TO_WEBSITE_FOLDER>')
)

The sample (and the script itself) demonstrates using Azure Cloud Services and Azure VM's, but the script should work just as well on-prem. Change the address of the server to the server's IP address. Indicate the server's port where PowerShell is listening. If you don't port map it away, it's typically 5986 for SSL.

In the Azure scenario, note that these ports have been mapped in the Azure portal for these VM's: e.g., 55000 -> 5986, 55001 -> 5986, 55002 -> 5986. Each server under a Cloud Service endpoint (mycloudservice.cloudapp.net) must have a single, dedicated endpoint setup this way in the Azure portal.

Make sure that the path to the website folder in the script array is to the folder that holds the website deployment on the server.

Example

Say we have two Azure Cloud Services (myeastusservice.cloudapp.net and mywestusservice.cloudapp.net), each with two VM's. Each of the two VM's have had a dedicated port mapped to 5986 for SSL PowerShell. The web application has the same name on each VM, and the physical path is pointed to a data drive (F:) in the same location. This is how the array should be setup for this example:

$sourcePathToOutput = 'C:\_APPLICATIONS\corporate_public\bin\Release\netcoreapp1.0\win10-x64\publish'

$servers = @(
    ('myeastusservice.cloudapp.net',50000,'adminuser','corporate_public','F:\corporate_public'),
    ('myeastusservice.cloudapp.net',50001,'adminuser','corporate_public','F:\corporate_public'),
    ('mywestusservice.cloudapp.net',50000,'adminuser','corporate_public','F:\corporate_public'),
    ('mywestusservice.cloudapp.net',50001,'adminuser','corporate_public','F:\corporate_public')
)

Processing

  1. Create a manifest of the project's payload folder
  2. Update the application on each Azure VM
  3. Take credentials for the server and establish a PowerShell session
  4. Establish a deployment folder for the deployment on the server
  5. Check payload items on the server by hash comparison and send up any payload items from the local project to the deployment folder
  6. Deploy the payload on the server from the deployment folder to the application folder 1. Stop the AppPool (to prevent file locks) 2. Copy payload items (if needed) 3. Restart the AppPool
  7. Disconnect and remove the PowerShell session to the server