Skip to content
Caution: You are browsing the legacy symfony 1.x part of this website.

Windows and symfony

Language

by Laurent Bonnet

Overview

This document is a new step-by-step tutorial covering the installation, deployment and functional test of the symfony framework on Windows Server 2008.

In order to prepare for Internet deployment, the tutorial can be executed in a dedicated server environment, hosted on the Internet.

Of course, it's possible to complete the tutorial on a local server, or a virtual machine at the reader's workstation.

Reason for a new Tutorial

Currently, there are two sources of information related to Microsoft Internet Information Server (IIS) on the symfony website , but they refer to previous versions that have not evolved with newer versions of Microsoft Windows operating systems, especially Windows Server 2008 (released in February, 2008), which includes many changes of interest to PHP developers:

  • IIS version 7, the version embedded in Windows Server 2008, was entirely rewritten to a fully modular design.

  • IIS 7 has proven to be very reliable, with very few fixes needed from Windows Update since the launch of the product.

  • IIS 7 also includes the FastCGI accelerator, a multi-threaded application pool that takes advantage of the native threading model of Windows operating systems.

  • The FastCGI implementation of PHP equates to a 5x to 10x performance improvement in execution, without cache, when compared to traditional ISAPI or CGI deployments of PHP on Windows and IIS.

  • More recently, Microsoft opened the curtain on a cache accelerator for PHP, which is in Release Candidate status at the time of this writing (2009-11-02).

sidebar

Planned Extension for this Tutorial

A supplemental section of this chapter is in the works and will be released on the symfony project web site shortly after the publication of this book. It covers the connection to MS SQL Server via PDO, something Microsoft is planning improvements for soon.

 [PHP_PDO_MSSQL]
 extension=php_pdo_mssql.dll

Currently, the best performance in code execution is obtained by the Microsoft native SQL Server driver for PHP 5, an open-source driver available on Windows and currently available in version 1.1. This is implemented as a new PHP extension DLL:

 [PHP_SQLSRV]
 extension=php_sqlsrv.dll

It is possible to use either Microsoft SQL Server 2005 or 2008 for the database. The planned tutorial extension will cover the usage of the edition that is available for free: SQL Server Express.

How to play with this Tutorial on different Windows Systems, including 32-bit

This document was written specifically for 64-bit editions of Windows Server 2008. However, you should be able to use other versions without any complications.

note

The exact version of operating software used in the screenshots is Windows Server 2008 Enterprise Edition with Service Pack 2, 64-bit edition.

32-bit Versions of Windows

The tutorial is easily portable to 32-bit versions of Windows, by replacing the following references in the text:

  • On 64-bit editions: C:\Program Files (x86)\ and C:\Windows\SysWOW64\

  • On 32-bit editions: C:\Program Files\ and C:\Windows\System32\

About Editions other than Enterprise

Also, if you don't have Enterprise Edition, this is not a problem. This document is directly portable to other editions of Windows Server software: Windows Server 2008 Web, Standard or Datacenter Windows Server 2008 Web, Standard or Datacenter with Service Pack 2 Windows Server 2008 R2 Web, Standard, Enterprise or Datacenter editions.

Please note that all editions of Windows Server 2008 R2 are only available as 64-bit operating systems.

About International Editions

The regional settings used in the screenshots are en-US. We also installed an international language package for France.

It is possible to execute the tutorial on Windows client operating systems: Windows XP, Windows Vista and Windows Seven both in x64 and x86 modes.

Web Server used throughout the Document

The web server used is Microsoft Internet Information Server version 7.0, which is included in all Windows Server 2008 editions as a role. We begin the tutorial with a fully functional Windows Server 2008 server and install IIS from scratch. The install steps use the default choices, we simply add two specific modules that come with the IIS 7.0 modular design: FastCGI and URL Rewrite.

Databases

SQLite is the pre-configured database for the symfony sandbox. On Windows, there's nothing specific to install: SQLite support is directly implemented in the PDO PHP extension for SQLite, which is installed at the time of PHP installation.

