devilbox/docs/getting-started/enter-the-php-container.rst

128 lines
3.5 KiB
ReStructuredText
Raw Normal View History

.. include:: /_includes/snippets/__ANNOUNCEMENTS__.rst
2018-07-30 09:32:40 +02:00
.. _enter_the_php_container:
2018-03-17 10:14:50 +01:00
***********************
Enter the PHP container
***********************
2018-03-17 10:49:32 +01:00
2018-07-03 15:47:58 +02:00
Another core feature of the Devilbox, is to be totally independent of what you have or have not
2018-03-17 10:49:32 +01:00
installed on your host operating system.
The Devilbox already ships with many common developer tools which are installed inside each PHP
container, so why not make use of it.
2018-03-17 12:21:46 +01:00
The only thing you might need to install on your host operating system is your favourite IDE or
editor to actually start coding.
.. seealso::
2018-06-03 20:45:01 +02:00
If you want to find out what tools are available inside the PHP container, visit the
following section: :ref:`available_tools`.
2018-03-17 12:21:46 +01:00
**Table of Contents**
.. contents:: :local:
How to enter
============
.. note::
2018-06-03 20:45:01 +02:00
You can only enter the PHP container if it is running.
2018-03-17 12:21:46 +01:00
Linux and MacOS
---------------
On Linux and MacOS you can simply execute the provided shell script: ``shell.sh``. By doing so
it will enter you into the PHP container and bring you to ``/shared/httpd``.
.. code-block:: bash
# Execute on the host operating system
host> ./shell.sh
# Now you are inside the PHP Linux container
devilbox@php-7.0.19 in /shared/httpd $
Windows
-------
On Windows you have a different script to enter the PHP container: ``shell.bat``.
Just run it and it will enter you into the PHP container and bring you to ``/shared/httpd``.
.. code-block:: bash
2018-06-03 20:45:01 +02:00
# Execute on the host operating system
C:/Users/user1/devilbox> shell.bat
2018-03-17 12:21:46 +01:00
2018-06-03 20:45:01 +02:00
# Now you are inside the PHP Linux container
devilbox@php-7.0.19 in /shared/httpd $
2018-03-17 12:21:46 +01:00
How to become root
==================
When you enter the container with the provided scripts, you are doing so as the user ``devilbox``.
If you do need to perform any actions as root (such as installing new software), you can use
the password-less ``sudo``.
.. code-block:: bash
2018-06-03 20:45:01 +02:00
# Inside the PHP Linux container as user devilbox
devilbox@php-7.0.19 in /shared/httpd $ sudo su -
2018-03-17 12:21:46 +01:00
2018-06-03 20:45:01 +02:00
# Now you are root and can do anything you want
root@php-7.0.19 in /shared/httpd $
2018-03-17 12:21:46 +01:00
.. note::
2018-06-03 20:45:01 +02:00
As this action is inside a Docker container, there is no difference between Linux, MacOS or
Windows. Every host operating system is using the same Docker container - equal accross all
platforms.
2018-03-17 12:21:46 +01:00
Tools
=====
What is available
-----------------
There are lots of tools available, for a full overview see :ref:`available_tools`.
If you think you are missing a tool, install it yourself as root, or open up an issue on github
to get it backed into the Docker image permanently.
.. seealso:: :ref:`available_tools`
How to update them
------------------
There is no need to update the tools itself. All Docker images are rebuilt every night and
automatically pushed to Docker hub to ensure versions are outdated at a maximum of 24 hours.
The only thing you have to do, is to update the Docker images itself, simply by pulling a new version.
2018-07-03 15:47:58 +02:00
.. seealso:: :ref:`update_the_devilbox_update_the_docker_images`
2018-03-17 12:21:46 +01:00
Advanced
========
This is just a short overview about the possibility to work inside the container.
If you want to dig deeper into this topic there is also a more advanced tutorial available:
2018-07-03 15:47:58 +02:00
.. seealso:: :ref:`work_inside_the_php_container`
2018-03-17 12:21:46 +01:00
Checklist
=========
* You know how to enter the PHP container on Linux, MacOS or Windows
* You know how to become ``root`` inside the PHP container
* You know what tools are available inside the PHP container
2018-03-17 12:21:46 +01:00
* You know how to update the tools by pulling new versions of the Docker images
2018-07-06 09:30:52 +02:00
.. seealso:: :ref:`troubleshooting`