2018-12-31 13:14:29 +01:00
|
|
|
.. include:: /_includes/all.rst
|
2019-03-07 16:35:54 +01:00
|
|
|
.. include:: /_includes/snippets/__ANNOUNCEMENTS__.rst
|
2018-12-31 13:14:29 +01:00
|
|
|
|
|
|
|
.. _autostarting_nodejs_apps:
|
|
|
|
|
|
|
|
************************
|
|
|
|
Autostarting NodeJS Apps
|
|
|
|
************************
|
|
|
|
|
|
|
|
|
|
|
|
You can have all of your NodeJS applications spin up automtically as soon as you ``docker-compose up``.
|
|
|
|
This can be achieved by makeing use of |ext_lnk_tool_pm2| (Node.js Process Manager) and the
|
|
|
|
autostart feature.
|
|
|
|
|
|
|
|
.. seealso::
|
|
|
|
**Read more about how to add scripts for autostart commands:**
|
|
|
|
|
|
|
|
* :ref:`custom_scripts_per_php_version` (individually for different PHP versions)
|
|
|
|
* :ref:`custom_scripts_globally` (equal for all PHP versions)
|
|
|
|
|
|
|
|
|
|
|
|
**Table of Contents**
|
|
|
|
|
|
|
|
.. contents:: :local:
|
|
|
|
|
|
|
|
|
|
|
|
Self-built
|
|
|
|
==========
|
|
|
|
|
|
|
|
Simply add a script ending by ``.sh`` to the ``autostart/`` directory that will accomplish this.
|
|
|
|
The following example will make use of |ext_lnk_tool_pm2| to spin up your NodeJS application.
|
|
|
|
|
|
|
|
Assumption
|
|
|
|
----------
|
|
|
|
|
|
|
|
* Path to your NodeJS project (within the Docker container): ``/shared/httpd/my-node/src``
|
|
|
|
* Name of the JS file to startup: ``index.js``
|
|
|
|
|
|
|
|
The script
|
|
|
|
----------
|
|
|
|
|
|
|
|
Add the following script to ``autostart/``
|
|
|
|
|
|
|
|
.. code-block:: bash
|
|
|
|
:caption: autostart/myscript.sh
|
|
|
|
|
|
|
|
su -c "cd /shared/httpd/my-node/src; pm2 start index.js" -l devilbox
|
|
|
|
|
|
|
|
* The whole command is wrapped into ``su`` to ensure the application will be started as the user ``devilbox``.
|
|
|
|
* ``cd`` tells it to you enter the directory where ``index.js`` can be found
|
|
|
|
* And finally |ext_lnk_tool_pm2| will take care about starting up your javascript file.
|
|
|
|
|
|
|
|
Once the Devilbox is running, you can enter the PHP container and verify with ``pm2 list`` that
|
|
|
|
everything is running as expected.
|
|
|
|
|
|
|
|
|
|
|
|
Pre-built
|
|
|
|
=========
|
|
|
|
|
|
|
|
Instead of writing multiple scripts for multiple applications, you can also make use of the
|
|
|
|
pre-shipped script that allows you to start unlimitted NodeJS applications via |ext_lnk_tool_pm2|.
|
|
|
|
|
|
|
|
The following script is provided in ``autostart/run-node-js-projects.sh-example`` and needs to be
|
|
|
|
copied to a file ending by ``.sh``
|
|
|
|
|
|
|
|
.. code-block:: bash
|
|
|
|
|
|
|
|
host> cd /path/to/devilbox
|
|
|
|
host> cd autostart
|
|
|
|
host> cp run-node-js-projects.sh-example run-node-js-projects.sh
|
|
|
|
|
|
|
|
|
|
|
|
In that newly created file, you can simply add the full paths (path inside the Docker containre)
|
|
|
|
of your Javascript files that need to be started. There is already one example which is not
|
|
|
|
commented. Change this to your path and add as many lines as you have projects to startup.
|
|
|
|
|
2019-01-03 17:57:35 +01:00
|
|
|
.. literalinclude:: ../../autostart/run-node-js-projects.sh-example
|
2018-12-31 13:14:29 +01:00
|
|
|
:caption: autostart/run-node-js-projects.sh
|
|
|
|
:language: bash
|
|
|
|
:emphasize-lines: 16
|
|
|
|
|
|
|
|
|
|
|
|
Reverse proxy NodeJS
|
|
|
|
====================
|
|
|
|
|
|
|
|
If you also want to know how to reverse proxy your NodeJS service and have it available via the web
|
|
|
|
server including HTTPS support have a look at the following links:
|
|
|
|
|
|
|
|
.. seealso::
|
|
|
|
|
|
|
|
* :ref:`reverse_proxy_with_https`
|
|
|
|
* :ref:`example_setup_reverse_proxy_nodejs`
|
|
|
|
|
|
|
|
|
|
|
|
Imagine you have started an application within the PHP container that creates a listening port
|
|
|
|
(e.g.: NodeJS). This will now only listen on the PHP container and you would have to adjust
|
|
|
|
the docker-compose.yml definition in order to have that port available outside to your host OS.
|
|
|
|
|
|
|
|
Alternatively, there is a simple way to reverse proxy it to the already running web server and even
|
|
|
|
make use of the already available HTTPS feature.
|