Hence, there's no need to download and run a separate instance of SQLITE.EXE:

  [PHP_PDO_SQLITE]
  extension=php_pdo_sqlite.dll

Windows Server Configuration

It is better to use a fresh installation of Windows Server in order to match the step-by-step screenshots in this chapter.

Of course you can work directly on an existing machine, but you may encounter differences due to installed software, runtime, and regional configurations.

In order for you to get the same screenshots as displayed in this tutorial, we recommend obtaining a dedicated Windows Server in a virtual environment, available for free on the Internet for a period of 30 days.

sidebar

How to get a free Windows Server Trial?

It is of course possible to use any dedicated server with Internet access. A physical server or even virtual dedicated server (VDS) will work perfectly.

A 30-day server with Windows is available as a trial from Ikoula, a French web host who offers a comprehensive list of services for developers and designers. This trial starts at 0 € / month for a Windows virtual machine running in a Microsoft Hyper-V environment. Yes, you can get a fully functional virtual machine with Windows Server 2008 Web, Standard, Enterprise or even Datacenter edition for FREE for a period of 30 days.

To order, just open your browser to http://www.ikoula.com/flex_server and click on the "Testez gratuitement" button.

In order to get the same messages as outlined in this document, the operating system we ordered with the Flex server is: "Windows Server 2008 Enterprise Edition 64 bits". This is an x64 distribution, delivered with both fr-FR and en-US locales. It's easy to switch from fr-FR to en-US and vice-versa from the Windows Control Panel. Specifically, this setting can be found in the "Regional and Language Options", which lives under the "Keyboards and Languages" tab. Just click on "Install/uninstall languages".

It is mandatory to have Administrator access to the server.

If working from a remote workstation, the reader should run Remote Desktop Services (formerly known as Terminal Server Client) and ensure he has Administrator access.

The distribution used here is: Windows Server 2008 with Service Pack 2.

Check your startup environment, with Winver command - here in English

Windows Server 2008 was installed with the graphical environment, which matches Windows Vista's look and feel. It is also possible to use a command-line only for version of Windows Server 2008 with the same services in order to reduce the size of the distribution (1.5 GB instead of 6.5 GB). This also reduces the attack surface and the number of Windows Update patches that will need to be applied.

Preliminary Checks - Dedicated Server on the Internet

Since the server is directly accessible on the Internet, it's always a good idea to check that the Windows Firewall is providing active protection. The only exceptions that should be checked are:

  • Core Networking
  • Remote Desktop (if accessed remotely)
  • Secure World Wide Web Services (HTTPS)
  • World Wide Web Services (HTTP)

Check firewall settings, directly from Control Panel.

Then, it's always good to run a round of Windows Update to ensure all software pieces are up-to-date with the latest fixes, patches, and documentation.

Check Windows Update status, directly from Control Panel.

As a last step of preparation, and for the sake of removing any potential conflicting parameters in the existing Windows distribution or IIS configuration, we recommend that you uninstall the Web role in Windows server, if previously installed.

Remove Web Server role, from Server Manager.

Installing PHP - Just a few Clicks away

Now, we can install IIS and PHP in one simple operation.

PHP is NOT a part of the Windows Server 2008 distribution, hence we need to first install the Microsoft Web Platform Installer 2.0, referred to as Web PI in the following sections.

Web PI takes care of installing all dependencies necessary for executing PHP on any Windows/IIS system. Hence, it deploys IIS with the minimal Role Services for the Web Server, and also provides minimal options for PHP runtime.

http://www.microsoft.com/web - Download it now.

The installation of Microsoft Web Platform Installer 2.0 contains a configuration analyzer, checks for existing modules, proposes any necessary module upgrades, and even allows you to beta-test un-released extensions of the Microsoft Web Platform.

Web PI 2.0 - First View.

