Skip to content

Deploy React + NodeJs App

Solved Configure
25 2 4.5k 1
  • @phenomlab no config file, the app platform does everything automatically. so its better that i will create a droplet instead? but no idea on how can i configure all…

    @justoverclock have you approached Digital Ocean concerning this ?

  • @justoverclock have you approached Digital Ocean concerning this ?

    @phenomlab yeah, no response at all

  • @phenomlab yeah, no response at all

    @justoverclock Wow. I’ll need to understand a bit more in terms of the topology etc before I can help.

  • @justoverclock Wow. I’ll need to understand a bit more in terms of the topology etc before I can help.

    @phenomlab if you have some step by step guide to setup the droplet i’ll switch to that…

    for now i have a droplet with node installed, i’ve dropped all the file inside, now i’m running npm install and npm run build to install dependencies…after that i do not know how to tell the file to show 🦆

  • @phenomlab if you have some step by step guide to setup the droplet i’ll switch to that…

    for now i have a droplet with node installed, i’ve dropped all the file inside, now i’m running npm install and npm run build to install dependencies…after that i do not know how to tell the file to show 🦆

    @justoverclock I don’t have a guide for this I’m afraid.

  • @justoverclock I don’t have a guide for this I’m afraid.

    @phenomlab ok…i think i’ve managed all, now it works on a droplet…

    i have only one problem running chromium (my app use chromium)

    /home/marco/.pm2/logs/app-error.log last 15 lines:
    1|app      |     at ExecutionContext.evaluate (/home/marco/node_modules/puppetee                                              r/lib/cjs/puppeteer/common/ExecutionContext.js:110:27)
    1|app      |     at DOMWorld.evaluate (/home/marco/node_modules/puppeteer/lib/cj                                              s/puppeteer/common/DOMWorld.js:97:24)
    1|app      |     at processTicksAndRejections (node:internal/process/task_queues                                              :96:5)
    1|app      | Error: Protocol error (Runtime.callFunctionOn): Session closed. Mos                                              t likely the page has been closed.
    1|app      |     at CDPSession.send (/home/marco/node_modules/puppeteer/lib/cjs/                                              puppeteer/common/Connection.js:218:35)
    1|app      |     at ExecutionContext._evaluateInternal (/home/marco/node_modules                                              /puppeteer/lib/cjs/puppeteer/common/ExecutionContext.js:204:50)
    1|app      |     at ExecutionContext.evaluate (/home/marco/node_modules/puppetee                                              r/lib/cjs/puppeteer/common/ExecutionContext.js:110:27)
    1|app      |     at DOMWorld.evaluate (/home/marco/node_modules/puppeteer/lib/cj                                              s/puppeteer/common/DOMWorld.js:97:24)
    1|app      |     at processTicksAndRejections (node:internal/process/task_queues                                              :96:5)
    1|app      | Error: Protocol error (Runtime.callFunctionOn): Session closed. Mos                                              t likely the page has been closed.
    1|app      |     at CDPSession.send (/home/marco/node_modules/puppeteer/lib/cjs/                                              puppeteer/common/Connection.js:218:35)
    1|app      |     at ExecutionContext._evaluateInternal (/home/marco/node_modules                                              /puppeteer/lib/cjs/puppeteer/common/ExecutionContext.js:204:50)
    1|app      |     at ExecutionContext.evaluate (/home/marco/node_modules/puppetee                                              r/lib/cjs/puppeteer/common/ExecutionContext.js:110:27)
    1|app      |     at DOMWorld.evaluate (/home/marco/node_modules/puppeteer/lib/cj                                              s/puppeteer/common/DOMWorld.js:97:24)
    1|app      |     at processTicksAndRejections (node:internal/process/task_queues                                              :96:5)
    
    

    any suggestion?

  • @phenomlab ok…i think i’ve managed all, now it works on a droplet…

    i have only one problem running chromium (my app use chromium)

    /home/marco/.pm2/logs/app-error.log last 15 lines:
    1|app      |     at ExecutionContext.evaluate (/home/marco/node_modules/puppetee                                              r/lib/cjs/puppeteer/common/ExecutionContext.js:110:27)
    1|app      |     at DOMWorld.evaluate (/home/marco/node_modules/puppeteer/lib/cj                                              s/puppeteer/common/DOMWorld.js:97:24)
    1|app      |     at processTicksAndRejections (node:internal/process/task_queues                                              :96:5)
    1|app      | Error: Protocol error (Runtime.callFunctionOn): Session closed. Mos                                              t likely the page has been closed.
    1|app      |     at CDPSession.send (/home/marco/node_modules/puppeteer/lib/cjs/                                              puppeteer/common/Connection.js:218:35)
    1|app      |     at ExecutionContext._evaluateInternal (/home/marco/node_modules                                              /puppeteer/lib/cjs/puppeteer/common/ExecutionContext.js:204:50)
    1|app      |     at ExecutionContext.evaluate (/home/marco/node_modules/puppetee                                              r/lib/cjs/puppeteer/common/ExecutionContext.js:110:27)
    1|app      |     at DOMWorld.evaluate (/home/marco/node_modules/puppeteer/lib/cj                                              s/puppeteer/common/DOMWorld.js:97:24)
    1|app      |     at processTicksAndRejections (node:internal/process/task_queues                                              :96:5)
    1|app      | Error: Protocol error (Runtime.callFunctionOn): Session closed. Mos                                              t likely the page has been closed.
    1|app      |     at CDPSession.send (/home/marco/node_modules/puppeteer/lib/cjs/                                              puppeteer/common/Connection.js:218:35)
    1|app      |     at ExecutionContext._evaluateInternal (/home/marco/node_modules                                              /puppeteer/lib/cjs/puppeteer/common/ExecutionContext.js:204:50)
    1|app      |     at ExecutionContext.evaluate (/home/marco/node_modules/puppetee                                              r/lib/cjs/puppeteer/common/ExecutionContext.js:110:27)
    1|app      |     at DOMWorld.evaluate (/home/marco/node_modules/puppeteer/lib/cj                                              s/puppeteer/common/DOMWorld.js:97:24)
    1|app      |     at processTicksAndRejections (node:internal/process/task_queues                                              :96:5)
    
    

    any suggestion?

    @justoverclock Looks like it fails on unit tests. Have you added a try / catch to see what the exact error is or where it stalls ? Or perhaps you forgot an await so that the browser.close() executes before your command has terminated.

  • @justoverclock Looks like it fails on unit tests. Have you added a try / catch to see what the exact error is or where it stalls ? Or perhaps you forgot an await so that the browser.close() executes before your command has terminated.

    @phenomlab yes the logs file suggest me some missing libraries from puppeteer, i’m trying now to install all…

  • @phenomlab yes the logs file suggest me some missing libraries from puppeteer, i’m trying now to install all…

    @justoverclock Thought so.

  • @phenomlab said in Deploy React + NodeJs App:

    Thought so.

    ok everything works fine now…

    i just need some help on little things!

    now i can access my droplet with the ip address. and is only http (no https).

    so first of all i do not have nginx or other stuff right now, and i need to:

    • secure all with https
    • use a name instead of ip (not a real domain, something like appname.digitalocean.idontknow)

    is this possible?

  • @phenomlab said in Deploy React + NodeJs App:

    Thought so.

    ok everything works fine now…

    i just need some help on little things!

    now i can access my droplet with the ip address. and is only http (no https).

    so first of all i do not have nginx or other stuff right now, and i need to:

    • secure all with https
    • use a name instead of ip (not a real domain, something like appname.digitalocean.idontknow)

    is this possible?

    @justoverclock the security of HTTPS is possible, as is an nginx build, but not the FQDN you have chosen as you don’t own the digitalocean domain name space. If you wanted mytest.nydomain.com for example then this would be possible, but but for a domain you so not own or manage.

  • @justoverclock the security of HTTPS is possible, as is an nginx build, but not the FQDN you have chosen as you don’t own the digitalocean domain name space. If you wanted mytest.nydomain.com for example then this would be possible, but but for a domain you so not own or manage.

    @phenomlab i understand…

    now i’ve installed nginx…but i’m stucked…

    i’ve installed nginx and enabled the following ports

    sudo apt update
    sudo apt install nginx
    
    To                         Action      From
    --                         ------      ----
    Nginx HTTP                 ALLOW       Anywhere
    22/tcp                     ALLOW       Anywhere
    22                         ALLOW       Anywhere
    2222                       ALLOW       Anywhere
    80/tcp                     ALLOW       Anywhere
    443                        ALLOW       Anywhere
    8080                       ALLOW       Anywhere
    3030                       ALLOW       Anywhere
    Nginx HTTP (v6)            ALLOW       Anywhere (v6)
    22/tcp (v6)                ALLOW       Anywhere (v6)
    22 (v6)                    ALLOW       Anywhere (v6)
    2222 (v6)                  ALLOW       Anywhere (v6)
    80/tcp (v6)                ALLOW       Anywhere (v6)
    443 (v6)                   ALLOW       Anywhere (v6)
    8080 (v6)                  ALLOW       Anywhere (v6)
    3030 (v6)                  ALLOW       Anywhere (v6)
    

    now what i have to do to have my site running on https://21.21.21.21:8080 instead of actual http://21.21.21.21:8080 (p.s. ip is fake, not the real one)

  • @phenomlab i understand…

    now i’ve installed nginx…but i’m stucked…

    i’ve installed nginx and enabled the following ports

    sudo apt update
    sudo apt install nginx
    
    To                         Action      From
    --                         ------      ----
    Nginx HTTP                 ALLOW       Anywhere
    22/tcp                     ALLOW       Anywhere
    22                         ALLOW       Anywhere
    2222                       ALLOW       Anywhere
    80/tcp                     ALLOW       Anywhere
    443                        ALLOW       Anywhere
    8080                       ALLOW       Anywhere
    3030                       ALLOW       Anywhere
    Nginx HTTP (v6)            ALLOW       Anywhere (v6)
    22/tcp (v6)                ALLOW       Anywhere (v6)
    22 (v6)                    ALLOW       Anywhere (v6)
    2222 (v6)                  ALLOW       Anywhere (v6)
    80/tcp (v6)                ALLOW       Anywhere (v6)
    443 (v6)                   ALLOW       Anywhere (v6)
    8080 (v6)                  ALLOW       Anywhere (v6)
    3030 (v6)                  ALLOW       Anywhere (v6)
    

    now what i have to do to have my site running on https://21.21.21.21:8080 instead of actual http://21.21.21.21:8080 (p.s. ip is fake, not the real one)

    @justoverclock you’ll need a basic configuration for the nginx configuration. I expect you need a reverse proxy

  • @justoverclock you’ll need a basic configuration for the nginx configuration. I expect you need a reverse proxy

    @phenomlab at moment works fine without anything, i don’t know why :D. no way that i can configure nginx without reading some sources…but i can’t find something simple

  • @phenomlab at moment works fine without anything, i don’t know why :D. no way that i can configure nginx without reading some sources…but i can’t find something simple

    @justoverclock You just need a basic config block. Which port are you running the NodeJS app on ?

  • @phenomlab at moment works fine without anything, i don’t know why :D. no way that i can configure nginx without reading some sources…but i can’t find something simple

    @justoverclock Any update ?

    Thanks

    EDIT - marking as solved based on the below thread
    https://sudonix.com/topic/339/digitalocean-step-by-step-guide-to-nginx-configuration

  • phenomlabundefined phenomlab has marked this topic as solved on

