-
-
Notifications
You must be signed in to change notification settings - Fork 219
Installing (VPS)
In this walkthrough, we are going to install BookCars on a VPS running under Ubuntu 22.04 with at least 1GB of RAM and one CPU.
We will to use Apache as a web server and MongoDB Atlas free tier as database server. The free tier provides 512MB of storage which is largely enough for testing purposes. On production, you should use your own MongoDB server or choose another plan.
- Install git:
sudo apt update sudo apt install git
- Install Node.js:
Update
curl -fsSL https://deb.nodesource.com/setup_20.x | sudo -E bash - &&\ sudo apt install -y nodejs
npm
to its latest version:sudo npm i -g npm
- Install Apache server:
After letting the command run and all required packages are installed, test it out by typing in the IP address of the VPS on a web browser.
sudo apt update sudo apt install apache2
- Create and configure MongoDB Atlas account:
- Create a an account or login to MongoDB Atlas
- Fill out the forms and click on Finish
- Choose M0 Free
- You can change the name of the cluster or leave Cluster0
- Choose the Provider (AWS, Google Cloud or Azure)
- Choose the Region
- Click on Create Deployment
- Set admin as database username and save the generated password somewhere safe. You will need it later. Then, click on Create Database User.
- Click on Choose a Connection Method and select Node.js as Driver. Copy the connection string somewhere safe. We will need it later. The connection string looks like this:
mongodb+srv://admin:[email protected]/?retryWrites=true&w=majority&appName=Cluster0
- Click on Review setup steps then on Done.
- On the left panel under Security, click on Network Access. Then, click on ADD IP ADDRESS. Then in Access List Entry, enter the IP address of the VPS to allow the VPS accessing MongoDB Atlas server. Finally, click on Confirm.
-
Clone BookCars repo:
cd /opt sudo git clone https://github.com/aelassas/bookcars.git
-
Add permissions:
sudo chown -R $USER:$USER /opt/bookcars
-
Create BookCars service:
sudo cp /opt/bookcars/__services/bookcars.service /etc/systemd/system sudo systemctl enable bookcars.service
-
Create
/opt/bookcars/api/.env
file with the following content:NODE_ENV=production BC_PORT=4002 BC_HTTPS=false BC_PRIVATE_KEY=/etc/ssl/bookcars.ma.key BC_CERTIFICATE=/etc/ssl/bookcars.ma.crt BC_DB_URI=mongodb+srv://admin:[email protected]/bookcars?retryWrites=true&w=majority&appName=Cluster0 BC_DB_SSL=false BC_DB_SSL_CERT=/etc/ssl/bookcars.ma.crt BC_DB_SSL_CA=/etc/ssl/bookcars.ma.ca.pem BC_DB_DEBUG=false BC_COOKIE_SECRET=COOKIE_SECRET BC_AUTH_COOKIE_DOMAIN=localhost BC_JWT_SECRET=JWT_SECRET BC_JWT_EXPIRE_AT=86400 BC_TOKEN_EXPIRE_AT=86400 BC_SMTP_HOST=smtp.sendgrid.net BC_SMTP_PORT=587 BC_SMTP_USER=apikey BC_SMTP_PASS=PASSWORD [email protected] BC_CDN_USERS=/var/www/cdn/bookcars/users BC_CDN_TEMP_USERS=/var/www/cdn/bookcars/temp/users BC_CDN_CARS=/var/www/cdn/bookcars/cars BC_CDN_TEMP_CARS=/var/www/cdn/bookcars/temp/cars BC_CDN_LOCATIONS=/var/www/cdn/bookcars/locations BC_CDN_TEMP_LOCATIONS=/var/www/cdn/bookcars/temp/locations BC_CDN_CONTRACTS=/var/www/cdn/bookcars/contracts BC_CDN_TEMP_CONTRACTS=/var/www/cdn/bookcars/temp/contracts BC_CDN_LICENSES=/var/www/cdn/bookcars/licenses BC_CDN_TEMP_LICENSES=/var/www/cdn/bookcars/temp/licenses BC_DEFAULT_LANGUAGE=en BC_BACKEND_HOST=http://localhost:3001/ BC_FRONTEND_HOST=http://localhost/ BC_MINIMUM_AGE=21 BC_EXPO_ACCESS_TOKEN=EXPO_ACCESS_TOKEN BC_STRIPE_SECRET_KEY=STRIPE_SECRET_KEY [email protected] BC_RECAPTCHA_SECRET=RECAPTCHA_SECRET
Set the following options:
BC_DB_URI=mongodb+srv://admin:[email protected]/bookcars?retryWrites=true&w=majority&appName=Cluster0 BC_COOKIE_SECRET=COOKIE_SECRET BC_AUTH_COOKIE_DOMAIN=localhost BC_JWT_SECRET=JWT_SECRET BC_SMTP_HOST=smtp.sendgrid.net BC_SMTP_PORT=587 BC_SMTP_USER=apikey BC_SMTP_PASS=PASSWORD [email protected] BC_BACKEND_HOST=http://localhost:3001/ BC_FRONTEND_HOST=http://localhost/ BC_STRIPE_SECRET_KEY=STRIPE_SECRET_KEY BC_RECAPTCHA_SECRET=RECAPTCHA_SECRET
Put you MongoDB Atlas URI in
BC_DB_URI
and don't forgetmongodb.net/bookcars
. ReplaceJWT_SECRET
with a secret token of your choice.COOKIE_SECRET
andJWT_SECRET
should at least be 32 characters long, but the longer the better. You can use an online password generator and set the password length to 32 or longer.Finally, set the SMTP options. SMTP options are necessary for sign up. You can use sendgrid or any other transactional email provider.
If you choose sendgrid, create an account on sendgrid.com, login and go to the dashboard. On the left panel, click on Email API, then on Integration Guide. Then, choose SMTP Relay and follow the steps. You will be prompted to create an API Key. Once you create the API Key and verify the smtp relay, copy the API key in
BC_SMTP_PASS
in ./api/.env. Sendgrid's free plan allows to send up to 100 emails/day. If you need to send more than 100 emails/day, switch to a paid plan or choose another transactional email provider.The following settings are very important and if they are not set properly, authentication won't work:
BC_AUTH_COOKIE_DOMAIN=localhost BC_BACKEND_HOST=http://localhost:3001/ BC_FRONTEND_HOST=http://localhost/
Replace
localhost
with an IP or FQDN. That is if you access the backend from http://<FQDN>:3001/.BC_BACKEND_HOST
should be http://<FQDN>:3001/. The same goes forBC_FRONTEND_HOST
. AndBC_AUTH_COOKIE_DOMAIN
should be FQDN.If you want to enable push notifications in the mobile app, follow these instructions and set the following option:
BC_EXPO_ACCESS_TOKEN=EXPO_ACCESS_TOKEN
If you want to enable stripe payment gateway, sign up for a stripe account, fill the forms and save the publishable key and the secret key from stripe dashboard. Then, set the secret key in the following option in api/.env:
BC_STRIPE_SECRET_KEY=STRIPE_SECRET_KEY
Don't expose stripe secret key on a website or embed it in a mobile application. It must be secret and stored securely in the server-side.
In stripe, all accounts have a total of four API keys by default-two for test mode and two for live mode:
- Test mode secret key: Use this key to authenticate requests on your server when in test mode. By default, you can use this key to perform any API request without restriction.
- Test mode publishable key: Use this key for testing purposes in your web or mobile app’s client-side code.
- Live mode secret key: Use this key to authenticate requests on your server when in live mode. By default, you can use this key to perform any API request without restriction.
- Live mode publishable key: Use this key, when you’re ready to launch your app, in your web or mobile app’s client-side code.
Use only your test API keys for testing. This ensures that you don't accidentally modify your live customers or charges.
If you want to enable HTTPS, you have to set the following options:
BC_HTTPS=true BC_PRIVATE_KEY=/etc/ssl/bookcars.ma.key BC_CERTIFICATE=/etc/ssl/bookcars.ma.crt
If you want to use Google reCAPTCHA on the frontend, you need to set:
BC_RECAPTCHA_SECRET=RECAPTCHA_SECRET
-
Create
cdn
folder:sudo mkdir -p /var/www/cdn/bookcars sudo chown -R $USER:$USER /var/www/cdn/bookcars
-
Start bookcars service:
cd /opt/bookcars/api npm install sudo systemctl start bookcars.service
Make sure that bookcars service is running with the following command:
sudo systemctl status bookcars.service
Make sure that the database connection is established by checking the logs with the following command:
tail -f /var/log/bookcars.log
Or this one:
sudo journalctl -xfu bookcars.service
Or by opening this file:
tail -f /opt/bookcars/api/logs/all.log
Error logs are written in:
tail -f /opt/bookcars/api/logs/error.log
-
If you want to use the demo database, follow this step otherwise you can skip it.
- On your desktop PC, Download and install MongoDB Command Line Database Tools.
- On Windows, add MongoDB Command Line Database Tools folder to
Path
environment variable. - Download bookcars-db.zip down to your machine, unzip it and go to the unzipped folder from a terminal.
- Restore BookCars demo db by using the following command:
mongorestore --verbose --drop --gzip --uri="$URI" --nsInclude="bookcars.*" --nsFrom="bookcars.*" --nsTo="bookcars.*" --archive=bookcars.gz
Replace
$URI
with your MongoDB Atlas URI. 5. Copy the content ofcdn
folder in/var/www/cdn/bookcars/
on your VPS. You can use FileZilla and connect to your VPS through SFTP.cdn
folder contains the following folders:-
users
: This folder contains users’ avatars and suppliers’ images. -
cars
: This folder contains cars’ images. -
temp
: This folder contains temporay files.
Make sure permissions are set for these folders, otherwise run the following command:
sudo chown -R $USER:$USER /var/www/cdn/bookcars/
Now, we are going to build the frontend on a desktop PC and install it on Apache server in the VPS:
-
On your desktop PC, download the latest version of the source code down to your machine.
-
download and install the latest LTS version of Node.js.
-
Open the source code with Visual Studio Code.
-
Create
frontend/.env
file with the following content:VITE_NODE_ENV=production VITE_BC_API_HOST=http://localhost:4002 VITE_BC_RECAPTCHA_ENABLED=false VITE_BC_RECAPTCHA_SITE_KEY=GOOGLE_RECAPTCHA_SITE_KEY VITE_BC_DEFAULT_LANGUAGE=en VITE_BC_PAGE_SIZE=30 VITE_BC_CARS_PAGE_SIZE=15 VITE_BC_BOOKINGS_PAGE_SIZE=20 VITE_BC_BOOKINGS_MOBILE_PAGE_SIZE=10 VITE_BC_CDN_USERS=http://localhost/cdn/bookcars/users VITE_BC_CDN_CARS=http://localhost/cdn/bookcars/cars VITE_BC_CDN_LOCATIONS=http://localhost/cdn/bookcars/locations VITE_BC_CDN_LICENSES=http://localhost/cdn/bookcars/licenses VITE_BC_CDN_TEMP_LICENSES=http://localhost/cdn/bookcars/temp/licenses VITE_BC_SUPPLIER_IMAGE_WIDTH=60 VITE_BC_SUPPLIER_IMAGE_HEIGHT=30 VITE_BC_CAR_IMAGE_WIDTH=300 VITE_BC_CAR_IMAGE_HEIGHT=200 VITE_BC_MINIMUM_AGE=21 VITE_BC_PAGINATION_MODE=classic VITE_BC_STRIPE_PUBLISHABLE_KEY=STRIPE_PUBLISHABLE_KEY VITE_BC_STRIPE_CURRENCY_CODE=USD VITE_BC_CURRENCY=$ VITE_BC_SET_LANGUAGE_FROM_IP=false VITE_BC_GOOGLE_ANALYTICS_ENABLED=false VITE_BC_GOOGLE_ANALYTICS_ID=G-XXXXXXXXXX [email protected] VITE_BC_DEPOSIT_FILTER_VALUE_1=250 VITE_BC_DEPOSIT_FILTER_VALUE_2=500 VITE_BC_DEPOSIT_FILTER_VALUE_3=750 VITE_BC_FB_APP_ID=XXXXXXXXXX VITE_BC_APPLE_ID=XXXXXXXXXX VITE_BC_GG_APP_ID=XXXXXXXXXX VITE_BC_MIN_LOCATIONS=4
Set the following options:
VITE_BC_API_HOST=http://localhost:4002 VITE_BC_CDN_USERS=http://localhost/cdn/bookcars/users VITE_BC_CDN_CARS=http://localhost/cdn/bookcars/cars VITE_BC_CDN_LOCATIONS=http://localhost/cdn/bookcars/locations VITE_BC_CDN_LICENSES=http://localhost/cdn/bookcars/licenses VITE_BC_CDN_TEMP_LICENSES=http://localhost/cdn/bookcars/temp/licenses VITE_BC_STRIPE_PUBLISHABLE_KEY=STRIPE_PUBLISHABLE_KEY VITE_BC_STRIPE_CURRENCY_CODE=USD VITE_BC_CURRENCY=$ VITE_BC_SET_LANGUAGE_FROM_IP=false VITE_BC_GOOGLE_ANALYTICS_ENABLED=false VITE_BC_GOOGLE_ANALYTICS_ID=G-XXXXXXXXXX [email protected] VITE_BC_FB_APP_ID=XXXXXXXXXX VITE_BC_APPLE_ID=XXXXXXXXXX VITE_BC_GG_APP_ID=XXXXXXXXXX
Replace
localhost
with the VPS IP or FQDN.For Google Auth, you need to create OAuth 2.0 client ID and add your domains here and set
VITE_BC_GG_APP_ID
. Do the samething forVITE_BC_APPLE_ID
here andVITE_BC_FB_APP_ID
here.If you want to enable stripe payment gateway, set stripe publishable key in
VITE_BC_STRIPE_PUBLISHABLE_KEY
. You can retrieve it from stripe dashboard.VITE_BC_STRIPE_CURRENCY_CODE
is the three-letter ISO 4217 alphabetic currency code, e.g. "USD" or "EUR". Required for Stripe payments. Must be a supported currency: https://docs.stripe.com/currenciesVITE_BC_PAGINATION_MODE
: You can choose betweenclassic
orinfinite_scroll
. This option defaults toclassic
. If you chooseclassic
, you will get a classic pagination with next and previous buttons on desktop and infinite scroll on mobile. If you chooseinfinite_scroll
, you will get infinite scroll on desktop and mobile.Emails sent from the contact form are sent to:
If you want to enable Google Analytics, set the following options:
VITE_BC_GOOGLE_ANALYTICS_ENABLED=true VITE_BC_GOOGLE_ANALYTICS_ID=G-XXXXXXXXXX
-
Go to
frontend
folder from a terminal and build the frontend with the following command:npm install --force npm run build
-
Copy the folder
frontend/build
in/opt/bookcars/frontend/
on your VPS. You can use FileZilla and connect to your VPS through SFTP. -
Copy the content of
/opt/bookcars/frontend/build/
in/var/www/bookcars/frontend/
:sudo mkdir -p /var/www/bookcars/frontend/ sudo cp -rf /opt/bookcars/frontend/build/* /var/www/bookcars/frontend/
-
Set up the frontend VirtualHost on Apache:
- We start this step by going into the configuration files directory:
cd /etc/apache2/sites-available/
- Since Apache came with a default VirtualHost file, let’s use that as a base.
sudo cp 000-default.conf bookcars-frontend.conf sudo cp 000-default.conf 000-default.conf.original sudo a2dissite 000-default.conf
- Now edit the configuration file:
The file should have the following content:
sudo nano bookcars-frontend.conf
If you want to enable HTTPS, add the following configuration at the end before<VirtualHost *:80> # The ServerName directive sets the request scheme, hostname and port that # the server uses to identify itself. This is used when creating # redirection URLs. In the context of virtual hosts, the ServerName # specifies what hostname must appear in the request's Host: header to # match this virtual host. For the default virtual host (this file) this # value is not decisive as it is used as a last resort host regardless. # However, you must set it for any further virtual host explicitly. #ServerName www.example.com ServerAdmin webmaster@localhost DocumentRoot /var/www/bookcars/frontend Alias /cdn /var/www/cdn <Directory "/var/www/cdn"> allow from all order allow,deny AllowOverride All </Directory> <Directory "/var/www/bookcars/frontend"> RewriteEngine On # Don't rewrite files or directories RewriteCond %{REQUEST_FILENAME} -f [OR] RewriteCond %{REQUEST_FILENAME} -d RewriteRule ^ - [L] # Rewrite everything else to index.html to allow html5 state links RewriteRule ^ index.html [L] </Directory> # Available loglevels: trace8, ..., trace1, debug, info, notice, warn, # error, crit, alert, emerg. # It is also possible to configure the loglevel for particular # modules, e.g. #LogLevel info ssl:warn ErrorLog ${APACHE_LOG_DIR}/error.log CustomLog ${APACHE_LOG_DIR}/access.log combined # For most configuration files from conf-available/, which are # enabled or disabled at a global level, it is possible to # include a line for only one particular virtual host. For example the # following line enables the CGI configuration for this host only # after it has been globally disabled with "a2disconf". #Include conf-available/serve-cgi-bin.conf </VirtualHost> # vim: syntax=apache ts=4 sw=4 sts=4 sr noet
</VirtualHost>
:SSLEngine on SSLCertificateFile /path/to/ssl.cert SSLCertificateKeyFile /path/to/ssl.key SSLCACertificateFile /path/to/ssl.ca SSLProtocol all -SSLv2 -SSLv3 -TLSv1 -TLSv1.1
- Activate Apache
RewriteEngine
:sudo a2enmod rewrite sudo systemctl restart apache2
- Activate frontend VirtualHost file:
sudo a2ensite bookcars-frontend.conf
- Check that you have the following configuration in
/etc/apache2/apache2.conf
:<Directory /var/www/> Options Indexes FollowSymLinks AllowOverride None Require all granted </Directory>
- Load the frontend:
sudo systemctl restart apache2 sudo systemctl status apache2
- The frontend is accessible on: http://<VPS-IP>
- We start this step by going into the configuration files directory:
Now, we are going to build the backend on a desktop PC and install it on Apache server in the VPS:
-
On your desktop PC, download the latest version of the source code down to your machine.
-
download and install the latest LTS version of Node.js.
-
Open the source code with Visual Studio Code.
-
Create
backend/.env
file with the following content:VITE_NODE_ENV=production VITE_BC_API_HOST=http://localhost:4002 VITE_BC_DEFAULT_LANGUAGE=en VITE_BC_PAGE_SIZE=30 VITE_BC_CARS_PAGE_SIZE=15 VITE_BC_BOOKINGS_PAGE_SIZE=20 VITE_BC_BOOKINGS_MOBILE_PAGE_SIZE=10 VITE_BC_CDN_USERS=http://localhost/cdn/bookcars/users VITE_BC_CDN_TEMP_USERS=http://localhost/cdn/bookcars/temp/users VITE_BC_CDN_CARS=http://localhost/cdn/bookcars/cars VITE_BC_CDN_TEMP_CARS=http://localhost/cdn/bookcars/temp/cars VITE_BC_CDN_LOCATIONS=http://localhost/cdn/bookcars/locations VITE_BC_CDN_TEMP_LOCATIONS=http://localhost/cdn/bookcars/temp/locations VITE_BC_CDN_CONTRACTS=http://localhost/cdn/bookcars/contracts VITE_BC_CDN_TEMP_CONTRACTS=http://localhost/cdn/bookcars/temp/contracts VITE_BC_CDN_LICENSES=http://localhost/cdn/bookcars/licenses VITE_BC_CDN_TEMP_LICENSES=http://localhost/cdn/bookcars/temp/licenses VITE_BC_SUPPLIER_IMAGE_WIDTH=60 VITE_BC_SUPPLIER_IMAGE_HEIGHT=30 VITE_BC_CAR_IMAGE_WIDTH=300 VITE_BC_CAR_IMAGE_HEIGHT=200 VITE_BC_MINIMUM_AGE=21 VITE_BC_PAGINATION_MODE=classic VITE_BC_CURRENCY=$ VITE_BC_DEPOSIT_FILTER_VALUE_1=250 VITE_BC_DEPOSIT_FILTER_VALUE_2=500 VITE_BC_DEPOSIT_FILTER_VALUE_3=750
Set the following options:
VITE_BC_API_HOST=http://localhost:4002 VITE_BC_CDN_USERS=http://localhost/cdn/bookcars/users VITE_BC_CDN_TEMP_USERS=http://localhost/cdn/bookcars/temp/users VITE_BC_CDN_CARS=http://localhost/cdn/bookcars/cars VITE_BC_CDN_TEMP_CARS=http://localhost/cdn/bookcars/temp/cars VITE_BC_CDN_LOCATIONS=http://localhost/cdn/bookcars/locations VITE_BC_CDN_TEMP_LOCATIONS=http://localhost/cdn/bookcars/temp/locations VITE_BC_CDN_CONTRACTS=http://localhost/cdn/bookcars/contracts VITE_BC_CDN_TEMP_CONTRACTS=http://localhost/cdn/bookcars/temp/contracts VITE_BC_CDN_LICENSES=http://localhost/cdn/bookcars/licenses VITE_BC_CDN_TEMP_LICENSES=http://localhost/cdn/bookcars/temp/licenses VITE_BC_CURRENCY=$
Replace
localhost
with the VPS IP or FQDN.VITE_BC_PAGINATION_MODE
: You can choose betweenclassic
orinfinite_scroll
. This option defaults toclassic
. If you chooseclassic
, you will get a classic pagination with next and previous buttons on desktop and infinite scroll on mobile. If you chooseinfinite_scroll
, you will get infinite scroll on desktop and mobile. -
Go to
backend
folder from a terminal and build the backend with the following command:npm install --force npm run build
-
Copy the folder
backend/build
in/opt/bookcars/backend/
on your VPS. You can use FileZilla and connect to your VPS through SFTP. -
Copy the content of
/opt/bookcars/backend/build/
in/var/www/bookcars/backend/
:sudo mkdir -p /var/www/bookcars/backend/ sudo cp -rf /opt/bookcars/backend/build/* /var/www/bookcars/backend/
-
Set up the backend VirtualHost on Apache:
- We start this step by going into the configuration files directory:
cd /etc/apache2/sites-available/
- Let’s use the frontend configuration file as a base.
sudo cp bookcars-frontend.conf bookcars-backend.conf
- Now edit the configuration file:
The file should have the following content:
sudo nano bookcars-backend.conf
If you want to enable HTTPS, add the following configuration at the end beforeListen 3001 <VirtualHost *:3001> # The ServerName directive sets the request scheme, hostname and port that # the server uses to identify itself. This is used when creating # redirection URLs. In the context of virtual hosts, the ServerName # specifies what hostname must appear in the request's Host: header to # match this virtual host. For the default virtual host (this file) this # value is not decisive as it is used as a last resort host regardless. # However, you must set it for any further virtual host explicitly. #ServerName www.example.com ServerAdmin webmaster@localhost DocumentRoot /var/www/bookcars/backend <Directory "/var/www/bookcars/backend"> RewriteEngine On # Don't rewrite files or directories RewriteCond %{REQUEST_FILENAME} -f [OR] RewriteCond %{REQUEST_FILENAME} -d RewriteRule ^ - [L] # Rewrite everything else to index.html to allow html5 state links RewriteRule ^ index.html [L] </Directory> # Available loglevels: trace8, ..., trace1, debug, info, notice, warn, # error, crit, alert, emerg. # It is also possible to configure the loglevel for particular # modules, e.g. #LogLevel info ssl:warn ErrorLog ${APACHE_LOG_DIR}/error.log CustomLog ${APACHE_LOG_DIR}/access.log combined # For most configuration files from conf-available/, which are # enabled or disabled at a global level, it is possible to # include a line for only one particular virtual host. For example the # following line enables the CGI configuration for this host only # after it has been globally disabled with "a2disconf". #Include conf-available/serve-cgi-bin.conf </VirtualHost> # vim: syntax=apache ts=4 sw=4 sts=4 sr noet
</VirtualHost>
:SSLEngine on SSLCertificateFile /path/to/ssl.cert SSLCertificateKeyFile /path/to/ssl.key SSLCACertificateFile /path/to/ssl.ca SSLProtocol all -SSLv2 -SSLv3 -TLSv1 -TLSv1.1
- Activate backend VirtualHost file:
sudo a2ensite bookcars-backend.conf
- Load the backend:
sudo systemctl reload apache2 sudo systemctl status apache2
- The backend is accessible on: http://<VPS-IP>:3001
- We start this step by going into the configuration files directory:
If you decided to not use the demo database, you need to create an admin user by navigation to http://<VPS-IP>:3001/sign-up and filling the form. Once the admin user is created, you need to secure the backend by commenting the following line in backend/src/App.tsx:
<Route exact path='/sign-up' element={<Signup />} />
Then you need to build the backend and run the installation process again.
If you want to update the API to the latest version, run the following commands:
cd /opt/bookcars/api
git pull
npm install
sudo systemctl restart bookcars.service
sudo systemctl status bookcars.service
tail -f /opt/bookcars/api/logs/all.log
If you want to update the frontend and the backend to the latest version, fetch the latest version of the source code from GitHub then run the installation steps of the frontend and the backend again.
Copyright © 2024 Akram El Assas. All rights reserved.