Configuring Abyss Web Server on Ubuntu Server 20.04

 
Post new topic   Reply to topic    Aprelium Forum Index -> Tutorials
View previous topic :: View next topic  
Author Message
TRUSTAbyss
-


Joined: 29 Oct 2003
Posts: 3752
Location: USA, GA

PostPosted: Thu Mar 25, 2021 2:16 pm    Post subject: Configuring Abyss Web Server on Ubuntu Server 20.04 Reply with quote

Configuring Abyss Web Server on Ubuntu Server 20.04

This tutorial is outdated because it uses PHP version 7, which was discontinued on November 3rd, 2022. Please use the updated tutorial here.

This tutorial explains the configuration for setting up Abyss Web Server X2 on Ubuntu Server 20.04.2 LTS. If you're running a different distro such as Fedora or CentOS, you will need to use different commands for some of the steps such as installing the packages and modifying the sudoers file. This guide also assumes that you configured the network settings for a static IP Address and enabled the OpenSSH server during the installation process. You can follow this guide from a Virtual Machine using a program like VirtualBox or a dedicated server (my preferred choice). If you haven't already installed the server, download it from the official Ubuntu website. There are many video tutorials out there explaining how to set up Linux. I hope you find this tutorial helpful. It's good to be back in the Aprelium community!

FROM THE CLIENT COMPUTER:
Connect to the server from the client side
Open Windows PowerShell and enter the following command:
Code:
ssh yourUserName@serverip
Note: SSH is installed by default on Windows 10 1909 or higher. Click here for details on installing it on an earlier version. PuTTY also has an SSH client but I find using Windows PowerShell convenient since you can copy and paste information into the command window.

FROM THE SSH TERMINAL:
Configure your account so that password is disabled for sudo command. You don't need to do this but it makes life easier.
Code:
sudo visudo
Add this to the end of the configuration file
Code:
youUserName ALL=(ALL) NOPASSWD:ALL
Press CTRL+O, Enter, then CTRL+X to save changes and exit.

Set time zone of server so it matches your local time (I'm U.S. Eastern Time)
Code:
sudo timedatectl set-timezone America/New_York
Note: sudo timedatectl list-timezones will display a list of time zones to choose from.

Create the user for managing the server and the folders we will use for our setup
Code:
sudo adduser server
su server
cd ~
mkdir -p .ssh public_html/default apps

Download and install FileZilla FTP Client
https://filezilla-project.org/download.php?show_all=1

Use FileZilla FTP Client to connect to server account using SFTP
Upload the tgz file for abyssws into ~/apps
Upload website files into ~/public_html/default

FROM THE SSH TERMINAL:
Install Abyss Web Server
Code:
cd apps
tar xzfm abwsx2-2-14-1.tgz
cd abyssws
./abyssws
This will generate a configuration file. Press CTRL+C to exit program.

Edit abyss.conf to allow your external IP Address.
Code:
nano abyss.conf
Look for console > ipcontrol and add an <allow> tag to include your external IP Address. To find your IP Address, I like to use ipchicken.com but Aprelium also has an IP detector here. This will allow you access to the abyssws console remotely while blocking everyone else. Save your changes and exit by pressing CTRL+O, Enter, then CTRL+X.

Run the program again.
Code:
./abyssws

FROM THE WEB BROWSER:
Log into server from http://serverip:9999 to enter any licensing information and to setup the initial user to log into the console. Do not exit the web browser!

FROM THE SSH TERMINAL:
Install Abyss Web Server as a service
Press CTRL+C to close abyssws
Code:
su yourUserName
sudo ./autostart-setup install
sudo systemctl start abyssws

FROM THE WEB BROWSER:
Change the port to 80
Change the document root to /home/server/public_html/default

FROM THE SSH TERMINAL:
Make sure you have the latest package updates
Code:
sudo apt update
sudo apt -y upgrade

Optional packages for those that require PHP 7.4 scripting. Unfortunately it doesn't appear PHP 8.0 is included in Ubuntu 20.04.2 LTS so you will need to manually compile your own. A tutorial on that will follow in the future.
Code:
sudo apt -y install php7.4-cgi
sudo apt -y install php7.4 php7.4-mysqlnd php7.4-opcache php7.4-pdo php7.4-xml php7.4-bz2 php7.4-calendar php7.4-ctype php7.4-curl php7.4-dom php7.4-exif php7.4-ffi php7.4-fileinfo php7.4-ftp php7.4-gd php7.4-iconv php7.4-json php7.4-mbstring php7.4-mysqli php7.4-pdo-firebird php7.4-pdo-mysql php7.4-pdo-pgsql php7.4-pgsql php7.4-phar php7.4-posix php7.4-readline php7.4-shmop php7.4-simplexml php7.4-sockets php7.4-sysvmsg php7.4-sysvsem php7.4-sysvshm php7.4-tokenizer php7.4-xmlreader php7.4-xmlwriter php7.4-xsl
Note: Please see the documentation for installing PHP on Linux for more details.

Securing your server
At this point, you have a fairly secure server. To make it even more secure, we need to enable the firewall and make sure that we disable password authentication so that only key files are allowed. This prevents attackers from brute forcing into your server (guessing the user and pass multiple times).

FROM THE CLIENT COMPUTER:
Generating the key pair (public and private key) for SSH access
Open Windows PowerShell and run the following command:
Code:
ssh-keygen -t ecdsa -b 521
Note: You don’t need to enter a password but it's a good idea to enter one, that way if someone gets a hold of your private key file id_ecdsa, they would need a password to access the server. Unfortunately this is an inconvenience because every time you connect to the server you will require both the key and the password. As long as you use Bit Locker to encrypt your hard drive and keep your security software up to date, you shouldn't need a password. Do not store the private key file on the Internet unless you know it's in a secure location! OneDrive Personal Vault makes a great location if you want to store it as a backup in the cloud. The public key file is located in C:\Users\yourUserName\.ssh and it's named id_ecdsa.pub)

