How to Install OpenLiteSpeed on Ubuntu 20.04

Updated on 08 May, 2025
How to Install OpenLiteSpeed on Ubuntu 20.04 header image

OpenLiteSpeed is a high-performance, open-source web server that supports protocols like HTTP/2 and HTTP/3, and natively integrates with PHP to serve dynamic web applications securely. It also offers a user-friendly graphical web administration console for managing virtual hosts.

This article explains how to install OpenLiteSpeed on Ubuntu 20.04 and configure the web administration console to securely deliver web applications on your server.

Prerequisites

Before you begin:

Install OpenLiteSpeed

OpenLiteSpeed is not included in the default Ubuntu 20.04 APT repositories, but you can install it by adding the latest repository setup script. Follow these steps to download the repository script and install OpenLiteSpeed using the APT package manager.

  1. Download the latest OpenLiteSpeed repository setup script.

    console
    $ wget -O openlitespeed.sh https://repo.litespeed.sh
    
  2. Run the script to add the OpenLiteSpeed repository information to your APT sources.

    console
    $ sudo bash openlitespeed.sh
    

    Output:

    LiteSpeed repository has been setup!
  3. Install OpenLiteSpeed.

    console
    $ sudo apt install openlitespeed -y
    
  4. View the installed OpenLiteSpeed version on your server.

    console
    $ cat /usr/local/lsws/VERSION
    

    Your output should be similar to the one below.

    1.8.2

Manage the OpenLiteSpeed System Service

