Note
The last version of Rocky Linux that this procedure was tested on was version 8.5. Because the bulk of this procedure relies on source builds directly from Asterisk and a simple set of Development Tools from Rocky Linux, it should work on all versions. If you run into a problem, please let us know!
Installing Asterisk on Rocky Linux¶
What is Asterisk?
Asterisk is an open source framework for building communications applications. Additionally, Asterisk turns an ordinary computer into a communications server, as well as powering IP PBX systems, VoIP gateways, conference servers and other custom solutions. It is used by small businesses, large businesses, call centers, carriers, and government agencies worldwide.
Asterisk is free and open source and is sponsored by Sangoma. Sangoma also offers commercial products that use Asterisk under the hood, and depending on your experience and budget, using these products may be more beneficial than rolling your own. Only you and your organization know that answer.
It should be noted that this guide requires the administrator to do a fair amount of research on their own. Installing a communications server is not a difficult process, but running one can be quite complicated. While this guide will get your server up and running, it will not be fully ready for you to use in production.
Prerequisites¶
At minimum, you will need the following skills and tools to complete this guide:
- A machine running Rocky Linux
- A comfort level with modifying configuration files and issuing commands from the command-line
- Knowledge of how to use a command line editor (We are using
vi
here, but feel free to substitute in your favorite editor.) - You will need root access, and ideally be signed in as the root user in your terminal
- The EPEL repositories from Fedora
- The ability to login as root or run root commands with sudo. All commands here assume a user that has sudo rights, however the configuration and build processes are run with
sudo -s
. - To grab the latest build of Asterisk, you will need to either use
curl
orwget
. This guide useswget
, but feel free to substitute in the appropriatecurl
string if you want to use that.
Update Rocky Linux and Install wget
¶
sudo dnf -y update
This will get your server up-to-date with all packages that have been released or updated since the last update or install. Then run:
sudo dnf install wget
Set Hostname¶
Set your host name to the domain you'll be using for Asterisk.
sudo hostnamectl set-hostname asterisk.example.com
Add Needed Repositories¶
First, install the EPEL (Extra Packages for Enterprise Linux):
sudo dnf -y install epel-release
Next, enable Rocky Linux' PowerTools:
sudo dnf config-manager --set-enabled powertools
Install Development Tools¶
sudo dnf group -y install "Development Tools"
sudo dnf -y install git wget
Install Asterisk¶
Downloading and Configuring the Asterisk Build¶
Before you download this script, make sure you have the latest version. To do so, navigate to the Asterisk download link here and look for the latest build of Asterisk. Then copy the link location. As of the writing of this document, the following was the latest build:
wget http://downloads.asterisk.org/pub/telephony/asterisk/asterisk-20-current.tar.gz
tar xvfz asterisk-20-current.tar.gz
cd asterisk-20.0.0/
Before running the install_prereq
below (and the remaining commands), you are going to need to be the superuser or root. It's much easier at this point to get into sudo permanently for a while. We will exit back out of sudo later in the process:
sudo -s
contrib/scripts/install_prereq install
You should see the following when the script completes:
#############################################
## install completed successfully
#############################################
Now that all of the required packages are installed, our next step is to configure and build Asterisk:
./configure --libdir=/usr/lib64 --with-jansson-bundled=yes
Assuming that the configuration runs without issue, you should get a large ASCII Asterisk emblem, followed by the following on Rocky Linux:
configure: Package configured for:
configure: OS type : linux-gnu
configure: Host CPU : x86_64
configure: build-cpu:vendor:os: x86_64 : pc : linux-gnu :
configure: host-cpu:vendor:os: x86_64 : pc : linux-gnu :
Set Asterisk menu options [For more options]¶
This is one of the steps where the administrator is going to need to do his homework. There are a lot of menu options that you may or may not need. Running the following command:
make menuselect
will bring you to a menu select screen:
Look through these options carefully and make selections based on your requirements. As stated earlier, this may take some additional homework.
Build and Install Asterisk¶
To build, we want to execute the following commands in succession:
make
make install
Installing the documentation isn't required, but unless you are a communications server expert, you'll want them installed:
make progdocs
Next install the basic PBX and make the config. The basic PBX is just that, very basic! You will probably need to make changes going forward to get your PBX to function as you want it to.
make basic-pbx
make config
Asterisk Configuration¶
Create User & Group¶
You'll need a specific user just for asterisk. Might as well create it now.
groupadd asterisk
useradd -r -d /var/lib/asterisk -g asterisk asterisk
chown -R asterisk.asterisk /etc/asterisk /var/{lib,log,spool}/asterisk /usr/lib64/asterisk
restorecon -vr {/etc/asterisk,/var/lib/asterisk,/var/log/asterisk,/var/spool/asterisk}
Now that the bulk of our work is completed, go ahead and exit out of the sudo -s
command. This will require that most of the remaining commands use sudo again:
exit
Set Default User & Group¶
sudo vi /etc/sysconfig/asterisk
Remove the comments on the two lines below and save:
AST_USER="asterisk"
AST_GROUP="asterisk"
sudo vi /etc/asterisk/asterisk.conf
Remove the comments on the two lines below and save:
runuser = asterisk ; The user to run as.
rungroup = asterisk ; The group to run as.
Configure Asterisk Service¶
sudo systemctl enable asterisk
Configure Firewall¶
This example uses firewalld
for the firewall, which is the default in Rocky Linux. The goal here is to open SIP ports to the world and to open RTP (Realtime Transport Protocol) to the world on ports 10000-20000 as recommended by the Asterisk documentation.
Keep in mind that you will almost certainly need other firewall rules for other forward-facing services (HTTP/HTTPS) which you will probably want to limit to your own IP addresses. That is beyond the scope of this document:
sudo firewall-cmd --zone=public --add-service sip --permanent
sudo firewall-cmd --zone=public --add-port=10000-20000/udp --permanent
Since we've made the firewalld
commands permanent, we will need to do a reboot of the server. You can do that with:
sudo shutdown -r now
Test¶
The Asterisk Console¶
To test, let's connect to the Asterisk console:
sudo asterisk -r
Which will bring you into the Asterisk command-line client. You will see this prompt after the basic Asterisk information is displayed:
asterisk*CLI>
To change the verbosity of the console, use the following:
core set verbose 4
Which should show you the following in the Asterisk console:
Console verbose was OFF and is now 4.
Show Sample End-Point Authentications¶
At the Asterisk command-line client prompt, type:
pjsip show auth 1101
This will return username and password information that you can then use to connect any SIP client with.
Conclusion¶
The above will get you up and running with the server, but finishing out the configuration, connecting devices, and further troubleshooting is up to you.
Running an Asterisk communications server takes a lot of time and effort and will require a lot of research by any administrator. For more information on how to configure and use Asterisk, take a look at the Asterisk Wiki here.
Contributors: Steven Spencer