Web PI 2.0 offers PHP runtime installation in one click. The selection installs the "non-thread safe" Win32 implementation of PHP, which is best associated with IIS 7 and FastCGI. It also offers the most recently tested runtime, here 5.2.11. To find it, just select the "Frameworks and Runtimes" tab on the left:

Web PI 2.0 - Frameworks and Runtimes tab.

After selecting PHP, Web PI 2.0 automatically selects all dependencies needed to service .php web pages stored on the server, including the minimal IIS 7.0 roles services:

Web PI 2.0 - Dependencies automatically added - 1/3.

Web PI 2.0 - Dependencies automatically added - 2/3.

Web PI 2.0 - Dependencies automatically added - 3/3.

Next, click on Install, then on the "I Accept" button. The installation of IIS components will begin while, in parallel, PHP is downloaded runtime and some module are updated (an update for IIS 7.0 FastCGI for instance).

Web PI 2.0 - IIS components install while updates are downloaded from the web.

Finally, the PHP setup program executes, and, after a few minutes, should display:

Web PI 2.0 - PHP Installation completed.

Click on "Finish".

The Windows Server is now listening and able to answer on port 80.

Let's check this in the browser:

Firefox - IIS 7.0 is responding on port 80.

Now, to check that PHP is correctly installed, and available from IIS, we create a small phpinfo.php file to be accessed by the default web server on port 80, at C:\inetpub\wwwroot.

Before doing this, ensure that, in Windows Explorer, we can see the correct extensions of the files. Select "Unhide Extensions for Known Files Types".

Windows Explorer - Unhide Extensions for Known Files Types.

Open Windows Explorer, and go to C:\inetpub\wwwroot. Right-click and, select "New Text Document". Rename it to phpinfo.php and copy the usual function call:

Windows Explorer - Create phpinfo.php.

Next, re-open the web browser, and put /phpinfo.php at the end of the server's URL:

Firefox - phpinfo.php Execution is OK

Finally, to ensure that symfony will install without any problems, download the http://sf-to.org/1.3/check.php.

PHP - Where to download check.php.

Copy it to the same directory as phpinfo.php (C:\inetpub\wwwroot) and rename it to check_configuration.php if necessary.

PHP - Copy and Rename check_configuration.php.

Finally, re-open the web browser one last time for now, and put /check_configuration.php at the end of the server's URL:

Firefox - check_configuration.php Execution is OK.

Executing PHP from the Command Line Interface

In order to later execute command line tasks with symfony, we need to ensure that PHP.EXE is accessible from the command prompt and executes correctly.

Open a command prompt to C:\inetpub\wwwroot and type

PHP phpinfo.php

The following error message should appear:

PHP - MSVCR71.DLL was not found.

If we don't do anything, the execution of PHP.EXE hangs on the absence of MSVCR71.DLL. So, we must find the DLL file and install it at the correct location.

This MSVCR71.DLL is an old version of the Microsoft Visual C++ runtime, which dates back to the 2003 era. It is contained in the .Net Framework 1.1 redistributable package.

The .Net Framework 1.1 redistributable package, can be downloaded at MSDN

The file we're looking for is installed in the following directory: C:\Windows\Microsoft.NET\Framework\v1.1.4322

Just copy the MSVCR71.DLL file to the following destination:

  • on x64 systems: the C:\windows\syswow64 directory
  • on x86 systems: the C:\windows\system32 directory

We can now uninstall the .Net Framework 1.1.

The PHP.EXE executable can now be run from the command prompt without error. For instance:

PHP phpinfo.php
PHP check_configuration.php

Later, we'll verify that SYMFONY.BAT (from the Sandbox distribution) also gives the expected response, which is the syntax of the symfony command.

Symfony Sandbox Installation and Usage

The following paragraph is an excerpt from the "Getting Started with symfony", "The Sandbox": page: "The sandbox is a dead-easy-to-install pre-packaged symfony project, already configured with some sensible defaults. It is a great way to practice using symfony without the hassle of a proper installation that respects the web best practices".