OpenLiteSpeed uses the lshttpd.service system service, with the alias lsws, to manage webserver processes using systemd. Follow the steps below to enable the OpenLiteSpeed service to start automatically at boot and start the webserver.

  1. Enable the OpenLiteSpeed system service to automatically start at boot time.

    console
    $ sudo systemctl enable lshttpd.service
    
  2. Start the OpenLiteSpeed service.

    console
    $ sudo systemctl start lsws
    
  3. View the OpenLiteSpeed service status and verify that it's running.

    console
    $ sudo systemctl status lsws
    

    Output:

    ● lshttpd.service - OpenLiteSpeed HTTP Server
         Loaded: loaded (/etc/systemd/system/lshttpd.service; enabled; vendor preset: enabled)
         Active: active (running) since Sun 2025-04-06 09:44:35 UTC; 1min 5s ago
       Main PID: 5638 (litespeed)
         CGroup: /system.slice/lshttpd.service
                 ├─5638 openlitespeed (lshttpd - main)
                 ├─5648 openlitespeed (lscgid)
                 ├─5677 openlitespeed (lshttpd - #01)
                 ├─5678 openlitespeed (lshttpd - #02)
                 ├─5679 openlitespeed (lshttpd - #03)
                 └─5680 openlitespeed (lshttpd - #04)
  4. Stop the OpenLiteSpeed service.

    console
    $ sudo systemctl stop lsws
    
  5. Restart the service.

    console
    $ sudo systemctl restart lsws
    

Access the OpenLiteSpeed Web Administration Control Panel

The OpenLiteSpeed web administration console runs on port 7080 by default, and the default administrator password is stored in the /usr/local/lsws/admin/password file. Follow the steps below to enable access to port 7080, change the default administrator credentials, and configure OpenLiteSpeed to serve web applications on HTTP port 80.

  1. Run the OpenLiteSpeed administrator script to create a new custom username and password.

    console
    $ sudo bash /usr/local/lsws/admin/misc/admpass.sh
    
    • Enter a new administrator username in the User name prompt and press Enter to save the user.

      Please specify the user name of administrator.
      This is the user name required to login the administration Web interface.
      
      User name [admin]: 
    • Enter a strong password to use with your new administrative user.

      Please specify the administrator's password.
      This is the password required to login the administration Web interface.
      
      Password: 
    • Enter the user password again and press Enter to save your new administrative user details.

      Administrator's username/password is updated successfully!
  2. Allow connections to the OpenLiteSpeed web administration port 7080 through the default UFW firewall utility.

    console
    $ sudo ufw allow 7080/tcp
    
  3. Reload the UFW rules to apply changes.

    console
    $ sudo ufw reload
    
  4. Access the OpenLiteSpeed port 7080 using your server IP in a web browser such as Chrome.

    http://SERVER-IP:7080

    Accept the insecure SSL certificate warning and enter the administrative user details you created earlier.

    • USERNAME: <username you set earlier>
    • PASSWORD: <password you set earlier>

    Default OpenLiteSpeed Login page

  5. Click Listeners on the main navigation bar to modify the default listening port on your webserver.

    Open the Listeners Page

  6. Click the view icon in the Actions section of the Default listener profile.

  7. Click Edit in the top right of the Address Settings section to modify the default listener details.

  8. Edit the Port field and replace the default value 8088 with 80 to enable all default virtual hosts to run on HTTP port 80.

    Edit the default listener port

  9. Click the Save icon in the top right Address Settings section to save the new default listener settings.

  10. Verify that a Configurations modified prompt displays. Then, find the LSWS PID option in the top right corner and click the Graceful Restart icon to apply your configuration changes.

    Apply a Graceful Restart

  11. Click Go when prompted to restart the OpenLiteSpeed webserver to apply changes.

    Restart LiteSpeed

Create a new OpenLiteSpeed Virtual Host

OpenLiteSpeed allows you to create virtual hosts through its web administration console. To set up a new virtual host, log in to the console, navigate to Listeners, and add a new virtual host. Specify the domain (e.g., app.example.com) and the web root directory (e.g., /var/www/app.example.com). After saving, map the domain to the virtual host under the listener settings and restart the server for changes to take effect.

  1. Create a new web root directory to use with your virtual host. For example, /usr/local/lsws/app.example.com.

    console
    $ sudo mkdir /usr/local/lsws/app.example.com
    
  2. Create the html, logs, and conf directories required by the OpenLiteSpeed webserver.

    console
    $ sudo mkdir /usr/local/lsws/app.example.com/{html,logs,conf} -p
    

    The command creates these sub-directories in the web root:

    • html: Stores the web application files for the virtual host.
    • logs: Contains access and error logs for the virtual host.
    • conf: Holds site-specific configurations for OpenLiteSpeed.
  3. Grant the OpenLiteSpeed console user and group lsadm full privileges to the web root directory.

    console
    $ sudo chown lsadm:lsadm -R /usr/local/lsws/app.example.com/
    
  4. Access your OpenLiteSpeed web administration console.

    http://SERVER-IP:7080
  5. Click Virtual Hosts on the main navigation menu to set up a new virtual host.

  6. Click the + Add option in the top right corner of the Virtual Host List section.

    Create a new Virtual Host

  7. Enter the following virtual host configuration details in the respective fields. Replace app.example.com with your actual domain.

    • Virtual Host Name: app.example.com
    • Virtual Host Root: $SERVER_ROOT/app.example.com/
    • Config File: $SERVER_ROOT/conf/vhosts/$VH_NAME/vhconf.conf
    • Follow Symbolic Link: Yes
    • Enable Scripts/ExtApps: Yes
    • Restrained: Yes
    • External App Set UID Mode: Server UID
  8. Keep the other virtual host values unchanged and click Save in the top right corner of the Virtual Host section to save changes.

    OpenLiteSpeed Virtual Host Settings

  9. Find and click the CLICK TO CREATE option when you receive a Please resolve the error(s) prompt to create a new vhconf.conf virtual host configuration in your web root directory.

    OpenLiteSpeed Virtual Host Config File Error

  10. Click Save to create the new virtual host configuration.

  11. Verify that your new virtual host is available in the Virtual Hosts summary. Then, click View within the Actions section to modify the new virtual host information.

    View the virtual host information

  12. Navigate to the General tab and click Edit to modify the virtual host with the following information.

    • Document Root: $VH_ROOT/html/
    • Domain Name: app.example.com
    • Enable GZIP Compression: Yes
    • Enable Brotli Compression: Yes

    OpenLiteSpeed Virtual Host General Section

  13. Click Save to apply the new virtual host configuration.

  14. Navigate to the Log tab and click Edit within the Virtual Host Log section. Then, enter the following values in the respective fields to set up the error log details.

    • Use Server’s Log: Yes
    • File Name: $VH_ROOT/logs/error.log
    • Log Level: ERROR
    • Rolling Size (bytes): 10M
    • Keep Days: 30

    OpenLiteSpeed Error Log Settings

  15. Click Save to apply the new virtual host error log details.

  16. Click Add within the Access Log section to set up the virtual host access log details. Then, enter the following values in the respective fields.

    • Log Control: Own Log File
    • File Name: $VH_ROOT/logs/access.log
    • Rolling Size (bytes): 10M
    • Keep Days: 30

    OpenLiteSpeed Access Log Settings

  17. Click Save to apply the new virtual host access log details.

  18. Navigate to the Rewrite tab and click edit within the Rewrite Control section to set up the virtual host rewrite configurations.

    • Enable Rewrite: Yes

    • Auto Load from .htaccess: Yes

    OpenLiteSpeed Rewrite Settings

  19. Click Save to apply your virtual host rewrite configurations.

  20. Navigate to Listeners on the main navigation bar.

  21. Edit the Default Listener and click Add within the Virtual Host Mappings section to set up your virtual host listening details.

    Edit the Default Listener

  22. Click the Virtual Host drop-down and select your virtual host profile.

  23. Enter your domain app.example.com in the Domains field to bind with the virtual host and serve web application files.

    OpenLiteSpeed Virtual Host Mappings

  24. Click Save to apply the new virtual host mapping details. Then, click the Graceful Restart next to LSWS PID in the top right console section to restart the OpenLiteSpeed webserver.

  25. Click Go when prompted to restart LiteSpeed and apply your webserver configurations.

  26. Access your server's SSH session.

    console
    $ ssh exampleuser@SERVER-IP
    
  27. Create a new HTML application file index.html in your web root html directory.

    console
    $ sudo nano /usr/local/lsws/app.example.com/html/index.html
    
  28. Add the following contents to the file.

    html
    <!DOCTYPE html>
    <html>
    <head>
        <meta charset="UTF-8">
        <title>OpenLiteSpeed Server Install Test</title>
    </head>
    <body>
        <h1 style="text-align: center;">Greetings from Vultr!</h1>
    </body>
    </html>
    

    Save and close the file.

    The above HTML application displays a Greetings from Vultr message when accessed in your web browser.

  29. Allow connections to the default HTTP port 80 through the firewall to test your virtual host configurations.

    console
    $ sudo ufw allow 80/tcp
    
  30. Access your virtual host domain in a new web browser window and verify that OpenLiteSpeed delivers your web application files.

    http://app.example.com

    Greetings from Vultr Page

Secure the OpenLiteSpeed Webserver

OpenLiteSpeed serves virtual hosts on HTTP port 80 for unencrypted connections. To enable encrypted connections, use HTTPS on port 443 with SSL certificates. Follow the steps to generate trusted Let's Encrypt SSL certificates and secure your OpenLiteSpeed server.

  1. Install the Certbot Let's Encrypt client tool using Snap.

    console
    $ sudo snap install --classic certbot
    
  2. Generate a new SSL Let's Encrypt SSL certificate using an HTTP-01 challenge and your virtual host web root directory. Replace app.example.com and admin@example.com with your actual details.

    console
    $ sudo certbot certonly --webroot -w /usr/local/lsws/app.example.com/html/ --agree-tos --no-eff-email --staple-ocsp --preferred-challenges http -m name@example.com -d app.example.com
    

    The command generates a Let's Encrypt SSL certificate for your domain app.example.com with the web root /usr/local/lsws/app.example.com/html/. Since Certbot doesn't support OpenLiteSpeed, you must manually enable the generated certificate in your virtual host configuration.

    Your output should be similar to the one below when an SSL is successfully generated.

    Successfully received certificate.
    Certificate is saved at: /etc/letsencrypt/live/app.example.com/fullchain.pem
    Key is saved at:         /etc/letsencrypt/live/app.example.com/privkey.pem
    This certificate expires on 2025-07-05.
    These files will be updated when the certificate renews.
    Certbot has set up a scheduled task to automatically renew this certificate in the background.
  3. Test the Certbot SSL certificate renewal process.

    console
    $ sudo certbot renew --dry-run
    
  4. Access your OpenLiteSpeed web administration dashboard.

    http://SERVER-IP:7080
  5. Navigate to Listeners on the main navigation bar.

  6. Click Add within the Listener List section to add a new listener.

  7. Enter the following values in the respective field to listen for HTTPS requests on the server.

    • Listener Name: HTTPS
    • IP Address: ANY IPv4
    • Port: 443
    • Secure: Yes

    OpenLiteSpeed SSL Listener

  8. Click Save to add the new listener on your webserver.

  9. Find the new HTTPS listener on your Listener list. Then, click View in the actions section to modify the listener details.

    View the HTTPS listener

  10. Click Add within the Virtual Host Mappings section to bind the listener to an existing virtual host on your server.

  11. Enter the following details in the respective fields to bind your virtual host.

    • Virtual Host: app.example.com
    • Domains: app.example.com

    OpenLiteSpeed Virtual Host Mappings

  12. Click Save to apply the new virtual host mappings on your webserver.

  13. Navigate to the SSL tab and click edit within the SSL Private Key & Certificate section to modify your certificate details.

  14. Enter the following details in the respective fields to match your Let's Encrypt SSL certificate paths.

    • Private Key File: /etc/letsencrypt/live/app.example.com/privkey.pem
    • Certificate File: /etc/letsencrypt/live/app.example.com/fullchain.pem
    • Chained Certificate: Yes

    OpenLiteSpeed SSL Certificate Locations

  15. Click Save to apply the SSL certificate changes to your virtual host.

  16. Locate the LSWS PID option and click Graceful Restart to restart the server.

  17. Click GO to confirm the restart and apply the configuration changes.

    Restart LiteSpeed to Apply SSL Configurations

    Note
    When running multiple virtual hosts on your server. Navigate to the Virtual Hosts tab, open your target virtual host, and click SSL to enable an SSL certificate to bind with the virtual host configuration.

Set Up Firewall Rules

UFW is active by default on Vultr Ubuntu servers. Follow the steps below to configure the firewall to allow access to the OpenLiteSpeed web admin port 7080, HTTPS port 443, and HTTP port 80.

  1. Enable UFW and allow connections to the SSH port 22 if it's inactive on your server.

    console
    $ sudo ufw allow 22/tcp && sudo ufw enable
    
  2. Allow connections to the OpenLiteSpeed console port 7080.

    console
    $ sudo ufw allow 7080/tcp
    
  3. Allow HTTP connections on the server.

    console
    $ sudo ufw allow  http
    
  4. Allow HTTPS connections.

    console
    $ sudo ufw allow https
    
  5. Restart UFW to apply your firewall changes.

    console
    $ sudo ufw reload
    
  6. View the firewall status and verify that the new rules are active on your server.

    console
    $ sudo ufw status
    
  7. Access your virtual host's domain using HTTPS in a new web browser window to test your SSL configurations.

    https://app.example.com

Conclusion

You have installed OpenLiteSpeed on Ubuntu 20.04 and set up a sample virtual host to deliver web applications securely. OpenLiteSpeed supports PHP, enabling dynamic web applications.

Comments

No comments yet.