Did this solution help you?
Did you find the suggested solution useful? Support 💗 Sudonix with a coffee
If your organisation needs deeper expertise around infrastructure, security, or technology leadership, learn more about Phenomlab Ltd. Many of the deeper technical guides behind Sudonix are published there.

Related Topics
  • How to deploy WordPress.org Developer theme

    Solved Configure wordpress theme github
    4
    1 Votes
    4 Posts
    1k Views
    @Hari the real issue here is that I don’t think it can be used as a theme for WordPress because of the dependencies it clearly has, including its own Web server. My view here is that this is designed to be a complete development environment outside of the WordPress core.
  • 4 Votes
    11 Posts
    2k Views
    @Hari Really? Can you elaborate a bit more here?
  • node vs nodejs confusion?

    Solved Configure node nodejs
    2
    1 Votes
    2 Posts
    849 Views
    @eeeee have a look at the below https://docs.nodebb.org/installing/os/ubuntu/ curl -sL https://deb.nodesource.com/setup_lts.x | sudo -E bash - sudo apt-get install -y nodejs You’ll notice that we are in fact “installing” NodeJS but never actually have a need to reference it. Here’s the nodejs --version command on my dev system [image: 1681584648061-6eb1482e-0c9b-454d-aa84-199bcc845702-image.png] More detail here https://askubuntu.com/questions/1030622/why-do-i-see-different-versions-of-node-and-nodejs
  • Updating Node and NPM

    General nodejs
    5
    1 Votes
    5 Posts
    979 Views
    @Sampo2910 said in Updating Node and NPM: Is there a way I can see what the app version of Node is? Then i could install ‘up to that’ and keep an eye out for any changes? Have a look in the source code for the app you are using, or better still, look at the GitHub page which should give you an idea of the version number which is the latest. In the source code you have running, there is typically a README file which should state the version you are running.
  • 4 Votes
    8 Posts
    3k Views
    @phenomlab Sorry to delay in responding, yes as i mentioned above, i had to remove my redis from docker and reinstall a new image with this command docker run --name=redis -p 127.0.0.1:6379:6379 -d -t redis:alpine and now when i test my ip and port on https://www.yougetsignal.com/tools/open-ports/ the status of my redis port is closed. I think which to configure firewall in droplet digital ocean is a good idea too, and i will configure soon. Thanks for the help!
  • Do i need more RAM? Plesk

    Solved Performance plesk digitalocean
    3
    1
    1 Votes
    3 Posts
    836 Views
    @Hari welcome to Grafana, the most confusing stats package there is ! According to the guidelines, you certainly have enough RAM at 4gb https://www.plesk.com/blog/various/plesk-requirements-hardware-software/
  • Virtualmin Setup DigitalOcean

    Solved Customisation virtualmin digitalocean
    26
    9 Votes
    26 Posts
    6k Views
    @Hari said in Virtualmin Setup DigitalOcean: i have felt it is very hard to manage Virtualmin the settings are confusing It’s a bit of a learning curve, admittedly, but very powerful and easy to use provided you understand the implications of what you are doing. For example, moving a VirtualMin server to subserver and then back again without changing underlying components that rely on the correct placement of the server, of course it will no longer work.
  • Digitalocean Ubuntu configuration

    Solved Linux
    33
    12 Votes
    33 Posts
    6k Views
    @phenomlab thank you! not me