The sandbox is pre-configured to use SQLite as a database engine. On Windows, there's nothing specific to install: SQLite support is directly implemented in the PDO PHP extension for SQLite, which is installed at the time of PHP's installation. We already accomplished this earlier when the PHP runtime was installed via the Microsoft Web PI.

Simply check that the SQLite extension is correctly referred to in the PHP.INI file, which resides in the C:\Program Files (x86)\PHP directory, and that the DLL implementing PDO support for SQLite is set to C:\Program Files (x86)\PHP\ext\php_pdo_sqlite.dll.

PHP - Location of the php.ini Configuration File.

Download, create Directory, copy all Files

The symfony sandbox project is "ready to install and run", and comes in a .zip archive.

Download the archive and extract it to a temporary location, such as the "downloads" directory, which is available for R/W in the C:\Users\Administrator directory.

sandbox - Download and unzip the archive.

Create a directory for the final destination of the sandbox, such as F:\dev\sfsandbox:

sandbox - Create sfsandbox Directory.

Select all files - CTRL-A in Windows Explorer - from your download location (source), and copy them to the F:\dev\sfsandbox directory.

You should see 2599 items copied to the destination directory:

sandbox - Copy 2599 Items.

Execution Test

Open the command prompt. Change to F:\dev\sfsandbox and execute the following command:

PHP symfony -V

This should return:

symfony version 1.3.0 (F:\dev\sfsandbox\lib\symfony)

From the same command prompt, execute:

SYMFONY.BAT -V

This should return the same result:

symfony version 1.3.0 (F:\dev\sfsandbox\lib\symfony)

sandbox - Test Command Line - Successful.

Web Application Creation

To create a web application on the local server, we use the IIS7 manager, which is the graphical user interface control panel for all IIS related activities. All actions triggered from that UI are actually executed behind-the-scenes via the command line interface.

The IIS Manager console is accessible from the Start Menu at Programs, Administrative Tools, Internet Information Server (IIS) Manager.

Reconfigure "Default Web Site" so it does not interfere on Port 80

We want to ensure that only our symfony sandbox is responding on port 80 (HTTP). To do this, change the existing "Default Web Site" port to 8080.

IIS Manager - Edit Binding for "Default Web Site".

Please note that if Windows Firewall is active, you may have to create an exception for port 8080 to still be able to reach the "Default Web Site". For that purpose, Go to Windows Control Panel, select Windows Firewall, click on "Allow a program through Windows Firewall", and click on "Add port" to create that exception. Check the box to enable it after creation.

Windows Firewall - Create an Exception for Port 8080.

Add a new web Site for the Sandbox

Open IIS Manager from Administration Tools. On the left pane, select the "Sites" icon, and right-click. Select Add Web Site from the popup menu. Enter, for instance, "Symfony Sandbox" as the Site name, D:\dev\sfsandbox for the Physical Path, and leave the other fields unchanged. You should see this dialog box:

IIS Manager - Add Web Site.

Click OK. If a small x appears on the web site icon (in Features View / Sites), don't hesitate to click "Restart" on the right pane to make it disappear.

Check if the Web Site is Answering

From IIS Manager, select the "Symfony Sandbox" site, and, on the Right pane, click on "Browse *.80 (http)".

IIS Manager - Click on Browse port 80.

You should get an explicit error message, this is not unexpected: HTTP Error 403.14 - Forbidden. The Web server is configured to not list the contents of this directory.

This originates from the default web server configuration, which specifies that the contents of this directory should not be listed. Since no default file such as index.php or index.html exists at D:\dev\sfsandbox, the server correctly returns the "Forbidden" error message. Don't be afraid.

Internet Explorer - Normal Error.

Type http://localhost/web in the URL bar of your browser, instead of just http://localhost. You now should see your browser, by default Internet Explorer, displaying "Symfony Project Created":

IIS Manager - Type http://localhost/web in the URL. Success!

By the way, you may see a light yellow band at the top saying "Intranet settings are now turned off by default". Intranet settings are less secure than Internet settings. Click for options. Don't be afraid of this message.

