How to Install osTicket Open Source Ticketing System on Debian 11. osTicket is a ticketing system aimed at improving the customer service and experience. With osticket customer service teams are able to create custom ticket queues, route tickets to the right department and create an extensive customer portal for satisfied customers. In this article we will introduce what osTicket is with its pros and move onto install phase on Debian 11. Let’s start!
What is osTicket
osTicket is an open source and web based ticketing system application written in PHP. osTicket is available as an on premise and on cloud (SupportSystem).
It provides a simple and user friendly web interface that allows you to allows you to manage, organize and archive your support requests via web browser. You can also add, edit and delete your help desk topics from the web interface. osTicket comes with more features and tools than most of the expensive and commercial support ticket systems on the market. Using osTicket, you can scale and streamline your customer service and improve your customer’s experience.
First, install the Nginx and MariaDB server using the following command:
apt-get install nginx mariadb-server -y
After installing both servers, you will need to install PHP 8.0 on your server. By default, PHP 8.0 is not included in the Debian 11 default repository. So you will need to add the PHP Ondrej repository to your server.
First, install the required dependencies using the following command:
Before creating a MariaDB database, you need to secure the MariaDB installation and set a MariaDB root password. You can do it by running the following script:
mysql_secure_installation
Answer all the questions to set a MariaDB root password and secure the installation:
Enter current password for root (enter for none):
OK, successfully used password, moving on...
Set root password? [Y/n] Y
New password:
Re-enter new password:
Password updated successfully!
Remove anonymous users? [Y/n] Y
Disallow root login remotely? [Y/n] Y
Remove test database and access to it? [Y/n] Y
Reload privilege tables now? [Y/n] Y
After securing the MariaDB, log in to the MariaDB shell with the following command:
mysql -u root -p
Once you are logged in, create a database and user for osTicket with the following command:
CREATE DATABASE osticket;
CREATE USER 'osticket'@'localhost' IDENTIFIED BY 'securepassword';
Grant all the privileges on osticket database with the following command:
GRANT ALL PRIVILEGES ON osticket.* TO osticket@localhost IDENTIFIED BY "securepassword";
Flush the privileges and exit from the MariaDB shell with the following command:
Save and close the file when you are done. Then, verify the Nginx for any syntax error using the following:
nginx -t
You should see the following output:
nginx: the configuration file /etc/nginx/nginx.conf syntax is ok
nginx: configuration file /etc/nginx/nginx.conf test is successful
Please restart the Nginx service to apply the configuration changes:
systemctl restart nginx
To check the status of the Nginx, run the following command:
systemctl status nginx
You should see the following output:
● nginx.service - A high performance web server and a reverse proxy server
Loaded: loaded (/lib/systemd/system/nginx.service; enabled; vendor preset: enabled)
Active: active (running) since Wed 2022-05-11 16:38:50 UTC; 8s ago
Docs: man:nginx(8)
Process: 68586 ExecStartPre=/usr/sbin/nginx -t -q -g daemon on; master_process on; (code=exited, status=0/SUCCESS)
Process: 68587 ExecStart=/usr/sbin/nginx -g daemon on; master_process on; (code=exited, status=0/SUCCESS)
Main PID: 68588 (nginx)
Tasks: 3 (limit: 4679)
Memory: 3.2M
CPU: 55ms
CGroup: /system.slice/nginx.service
├─68588 nginx: master process /usr/sbin/nginx -g daemon on; master_process on;
├─68589 nginx: worker process
└─68590 nginx: worker process
May 11 16:38:50 debian11 systemd[1]: Starting A high performance web server and a reverse proxy server...
May 11 16:38:50 debian11 systemd[1]: Started A high performance web server and a reverse proxy server.
Now, open your web browser and access the osTicket web installation wizard using the URL http://osticket.example.com. You will be redirected to the prerequisites page:
Make sure all prerequired packages are installed, then click on the Continue button. You should see the osTicket basic installation page:
Provide your helpdesk name, email, language, admin username, password, database settings, then click on the InstallNow button. Once the osTicket has been installed, you should see the following page:
osTicket Control Panel
Now, click on the StaffControlPanelURL. You will be redirected to the osTicket control panel login page:
Provide your admin username, password, and click on the LogIn button. You should see the osTicket setting page:
osTicket Settings Page
Change the default osTicket settings as per your requirement and click on the Savechanges button. You should see the osTicket dashboard on the following page:
Finally, open your terminal and remove the osTicket setup directory with the following command:
It is recommended to secure your website with Let’s Encrypt SSL. You will need to install the Certbot client to install and manage the SSL. You can install it with the following command:
apt-get install python3-certbot-nginx -y
Once the Certbot is installed, run the following command to secure your website with Let’s Encrypt SSL:
certbot --nginx -d osticket.example.com
You will be asked to provide your email and accept the term of service as shown below:
Saving debug log to /var/log/letsencrypt/letsencrypt.log
Plugins selected: Authenticator standalone, Installer None
Enter email address (used for urgent renewal and security notices) (Enter 'c' to
cancel): hitjethva1981@gmail.com
- - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - -
Please read the Terms of Service at
https://letsencrypt.org/documents/LE-SA-v1.2-November-15-2017.pdf. You must
agree in order to register with the ACME server at
https://acme-v02.api.letsencrypt.org/directory
- - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - -
(A)gree/(C)ancel: A
- - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - -
Would you be willing to share your email address with the Electronic Frontier
Foundation, a founding partner of the Let's Encrypt project and the non-profit
organization that develops Certbot? We'd like to send you email about our work
encrypting the web, EFF news, campaigns, and ways to support digital freedom.
- - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - -
(Y)es/(N)o: Y
Plugins selected: Authenticator Nginx, Installer Nginx
Obtaining a new certificate
Performing the following challenges:
http-01 challenge for osticket.example.com
Enabled Nginx rewrite module
Waiting for verification...
Cleaning up challenges
Created an SSL vhost at /etc/nginx/conf.d/osticket-le-ssl.conf
Enabled Nginx socache_shmcb module
Enabled Nginx ssl module
Deploying Certificate to VirtualHost /etc/nginx/conf.d/osticket-le-ssl.conf
Enabling available site: /etc/nginx/conf.d/osticket-le-ssl.conf
Next, select whether or not to redirect HTTP traffic to HTTPS as shown below:
Please choose whether or not to redirect HTTP traffic to HTTPS, removing HTTP access.
- - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - -
1: No redirect - Make no further changes to the webserver configuration.
2: Redirect - Make all requests redirect to secure HTTPS access. Choose this for
new sites, or if you're confident your site works on HTTPS. You can undo this
change by editing your web server's configuration.
- - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - -
Select the appropriate number [1-2] then [enter] (press 'c' to cancel): 2
Type 2 and hit Enter to install the Let’s Encrypt SSL for your website:
Redirecting vhost in /etc/nginx/conf.d/osticket.conf to ssl vhost in /etc/nginx/conf.d/osticket-le-ssl.conf
- - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - -
Congratulations! You have successfully enabled https://osticket.example.com
You should test your configuration at:
https://www.ssllabs.com/ssltest/analyze.html?d=osticket.example.com
- - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - -
IMPORTANT NOTES:
- Congratulations! Your certificate and chain have been saved at:
/etc/letsencrypt/live/osticket.example.com/fullchain.pem
Your key file has been saved at:
/etc/letsencrypt/live/osticket.example.com/privkey.pem
Your cert will expire on 2022-08-12. To obtain a new or tweaked
version of this certificate in the future, simply run certbot again
with the "certonly" option. To non-interactively renew *all* of
your certificates, run "certbot renew"
- If you like Certbot, please consider supporting our work by:
Donating to ISRG / Let's Encrypt: https://letsencrypt.org/donate
Donating to EFF: https://eff.org/donate-le
Now, you can access your osTicket website securely using the URL https://osticket.example.com.
Great effort! We have learned how to Install osTicket Open Source Ticketing System on Debian 11.
Install osTicket Open Source Ticketing System on Debian 11 Conclusion
In this post, we explained installation of osTicket on Debian 11 with Nginx and Let’s Encrypt SSL. You can now deploy osTicket in your organization and start managing support requests from the central location.
I am a fan of open source technology and have more than 10 years of experience working with Linux and Open Source technologies. I am one of the Linux technical writers for Cloud Infrastructure Services.
00votes
Article Rating
Subscribe
Login and comment with
I allow to create an account
When you login first time using a Social Login button, we collect your account public profile information shared by Social Login provider, based on your privacy settings. We also get your email address to automatically create an account for you in our website. Once your account is created, you'll be logged-in to this account.
DisagreeAgree
Login and comment with
I allow to create an account
When you login first time using a Social Login button, we collect your account public profile information shared by Social Login provider, based on your privacy settings. We also get your email address to automatically create an account for you in our website. Once your account is created, you'll be logged-in to this account.