Deploying Drupal 7 on Windows Azure | Déploiement de Drupal 7 sur Windows Azure
Article
English
Français
This article shows most of the steps decribed on the Interoperability Bridges web site. The main differences are that it shows more screen shots, it is tested against Windows Azure SDK 1.6 (Nov. 2011) with latest available package (Drupal 7.9), the package is slighty customized before uploading, and explanations are also in French .
Cet article montre la plupart des étapes qui sont décrites sur le site Web Interoperability Bridges. Les différences les plus importantes sont qu’il y a plus de copies d’écrans, il a été testé avec Windows Azure SDK 1.6 (Novembre 2011) avec le dernier package du moment (Drupal 7.9), le paquet est également modifié légèrement avant chargement sur Windows Azure. De plus, les explications sont aussi en français .
The starting point in this blog post are: - a local Windows Server 2008 R2 development environment with Windows Azure SDK 1.6 installed. - An active Windows Azure subscription. You may get one from https://windowsazure.fr for instance. - An Azure SQL Server setup in a local region (North Europe in this example) with correct firewall rules (cf instructions here)- Windows Azure SDK for PHP installed as described in this post.
Le point de départ de ce billet est constitué des éléments suivants: - un serveur local Windows Server 2008 R2- un environnement de développement local avec le SDK 1.6 de Windows Azure installé - un abonnement à Windows Azure en cours de validité. Il est possible de s’en procurer un à partir de https://windowsazure.fr par exemple.- un serveur SQL Azure créé dans une région local (Europe du Nord dans cet exemple) avec les bonnes règles de pare-feu (voir instructions ici)- Le SDK Windows Azure pour PHP installé tel que décrit dans ce billet.
The main steps are the following
Les principales étapes sont schématisées ainsi
Then a few steps happen inside Drupal itself to configure it.
D’autres étapes sont également nécessaires ensuite dans Drupal lui-même pour le configurer.
Let’s get started.
Démarrons.
Create a SQL Azure database
Créer une base SQL Azure
In order to avoid using the sysadmin login to connect to this drupal database, create a drupal login which will be the owner of the database. This can be done from the SQL Server Management Studio (from the developmenet environment) or from the management portal
De façon à éviter d’utiliser un compte de connexion administrateur du serveur SQL Azure pour se connecter à la base drupal, créons un compte pour drupal qui sera propriétaire de la base. Cela peut être fait depuis SQL Server Management Studio (depuis l’environnement de développement) ou depuis le portail de gestion
the code of the query is
le code de la requête est le suivant
CREATE LOGIN drupalLogin WITH PASSWORD = 'BVvvgdjs65'
Connect to the drupal database now (instead of the master database)
Se connecter maintenant sur la base drupal (à la place de la base master)
(sames steps as before) The script is the following:
(mêmes étapes qu’avant)Le script est le suivant:
CREATE USER drupalUser FOR LOGIN drupalLogin WITH DEFAULT_SCHEMA = dbo
GO
EXEC sp_addrolemember N'db_owner', N'drupalUser'
GO
Let’s now create a strorage account from the Windows Azure Management portal
Créons maintenant un compte de stockage depuis le portail de gestion Windows Azure
NB: create the storage account in the same region as the SQL Azure Server (North Europe in this example).
NB: créer le compte de stockage dans la même région que le serveur SQL Azure (Europe du Nord dans cet exemple)
…
At this stage, we have the following assets and credentials (NB: no need to try to use the passwords and keys, they have been changed since this post was written).
A cette étape, on dispose des crédentités suivantes (NB: n’essayez pas d’utiliser ces mots de passe et clefs, ils ont été changés depuis l’écriture de ce billet)
Modifions maintenant les fichiers .cscfg et .csdef.
NB: The .csdef file corresponds to what cannot be changed after packaging, while .cscfg file may be changed at runtime from the Windows Azure Portal or other means (API, …)
NB: le fichier .csdef correspond à ce qui ne peut pas être changé après avoir créer le paquet de déploiement, alors que le fichier .cscfg peut être changé au moment de l’exécution depuis le portail de gestion Windows Azure ou d’autres moyens (API, …)
In this example, this is done with notepad++, but this can also be done with any text editor, even notepad. The advantage of an editor that has XML syntax colorization is that it is less error prone, especially while dealing with XML comments.
Dans cet exemple, cela est fait avec notepad++, mais cela peut aussi être fait avec n’importe quel éditeur de texte, y compris notepad. L’avantage d’un éditeur qui dispose de coloration syntaxique XML est que cela peut éviter des erreurs, en particulier quand on est en train de supprimer des commentaires XML.
Optionally, if you want to enable remote desktop, i.e. being able to access to any server in the web farm once installed to Windows Azure, you may add the corresponding lines in the .csdef and .cscfg files. This is documented here. For instance:
Optionnellement, si on veut autoriser l’accsè au bureau à distance, c’est-à-dire être capcable de se connecter à n’importe quel serveur de la ferme une fois installée dans Windows Azure, il est possible d’ajouter les lignes correspondantes dans les fichiers .csdef et .cscfg. Cela est documenté ici. Par exemple:
Another important change is to choose the number of instances that the web farm will start with
Un autre changement important est de choisir le nombre d’instances avec laquelle la ferme Web sera initialement déployée
You may also want to change the size of a Virtual Machine inside the web farm. This is a .csdef parameter (i.e. changing it requires re-packaging and re-deployment). Possibles values for vmsize parameter are documented on MSDN web site.
On peut aussi vouloir changer la taille de chaque machine virtuelle dans la ferme Web. C’est un paramètre .csdef (et donc le modifier suppose de repackager et de redéployer). Les valeurs possibles pour le paramètre vmsize sont documentées sur le site MSDN.
So here is what can end up with, as an example, for the 2 files
Donc voici ce à quoi on peut aboutir, par exemple, pour les 2 fichiers
/**
* Internal function: prepare a query by calling PDO directly.
*
* This function has to be public because it is called by other parts of the
* database layer, but do not call it directly, as you risk locking down the
* PHP process.
*/
public function PDOPrepare($query, array $options = array()) {
if (!$this->bypassQueryPreprocess) {
$query = $this->preprocessQuery($query);
}
// THIS FIX IS TEMPORARY UNTIL MICROSOFT MOVE THE IMPLEMENTATION
// OF THIS ATTRIBUTE IN THE PDO DRIVER OPTIONS.
// Let's emulate the attributes preparation because it costs a little
// bit more to have it disabled than enabled and because we are not
// leveraging the benefits of it.
$options[PDO::ATTR_EMULATE_PREPARES] = TRUE;
return parent::prepare($query, $options);
}
by this one (the fix does not work with SQL Azure)
par celle-ci (la correction ne fonctionne pas pour SQL Azure)
/**
* Internal function: prepare a query by calling PDO directly.
*
* This function has to be public because it is called by other parts of the
* database layer, but do not call it directly, as you risk locking down the
* PHP process.
*/
public function PDOPrepare($query, array $options = array()) {
$query = $this->preprocessQuery($query);
return parent::prepare($query, $options);
}
You may also want to add an SMTP Server. Windows Azure does not provide one, but it is possible to connect to an external one.Like for other parameters, this can be done by updating the following file:
On peut aussi vouloir ajouter un serveur SMTP. Windows Azure n’en fournit pas, mais il est possible de se connecter à un serveur externe. Comme pour d’autres paramètres, cela peut se faire en modifiant le fichier suivant:
C:\Temp\Drupal01\WebRole\php\php.ini
Let’s now create the package from the package sources. Go to C:\Temp and create a text file named package-drupal.cmd containing the following code:
Créons maintenant le paquet de déploiement à partir des sources du paquet de déploiement. Aller à C:\Temp et créer un fichier texte appelé package-drupal.cmd contenant le code suivant:
this created the Windows Azure Package (.cspkg), that goes with the .cscfg file. They will both be uploaded to Windows Azure.
Cela a crée le paquet de déploiement pour Windows Azure (.cspkg), qui va avec le fichier .cscfg. Les deux devront être déployés vers Windows Azure.
In order to deploy, go to the Windows Azure portal,
Pour déployer, aller dans le portail Windows Azure
If you haven’t done so yet, create a hosted service.
Si ce n’est déjà fait, créer un service hébergé
Note that the choosen hosted service must be in the same region as SQL Azure and Windows Azure storage (North Europe) and it must be the same as the one used when optionally setting remote desktop.
A noter: le service hébergé choisi doit être dans la même région que SQL Azure et le stockage (Europe du Nord) et être le même que celui utilisé lors de l’éventuel ajout de l’accès au bureau à distance.
Select the hosted service and choose to deploy
Choisir le service hébergé et déployer
The two files to deploy are the ones in C:\Temp. The deployment name is whatever you choose.
Les deux fichiers à déployer sont ceux dans C:\temp. Le nom de déploiement peut être choisi librement
After a few minutes, the application is available and can be reached at the URL shown in the portal
Après quelques minutes, l’application est disponible et peut être atteinte par l’URL montrée dans le portail
If you click on the URL you will get this error
Si on clique sur l’URL, on a l’erreur suivante
PDOException: SQLSTATE[IMSSP]: An invalid statement option was specified.: SELECT SCHEMA_NAME(); Array ( ) in lock_may_be_available() (line 167 of E:\approot\includes\lock.inc).
This is because you firt need to initialize the database by running install.php. Add install.php to the URL. In our example, as the hosted service is named appazure, the URL is
C’est parce qu’il faut d’abord initialiser la base en exécutant install.php. Ajouter install.php à l’URL. Dans notre exemple, comme le service hébergé s’appelle appazure, l’URL est
In the next page enter the drupalLogin password (BVvvgdjs65)
Dans la page suivante, entrer le mot de passe du compte drupalLogin (BVvvgdjs65)
In next screen, a Drupal Admin password is created (LNdevikw03 in this example, do no try it, it is not the real one!)
Dans l’écran suivant, un mot de passe d’administrateur Drupal est créé (LNdevikw03 dans cet exemple, mais là encore ce mot de passe n’est pas le vrai, ne pas l’essayer!)
The warning would not have happened if we had set an SMTP server in php.ini which was not done in this example. Windows Azure does not provide an SMTP server so you need to bring one from your network provider for instance.In this example, we ignore the warning, and we’ll receive no e-mail.
Le message d’avertissement ne serait pas apparu si on avant renseigné plus haut le serveur SMTP dans le fichier php.ini, ce qui n’a pas été fait dans cet exemple.Windows Azure ne fournit pas de serveur SMTP donc il faut utiliser celui qu’on fournit depuis sont fournisseur d’accès à Internet par exemple. Dans cet exemple, on ignore le message d’avertissement, et l’on ne recevra pas de message.
Here is now where we give the credentials of the Windows Azure storage (drupal111205a) we created above.
Voici maintenant où l’on entre les crédentités du compte de stockage Windows Azure (drupal111205a) que l’on avait créé plus haut.
After publishing an article with an image, you can see that the image is stored in Windows Azure blob storage
Après avoir publié un article avec une image, on peut voir que cette image a été stockée dans un blob Windows Azure