This tutorial demonstrates deploying a CakePHP application to AppFog, a Platform as a Service (PaaS), while highlighting best practices for PHP application structure. We'll build a simple note-taking app, then organize its components for efficient management.
Key Concepts:
APP_ENV
) to control application behavior.Getting Started with AppFog:
AppFog, based on Cloud Foundry, supports various languages and deployment targets (AWS, HP OpenStack, Azure, Rackspace). Registration requires only an email and password, granting access to the free plan. Create your account to proceed.
Local Application Development:
http://fognotes.local
). Create a MySQL database (e.g., fognotes_local
).data
directory with config
and logs
subdirectories. Move the app/tmp
directory into data
and ensure the logs
directory has web server write permissions. Create a symbolic link to CakePHP's console: ln -s lib/Cake/Console/cake cake
. The resulting structure should resemble:<code>FogNotes/ app/ data/ config/ logs/ tmp/ cache/ logs/ sessions/ tests/ lib/ Cake/ plugins/ vendors/ cake index.php</code>
This structure isolates application code, framework, libraries, and data for better management.
app/webroot/index.php
to define the custom TMP
directory:<code>FogNotes/ app/ data/ config/ logs/ tmp/ cache/ logs/ sessions/ tests/ lib/ Cake/ plugins/ vendors/ cake index.php</code>
app/Config/database.php
to dynamically load database settings based on the environment:<?php // Custom TMP directory if (!defined('TMP')) { define('TMP', ROOT . DS . 'data' . DS . 'tmp' . DS); }
app/Config/bootstrap.php
to register the data/config
path and determine the environment (using APP_ENV
environment variable or defaulting to 'local'):<?php class DATABASE_CONFIG { // ... (code to dynamically load database config based on APP_ENV) ... }
data/config/local.php
and data/config/prod.php
files to hold environment-specific database settings and other configurations. Example local.php
:<?php // ... (code to register data/config path and set APP_ENV) ...
Deployment to AppFog:
fognotes_prod
).APP_ENV
variable to "prod".af
utility to push your local code to AppFog: af update FogNotes
.af tunnel
to create a tunnel to your remote database and import the data/config/notes.sql
schema.Final Steps and Summary:
Create the notes
table in your local database and use CakePHP's bake command (./cake bake
) to generate the necessary model, view, and controller. Update app/Config/routes.php
to direct the root URL to your notes index. Redeploy your application using af update FogNotes
.
This structured approach simplifies development, deployment, and maintenance of your CakePHP applications on AppFog. AppFog's cloning feature adds further flexibility for managing different environments.
The above is the detailed content of CloudSpring | Deploying CakePHP apps on AppFog the right way. For more information, please follow other related articles on the PHP Chinese website!