Composr Tutorial: Installation on a Windows server
Written by Chris Graham
Outdated tutorial
This tutorial is outdated as it focuses on the Microsoft Web Platform Installer, which was retired in 2022.
This tutorial will show you how to get a Composr installation running on a Windows server, using IIS (maintenance status). It is written for readers with a higher expertise than the Installation on a Windows desktop tutorial is. If you want to see Composr installation steps, or information about Composr's own Web Platform Installer, see that tutorial.
If you are running a Windows desktop machine that you want to behave like a proper IIS server, this tutorial will cater for that too.
Remote desktop
This step does not apply if working from a webhosting control panelYou'll want to connect to and manage a remote server using Remote Desktop. Remote Desktop clients are available for all the main operating systems and Windows Server comes with a Remote Desktop server built in.
Pre-setup
This step does not apply if working from a webhosting control panel – and presumably this is already handledIf you are on a new server remember to install any system updates. This may actually be necessary to get some of your server software installed.
Microsoft Web Platform Installer
This step does not apply if working from a webhosting control panel – you likely have everything you need pre-installed anywayThe easiest way to install your server software is with the Microsoft Web Platform Installer. Follow the link and install it.
When Web Platform Installer installs PHP it will make sure file permissions to PHP are correct as well as automatically configuring FastCGI. These are quite hard to do manually.
You also need to install Microsoft .net 3.5 via "server roles", if it is not already installed. You can also try installing .net 3.5 manually if needed.
From the Web Platform Installer you need to install:
- IIS Express if you are not running on a real Windows Server
- IIS: CGI
- (IIS) URL Rewrite
- PHP
- (PHP) Windows Cache Extension
- SQL Server Express if you will be using SQL Server rather than MySQL and if you don't have a full SQL Server installation already
- "Microsoft Drivers (…) for PHP (…) for SQL Server in IIS" if you will be using SQL Server rather than MySQL
- MySQL Windows if you will be MySQL
- PHP Manager for IIS
Configuring PHP
This step either does not apply if working from a webhosting control panel, or would be handled in a different way by the particular control panelFrom IIS Manager, go to the PHP Manager and enable the following PHP extensions:
- wincache (for faster PHP)
- opcache (for faster PHP)
- and potentially other extensions you want
Configuring IIS
This step either does not apply if working from a webhosting control panel, or would be handled in a different way by the particular control panelYou will want to turn off IIS's own error messages so that you can properly debug PHP/Composr. Go to the site node, the Error Pages icon, and Feature Settings (on the right), then enable Detailed Errors.
Configuring file permissions
Assign 'IUSR' 'Full control' permissions to your Composr base directory. If there's a 'IIS_IUSRS' user then give this user the same permissions. Permissions should recurse through (inherit), which is the default behaviour.Caveat: If IIS is configured to use a different user then set permissions for that user. Sometimes webhosts configure IIS differently to the defaults, especially for shared hosting (they almost certainly should for shared hosting).
If you prefer atomic permissions you can use the fixperms.php script ( php fixperms.php) to do this, or you can also do it by hand. It will make things very awkward when managing addons so I don't recommend it!
Shared hosting
Things can get tricky on Windows shared hosting. Let's assume you have found what user your hosting is running under, you still need to set permissions. It's not clearly defined how to do this, but should be one of the following:- Using Windows Explorer, using Remote Desktop. This is assuming you have Remote Desktop access.
- Using a webhosting control panel interface.
It's outside the scope of this tutorial to discuss how to ensure file permissions are secure on shared hosting, but we do touch on it in the Webhosting for Composr tutorial. Really this is up to the webhost to get right.
File extraction
This step does not apply if working from a webhosting control panelYou can download Composr's manual installer direct to the server, and extract it. For your situation this will be a little more intuitive and direct than using the quick installer.
Create databases
Create databases in MySQL / SQL Server. How to do this is outside the scope of this tutorial.Composr Installation
Now proceed with installing Composr, via launching install.php in your web browser.Shell scripts (advanced)
This step does not apply if working from a webhosting control panelYou may want to install git or Cygwin, so you can make use of some of the helper_scripts.
See also
- Web Platform Installer
- IIS Express
- PHP homesite
- MySQL homesite
- phpMyAdmin
- Installation
- Using SQL Server with Composr
- Webhosting for Composr
Feedback
Please rate this tutorial:
Have a suggestion? Report an issue on the tracker.