Book Image

Mastering Symfony

Book Image

Mastering Symfony

Overview of this book

In this book, you will learn some lesser known aspects of development with Symfony, and you will see how to use Symfony as a framework to create reliable and effective applications. You might have developed some impressive PHP libraries in other projects, but what is the point when your library is tied to one particular project? With Symfony, you can turn your code into a service and reuse it in other projects. This book starts with Symfony concepts such as bundles, routing, twig, doctrine, and more, taking you through the request/response life cycle. You will then proceed to set up development, test, and deployment environments in AWS. Then you will create reliable projects using Behat and Mink, and design business logic, cover authentication, and authorization steps in a security checking process. You will be walked through concepts such as DependencyInjection, service containers, and services, and go through steps to create customized commands for Symfony's console. Finally, the book covers performance optimization and the use of Varnish and Memcached in our project, and you are treated with the creation of database agnostic bundles and best practices.
Table of Contents (17 chapters)
Mastering Symfony
Credits
About the Author
About the Reviewers
Index

Setting up the server


Now that we have our instance set up and we are connected to it successfully, it is time to add the required tools and components to it. Basically, it is a fresh Ubuntu box with nothing on it. To make it act like a CI server, we need to install LAMP (Linux, Apache, MySQL, and PHP), Jenkins, and a few other libraries.

Installing Apache

Having the Linux in place already, let's start by installing the Apache web server:

  1. Before installing anything, first of all, update your Linux packages and install English language packs and locales:

    $ sudo apt-get update
    
  2. Then, install the locale package as follows:

    $ sudo apt-get install language-pack-en
    
  3. Now we can install Apache2 and some required modules to proxy the Jenkins server:

    $ sudo apt-get install apache2
    $ sudo a2enmod proxy
    $ sudo a2enmod proxy_http
    
  4. Now restart Apache:

    $ sudo service apache2 restart
    

Apache2 is now installed and ready to serve web requests.

Installing MySQL and PHP

To finalize the LAMP stack, we need to install...