Tool: reNgine – Optimal installation
reNgine is your ultimate web application reconnaissance suite, designed to supercharge the recon process for security pros, pentesters, and bug bounty hunters. It is go-to web application reconnaissance suite that’s designed to simplify and streamline the reconnaissance process for all the needs of security professionals, penetration testers, and bug bounty hunters.
data:image/s3,"s3://crabby-images/84d2d/84d2d8802bfe47c360514cc86bf6416cda704b1d" alt=""
Source: https://github.com/yogeshojha/rengine
In my opinion, reNgine provides a broader and more structured view of the target by presenting information in a graphical and organized manner. It integrates its own interface and logic as an ASM while incorporating a wide range of tools commonly used in hacking, pentesting, and bug bounty communities. Its capabilities include enumeration, OSINT, and vulnerability scanning, among others.
In this post, I aim to demonstrate how to achieve a more stable and optimized version of reNgine on a virtualized server (which could be a VPS, depending on the user’s budget). In the past, I have encountered several issues related to performance, installation, and maintenance. My goal is to share how I mitigate these problems from my own perspective.
If anyone has ideas or publications aligned with this topic, I will include them in the resources section at the end of this post. Additionally, it’s worth mentioning that reNgine has a comprehensive Wiki that can help you better understand the technical concepts or experiment on your own. Wiki: https://rengine.wiki/
Contents
- 1 Download and Install Ubuntu Server
- 2 Create a Virtual Machine
- 2.1 Steps to Create a Custom Virtual Machine for Ubuntu Server
- 2.2 Installing Ubuntu Server on the Virtual Machine
- 2.3 Steps to Set Up reNgine on Ubuntu Server
- 2.4 Create a Superuser for reNgine
- 2.5 Check reNgine Logs
- 2.6 Access the Web Interface
- 2.7 Verify reNgine Deployment
- 2.8 Automated Update and Start for reNgine Server to Improve Performance
- 3 Resources
Download and Install Ubuntu Server
For this installation, I will use VMware Workstation for convenience, but the process can be replicated on any other virtualization solution.
Let’s download Ubuntu Server from the following link (Ubuntu Server is also chosen for convenience):
Ubuntu Server Download
data:image/s3,"s3://crabby-images/4ff57/4ff57ee6a94bbf99df621909d8528730f84acc67" alt=""
Once the download is complete, we proceed to create the Ubuntu Server virtual machine.
If you don’t have virtualization software yet, here’s how you can get VMware Workstation Pro (now free for personal use):
👉 Download VMware Pro (Follow the official tutorial)
VMware Workstation Pro – Now Free
Alternatively, if you already know how to download it, you can check this repository:
VMware Software Update Repository
Create a Virtual Machine
Create a new virtual machine using the Custom (Advanced) option.
data:image/s3,"s3://crabby-images/f15b2/f15b2d5bceafea1ea249bdad6ac25eaa09e2457b" alt=""
Steps to Create a Custom Virtual Machine for Ubuntu Server
Select the Ubuntu Server ISO:
- In the Guest Operating System Installation step, choose “Use ISO image” and browse for your downloaded Ubuntu Server ISO.
- Once selected, the system will detect the Ubuntu version.
- Click Next.
Select Guest Operating System:
- Choose Linux as the operating system family.
- Select Ubuntu 64-bit for the version.
- Click Next.
Configure Virtual Hardware:
- Processors: Set the total number of processors to 4 cores for optimal performance.
data:image/s3,"s3://crabby-images/51c50/51c5069790859e9f20d3f900ed210b5f18439ac7" alt=""
- Memory (RAM): Allocate 8,192 MB (8 GB) of RAM.
data:image/s3,"s3://crabby-images/2b6a1/2b6a15dc90d4d6a486b7c263b11dc9405ca596fe" alt=""
- Network Connection: Choose the type of network you prefer (e.g., NAT for shared network access).
data:image/s3,"s3://crabby-images/e49f8/e49f8df4a63cea8e454daf35cf1997a9cad6f35f" alt=""
- I/O Controller Types: Select the recommended option (LSI Logic or NVMe).
data:image/s3,"s3://crabby-images/c6db3/c6db3827509613fd0d7d434bf68ef6d281298933" alt=""
- Virtual Disk Type: Choose NVMe for better performance.
data:image/s3,"s3://crabby-images/ccb2c/ccb2c0319dda6cfb8bb73d23caee407efcd831b4" alt=""
- Disk Size: Allocate 80 GB of virtual disk space. Select Split virtual disk into multiple files for flexibility.
data:image/s3,"s3://crabby-images/f0836/f0836515c7a0813f06bea0aac0109cf70fb1b3aa" alt=""
Finalize Configuration:
- Review the summary screen to ensure all settings are correct.
- The summary should look like the example shown in the last image.
- Click Finish to create the virtual machine.
data:image/s3,"s3://crabby-images/a7736/a7736cd8fb906ec6e7bba4773c0a8b5031103e29" alt=""
Installing Ubuntu Server on the Virtual Machine
Start the Virtual Machine:
Once the virtual machine is created, start it. The system will boot into the Ubuntu installation interface.
data:image/s3,"s3://crabby-images/73695/73695af29c3c237a200051bafd5579f95ea05a62" alt=""
Select Your Language:
Use the arrow keys to select your preferred language and press Enter.
data:image/s3,"s3://crabby-images/3160d/3160d4e9195babcd096a46e5b6fe7c3463781aa8" alt=""
Choose Installation Type:
Select Ubuntu Server as the installation type. This option includes the standard set of packages for a server environment.
data:image/s3,"s3://crabby-images/e3b0d/e3b0d22a15c23e34c91af406377edd3b2f0a5d87" alt=""
Network Configuration:
Leave the network configuration at its default settings unless you have specific requirements.
data:image/s3,"s3://crabby-images/435a1/435a11e5a02ff927041b0c16f528d8f975f558f0" alt=""
Guided Storage Configuration:
Select the default setup for disk storage. It will automatically partition the allocated disk space.
data:image/s3,"s3://crabby-images/00b4b/00b4b79d48f39c54048feaa820a1e370640e534b" alt=""
If you encounter disk space issues, it may be because the guided installation didn’t use the full disk. To fix this:
- Check your disk partitions:
lsblk
- Verify available space in the volume group:
sudo vgdisplay
- Expand the logical volume to use 100% of free space:
sudo lvextend -l +100%FREE /dev/ubuntu-vg/ubuntu-lv
- Resize the filesystem to make all system space available:
sudo resize2fs /dev/ubuntu-vg/ubuntu-lv
- Confirm the changes:
df -h
Set Up Your Profile:
- Enter your name, server name, and username.
- Create a secure password and confirm it.
data:image/s3,"s3://crabby-images/b821a/b821a19fddac23220c51a8b2ac5c4089428f47cb" alt=""
Install OpenSSH Server:
- Select the option to install OpenSSH Server. This will allow you to connect to the server via SSH for remote management.
data:image/s3,"s3://crabby-images/e75b8/e75b8eebf98e2f9a27ef95cc11bcbc93f899f340" alt=""
Optional: Install Docker:
- Choose Docker from the featured snaps to include in your setup. Docker provides containerization capabilities and is stable for server environments.
data:image/s3,"s3://crabby-images/c31e3/c31e38ec906d01e3f83373c0361750dae2c5a388" alt=""
Complete the Installation:
- The installer will proceed to configure and install the selected packages.
- Once the installation is complete, reboot the virtual machine.
data:image/s3,"s3://crabby-images/2c3a8/2c3a8871f8c8958ef991c307cee9360181716160" alt=""
Post-Installation:
- Log in with the username and password you set during the installation.
- To check the IP address of your virtual machine, use the command:
ip a
data:image/s3,"s3://crabby-images/66ace/66ace66b1cb7491ab22167e2bac44c397869607e" alt=""
Steps to Set Up reNgine on Ubuntu Server
Connect via SSH
From your host machine, connect to the Ubuntu server using SSH: ssh [email protected]
(Replace 172.16.1.137
with your server’s actual IP address).
Update and Upgrade the System
Update the system packages to ensure everything is up-to-date:
sudo apt update -y
sudo apt upgrade -y
data:image/s3,"s3://crabby-images/187cd/187cd331bbd9927143e2b18006af3d892727ae81" alt=""
Clone the reNgine Repository
Download the reNgine source code from GitHub:
git clone https://github.com/yogeshojha/rengine && cd rengine
data:image/s3,"s3://crabby-images/5693b/5693b82189c1d705287d0e2bce5f5ee1fb648694" alt=""
Edit the .env
File
Open the .env
file to modify the necessary configurations:
nano .env
data:image/s3,"s3://crabby-images/2d01b/2d01b948ef9e29798b7940cfefe62c013a0e2952" alt=""
- Configure secrets: Change the default passwords for security.
- Adjust Celery concurrency based on your server’s RAM:
- 4 GB RAM:
MAX_CONCURRENCY=10
- 8 GB RAM:
MAX_CONCURRENCY=30
- 16 GB RAM:
MAX_CONCURRENCY=50
Install Dependencies
Install the make
tool, which is necessary to build and configure the environment:
sudo apt install make -y
data:image/s3,"s3://crabby-images/150b1/150b1b372cf48df04c3f4a6a3ca074592a7215ae" alt=""
Generate SSL Certificates
Generate SSL certificates to enable secure connections:
sudo make certs
data:image/s3,"s3://crabby-images/91438/914380b95e534e862336eb53027af4917661f20b" alt=""
Build the reNgine Environment
Build the reNgine environment using Docker:
sudo make build
Note: This step may take some time depending on your network speed and server resources.
data:image/s3,"s3://crabby-images/a487c/a487ced322fef419bff02f7630d7ef8d4d215400" alt=""
Start reNgine
Once the build is complete, start the reNgine services:
sudo make up
This will start all the necessary containers (database, frontend, backend, etc.).
data:image/s3,"s3://crabby-images/cf598/cf598207fa7bc1ce485a6436dceaee762f9dba67" alt=""
data:image/s3,"s3://crabby-images/6d9ac/6d9ac28e43913fac57232a47279dead0acf5ab8c" alt=""
Create a Superuser for reNgine
To access the reNgine web interface, you need to create a superuser:
sudo make username
- You will be prompted to provide:
- Username (leave blank for
root
). - Email address.
- Password (and confirm it).
- Username (leave blank for
data:image/s3,"s3://crabby-images/1c944/1c94445827bf6114911346241f3ed18a0822e306" alt=""
Check reNgine Logs
You can verify the status of reNgine services by checking the logs:
sudo make logs
- This will display the current state of all running containers, including any warnings or errors.
data:image/s3,"s3://crabby-images/d50f2/d50f2d61ff97277904e3a7d5aea743d5d90607a0" alt=""
Access the Web Interface
- Open a browser on your host machine.
- Enter the IP address of your server (the same used for SSH), prefixed by
https://
.
Example:https://172.16.1.137
- If you encounter a security warning due to the self-signed certificate, click Advanced and proceed.
data:image/s3,"s3://crabby-images/b13b5/b13b5e39293d2a60b4556ff4e8ee160bcbca78a5" alt=""
- You will be redirected to the reNgine login page. Log in using the superuser credentials you created earlier.
data:image/s3,"s3://crabby-images/56a88/56a8821aaefb0b82eec82e901a53d79d6d4d7bc7" alt=""
Verify reNgine Deployment
After logging in:
- Navigate through the reNgine dashboard to ensure all features are functional.
- You can start testing scans or configurations based on your requirements.
Automated Update and Start for reNgine Server to Improve Performance
To ensure the reNgine server automatically updates and starts on every reboot, follow these steps:
Make update.sh
Executable
chmod +x /home/rengine/rengine/update.sh
Add Privileged Commands
Open the sudoers file to allow certain commands without a password prompt:
sudo visudo
Append these lines at the end.
rengine ALL=(ALL) NOPASSWD: /home/rengine/rengine/update.sh
rengine ALL=(ALL) NOPASSWD: /usr/bin/make down
rengine ALL=(ALL) NOPASSWD: /usr/bin/make up
data:image/s3,"s3://crabby-images/4d324/4d3249638c0bb7fa28f9dd84ebde818082d13008" alt=""
Create a Systemd Service
Create and configure a new service:
sudo nano /etc/systemd/system/rengine-update.service
Example content for the service:
[Unit] Description=Execute rengine update.sh at startup After=network.target
[Service]
User=rengine
WorkingDirectory=/home/rengine/rengine
ExecStart=/bin/bash -c 'echo y | sudo ./update.sh && sudo make down && sudo make up'
Environment=PATH=/usr/local/sbin:/usr/local/bin:/usr/sbin:/usr/bin:/sbin:/bin
Restart=on-failure
[Install]
WantedBy=multi-user.target
data:image/s3,"s3://crabby-images/3745e/3745e65944fa16c532e225aa55f7d85b46b25af1" alt=""
Enable and Start the Service
Run these commands to activate the service:
sudo systemctl daemon-reload
sudo systemctl enable rengine-update.service
sudo systemctl start rengine-update.service
sudo systemctl status rengine-update.service
data:image/s3,"s3://crabby-images/baf87/baf87d21fca7e607ea3ac09b4fdda6da29394608" alt=""
Now, every time the server restarts, the update script will run, reNgine will restart, and the system will be ready after a short wait. Just access it via the same IP address as before.
Important Notes:
- Production Security: Avoid using this setup in production environments since it automatically applies updates and grants passwordless privileges.
- Risks: Automated scripts may unintentionally break functionality. Always validate updates in a testing environment.
data:image/s3,"s3://crabby-images/9aae2/9aae28d636ab21c1d1a461b6978d3a148e31c2a7" alt=""
Resources
- https://github.com/yogeshojha/rengine – reNgine: The Ultimate Web Reconnaissance & Vulnerability Scanner 🚀
- https://www.youtube.com/watch?v=7OFfrU6VrWw – How to install reNgine – Automated Reconnaissance Framework by Secure the Cyber World