Download and open PuTTY Key Generator (named puttygen.exe)
https://www.chiark.greenend.org.uk/~sgtatham/putty/latest.html

In order for FileZilla to understand the key file, we need to import the id_ecdsa file (private key) into PuTTY Key Generator and save the private key file as server.ppk into the .ssh folder of your client computer. I won't go into detail how to import the key because it's self explanatory. Just make sure the options after importing are set to use ECDSA and number of bits is 521. ECDSA is the strongest encryption approved by the U.S. Government.

FROM FILEZILLA FTP CLIENT:
Upload the public key file (id_ecdsa.pub) to ~/.ssh and rename the file to authorized_keys
Configure FileZilla to use the key file. You can find this setting where you edit the sites. Open the server.ppk file you created earlier as the key file. Save your changes. You no longer require a password to SSH into the server.

FROM THE SSH TERMINAL:
Configure and restart the SSH service
Code:
sudo nano /etc/ssh/sshd_config
uncomment: PermitRootLogin and change option to no
uncomment: PubKeyAuthentication and change option to yes
uncomment: AuthorizedKeyFiles
uncomment: PasswordAuthentication and change option to no
Press CTRL+O, Enter, then CTRL+X to save changes and exit.
Code:
sudo systemctl restart ssh

Configure Firewall to allow ports 22, 80, 443, and 9999
Code:
sudo ufw allow 22
sudo ufw allow 80
sudo ufw allow 443
sudo ufw allow 9999
sudo ufw enable

Congratulations!!!
You can configure the server however way you want now.


Best regards,
Josh H (TRUSTAbyss)


Last edited by TRUSTAbyss on Thu Dec 22, 2022 1:01 pm; edited 16 times in total
Back to top View user's profile Send private message Visit poster's website
admin
Site Admin


Joined: 03 Mar 2002
Posts: 1306

PostPosted: Fri Mar 26, 2021 9:53 pm    Post subject: Re: Configuring Abyss Web Server on Linux (Ubuntu Server 20. Reply with quote

TRUSTAbyss,

Thank you for your contribution.
_________________
Follow @abyssws on Twitter
Subscribe to our newsletter
_________________
Forum Administrator
Aprelium - https://aprelium.com
Back to top View user's profile Send private message
TRUSTAbyss
-


Joined: 29 Oct 2003
Posts: 3752
Location: USA, GA

PostPosted: Tue Mar 30, 2021 12:12 am    Post subject: Reply with quote

Thanks. I tweaked the package installation commands to include the full package name and version of PHP to be installed. It doesn't look like Ubuntu has a package for PHP 8.0 yet. It's still very new and I prefer PHP 7.4.
Back to top View user's profile Send private message Visit poster's website
admin
Site Admin


Joined: 03 Mar 2002
Posts: 1306

PostPosted: Wed Mar 31, 2021 9:08 pm    Post subject: Reply with quote

TRUSTAbyss wrote:
Thanks. I tweaked the package installation commands to include the full package name and version of PHP to be installed. It doesn't look like Ubuntu has a package for PHP 8.0 yet. It's still very new and I prefer PHP 7.4.


Ubuntu and Debian are distributions that are a bit conservative in adopting new versions of most software. This is the case today for PHP as you noted. But it was also the case for Python way before when they continued to offer version 2.7 when version 3.0 was already released.
_________________
Follow @abyssws on Twitter
Subscribe to our newsletter
_________________
Forum Administrator
Aprelium - https://aprelium.com
Back to top View user's profile Send private message
unknown
-


Joined: 26 Mar 2021
Posts: 2
Location: Italy

PostPosted: Wed Mar 31, 2021 11:27 pm    Post subject: I confirm the validity of the guide. :D Reply with quote

I followed everything to the letter step by step and everything went well. Thanks for your valuable contribution.
_________________
IRCserveR Italia
Back to top View user's profile Send private message Visit poster's website AIM Address
TRUSTAbyss
-


Joined: 29 Oct 2003
Posts: 3752
Location: USA, GA

PostPosted: Thu Apr 01, 2021 11:34 pm    Post subject: Re: I confirm the validity of the guide. :D Reply with quote

unknown wrote:
I followed everything to the letter step by step and everything went well. Thanks for your valuable contribution.


You're welcome! More tutorials will follow in the future.
Back to top View user's profile Send private message Visit poster's website
TRUSTAbyss
-


Joined: 29 Oct 2003
Posts: 3752
Location: USA, GA

PostPosted: Thu Dec 22, 2022 11:55 am    Post subject: Reply with quote

Turns out this tutorial is now outdated because PHP 8 took over PHP 7 since November 3rd. I added a note linking to the new tutorial at the top of the page.
Back to top View user's profile Send private message Visit poster's website
admin
Site Admin


Joined: 03 Mar 2002
Posts: 1306

PostPosted: Thu Dec 29, 2022 10:16 pm    Post subject: Reply with quote

TRUSTAbyss,

Thank you for keeping the tutorial up-to-date.
_________________
Follow @abyssws on Twitter
Subscribe to our newsletter
_________________
Forum Administrator
Aprelium - https://aprelium.com
Back to top View user's profile Send private message
Display posts from previous:   
Post new topic   Reply to topic    Aprelium Forum Index -> Tutorials All times are GMT + 1 Hour
Page 1 of 1

 
Jump to:  
You cannot post new topics in this forum
You cannot reply to topics in this forum
You cannot edit your posts in this forum
You cannot delete your posts in this forum
You cannot vote in polls in this forum


Powered by phpBB phpBB Group