To close it permanently, just right-click the yellow band, and select the appropriate option.

This screen confirms that the default index.php page was correctly loaded from D:\dev\sfsandbox\web\index.php, correctly executed, and that symfony libraries are correctly configured.

We need to perform one last task before beginning to play with the symfony sandbox: configure the front-end web page by importing URL rewrite rules. These rules are implemented as .htaccess files and can be controlled in just a few clicks in the IIS Manager.

Sandbox: Web Front-end Configuration

We want to configure the sandbox application front-end in order to begin to play with the real symfony stuff. By default, the front-end page can be reached and executes correctly when requested from the local machine (i.e. the localhost name or the 127.0.0.1 address).

Internet Explorer - frontend_dev.php page is OK from localhost.

Let's explore the "configuration", "logs" and "timers" web debug panels to ensure that the sandbox is fully functional on Windows Server 2008.

sandbox usage: configuration.

sandbox usage: logs.

sandbox usage: timers.

While we could try to request the sandbox application from the Internet or from a remote IP address, the sandbox is mostly designed as a tool to learn the symfony framework on the local machine. Hence, we'll cover details related to remote access in the last section: Project: web Front-end Configuration.

Creation of a new symfony Project

Creating a symfony project environment for real development purposes is almost as straightforward as the installation of the sandbox. We'll see the whole installation process in a simplified procedure, as it is equivalent to the sandbox's installation and deployment.

The difference is that, in this "project" section, we'll focus on the configuration of the web application to make it work from anywhere on the Internet.

Like the sandbox, the symfony project comes pre-configured to use SQLite as a database engine. This was installed and configured earlier in this chapter.

Download, create a Directory and copy the Files

Each version of symfony can be downloaded as a .zip file and then used to create a project from scratch.

Download the archive containing the library from the symfony website. Next, extract the contained directory to a temporary location, such as the "downloads" directory.

Windows Explorer - Download and unzip the project archive.

Now we need to create a directory tree for the final destination of the project. This is a bit more complicated than the sandbox.

Directory Tree Setup

Let's create a directory tree for the project. Start from the volume root, D: for instance.

Create a \dev directory on D:, and create another directory called sfproject there:

D:
MD dev
CD dev
MD sfproject
CD sfproject

We are now in: D:\dev\sfproject

From there, create a subdirectory tree, by creating the lib, vendor and symfony directories in a cascading manner:

MD lib
CD lib
MD vendor
CD vendor
MD symfony
CD symfony

We now are in: D:\dev\sfproject\lib\vendor\symfony

Windows Explorer - the project directory tree.

Select all files (CTRL-A in Windows Explorer) from your download location (source), and copy from Downloads to D:\dev\sfproject\lib\vendor\symfony. You should see 3819 items copied to the destination directory:

Windows Explorer - Copy 3819 Items.

Creation and Initialization

Open the command prompt. Change to the D:\dev\sfproject directory and execute the following command:

PHP lib\vendor\symfony\data\bin\symfony -V

This should return:

symfony version 1.3.0 (D:\dev\sfproject\lib\vendor\symfony\lib)

To initialize the project, just run the following PHP command line:

PHP lib\vendor\symfony\data\bin\symfony generate:project sfproject

This should return a list of file operations, including some chmod 777 commands:

Windows Explorer - Project Initialization OK.

Still within the command prompt, create a symfony application by running the following command:

PHP lib\vendor\symfony\data\bin\symfony generate:app sfapp

Again, this should return a list of file operations, including some chmod 777 commands.

From this point, instead of typing PHP lib\vendor\symfony\data\bin\symfony each time it's needed, copy the symfony.bat file from its origin:

copy lib\vendor\symfony\data\bin\symfony.bat

We now have a convenient command to run at the command-line prompt in D:\dev\sfproject.

Still in D:\dev\sfproject, we can run the now-classic command:

symfony -V

to get the classic answer:

symfony version 1.3.0 (D:\dev\sfproject\lib\vendor\symfony\lib)

Web Application Creation

In the following lines, we assume that you've read the "Sandbox: Web Application Creation" preliminary steps to reconfigure the "Default Web Site", so that it does not interfere on port 80.

Add a new Web Site for the Project

Open IIS Manager from Administration Tools. On the left pane, select the "Sites" icon, and right-click. Select "Add Web Site" from the popup menu. Enter, for instance, "Symfony Project" as the Site name, D:\dev\sfproject for the "Physical Path", and leave other fields unchanged; you should see this dialog box:

IIS Manager - Add Web Site.

Click OK. If a small x appears on the web site icon (in Features View / Sites), don't hesitate to click "Restart" on the right pane to make it disappear.

Check if the web Site is Answering

From IIS Manager, select the "Symfony Project" site, and, on the Right pane, click "Browse *.80 (http)".

You should get the same explicit error message as you had when trying the sandbox:

HTTP Error 403.14 - Forbidden

The Web server is configured to not list the contents of this directory.

Type http://localhost/web in the URL bar of your browser You should now see the "Symfony Project Created" page, but with one slight difference from the same page resulting from sandbox initialization: there are no images:

Internet Explorer - Symfony Project Created - no Images.

The images are not here for the moment, though they're located in an sf directory in the symfony library. It's easy to link them to the /web directory by adding a virtual directory in /web, named sf, and pointing it to D:\dev\sfproject\lib\vendor\symfony\data\web\sf.

IIS Manager - Add sf Virtual Directory.

Now we have the regular "Symfony Project Created" page with images as expected:

Internet Explorer - Symfony Project Created - with Images.

And finally, the whole symfony application is working. From the web browser, enter the URL of the web application, i.e. http://localhost/web/sfapp_dev.php:

Internet Explorer - sfapp_dev.php page is OK from localhost.

Let's perform one last test while in local mode: check the "configuration", "logs" and "timers" web debug panels to ensure that the project is fully functional.

Internet Explorer - Logs page is OK from localhost.

Application Configuration for Internet-ready Applications

Our generic symfony project is now working locally, like the sandbox, from the local host server, located at http://localhost or http://127.0.0.1.

Now, we'd like to be able to access the application from the Internet.

The default configuration of the project protects the application from being executed from a remote location, though, in reality it should be ok to access both the index.php and sfapp_dev.php files. Let's execute the project from the web browser, using the server's external IP address (e.g. 94.125.163.150) and the FQDN of our Virtual Dedicated Server (e.g. 12543hpv163150.ikoula.com). You can even use both addresses from inside the server, as they're not mapped to 127.0.0.1:

Internet Explorer - Access to index.php from Internet is OK.

Internet Explorer - Execution of sfapp_dev.php from Internet is NOT OK.

As we said before, access to index.php and sfapp_dev.php from a remote location is ok. The execution of sfapp_dev.php, however fails, as it is not allowed by default. This prevents potentially malicious users from accessing your development environment, which contains potentially sensitive information about your project. You can edit the sfapp_dev.php file to make it work, but this is strongly discouraged.

Finally, we can simulate a real domain by editing the "hosts" file.

This file performs the local FQDN name resolution without needing to install the DNS service on Windows. The DNS service is available on all editions of Windows Server 2008 R2, and also in Windows Server 2008 Standard, Enterprise and Datacenter editions.

On Windows x64 operating systems, the "hosts" file is located by default in: C:\Windows\SysWOW64\Drivers\etc

The "hosts" file is pre-populated to have the machine resolve localhost to 127.0.0.1 in IPv4, and ::1 in IPv6.

Let's add a fake real domain name, like sfwebapp.local, and have it resolve locally.

Changes applied to the "hosts" file.

Your symfony project now runs on the Web, without DNS, from a web browser session executed from within the Web server.

This work is licensed under the Creative Commons Attribution-Share Alike 3.0 Unported License license.