Forum Replies Created
-
AuthorPosts
-
in reply to: Warning that hardware reporting may be inconsistent #6799
This message means that the operating system is having trouble enumerating hardware on your host. This is due to a bug in your BIOS or Linux OS.
Telium software tries to work around this bug, and everything SHOULD work fine. But if you have any problem with hardware failure detection or licensed features please contact Telium support and we’ll try to incorporate a fix specific to your BIOS/Linux.
in reply to: Detect running out of RTP ports #6798HAAst is correctly NOT failing over because your PBX is operational and in-progress calls remain up. From HAAst’s perspective your PBX has reached capacity (but is still operational).
First of all, be careful you don’t try to solve a security problem with an HA solution. Even if HAAst fails over to the other node, then that other node will subsequently be subject to those same DoS attacks and it will fail back, etc. So HA failover is not a solution. If you want HAAst to failover once your number of RTP ports in use reach a threshold you set, you can setup a HAAst sensor to monitor the number of RTP ports in use and factor this into each node’s health score. Then, HAAst will failover once the threshold you set for that sensor has been reached.
Second, a more appropriate solution is to block the DoS attacked. Have a look at our Security for Asterisk product (http://www.telium.io/?secast) which is designed to block DoS attacks (and a lot more).
in reply to: ¿Ofreces apoyo en español? #6797All of our support services are in English. We have some native French, German, and Hindi language skills, but that depends on the support representatives on duty.
However, for customers who can’t speak English we try to support them through Google Translate, translating each message in/out to the language of the customer’s choice.
(Sin embargo, para los clientes que no hablan inglés, intentamos ayudarlos a través de Google Translate, traduciendo cada mensaje de entrada / salida al idioma que elija el cliente.)
in reply to: Connect to our site using VPN #6831We would be happy to SSH into your hosts to help with configuration.
Our support machines have pre-installed VPN clients for the most popular protocols: Microsoft Windows protocols (PPTP/L2TP/IPSec/IKEv2), and shared Cisco VPN protocols.
If you chose not to use one of these protocols, or you require that we install a VPN client that is locked to your VPN concentrator address, then we must build a virtual machine for our support techs to use when connecting to your system. Our support techs cannot (and may not) install any software on their machines, in order to protect our computing environment.
If you cannot use one of the pre-installed VPN protocols above, and you cannot port forward SSH from your public IP to your nodes, then we will have to charge you an additional 2 hours of support time to build and maintain a support VM dedicated to your environment. We will also archive this VM (while your maintenance agreement is active) to ensure we can continue to support you going forward.
See FAQ 10042 for additional information: https://telium.io/faq1042
in reply to: Connect to our site using VPN #6795We would be happy to SSH into your hosts to help with configuration.
Our support machines have pre-installed VPN clients for the most popular protocols: Microsoft Windows protocols (PPTP/L2TP/IPSec/IKEv2), and Cisco VPN protocols (IPSec, PPTP/MPPE, L2TP/IPSec).
If you chose not to use one of these protocols, or you require that we install a VPN client that is locked to your VPN concentrator / host, then we must build a virtual machine for our support techs to use when connecting to your system. Our support techs cannot (and may not) install any other software on their machines, in order to protect our computing environment.
If you cannot use one of the pre-installed VPN protocols above, and you cannot port forward SSH from your public IP to your nodes, then we will have to charge you an additional 2 hours of support time to build and maintain a support VM dedicated to your environment. We will also archive this VM (while your maintenance agreement is active) to ensure we can continue to support you going forward.
See FAQ 10042 for additional information: https://telium.io/faq1042
in reply to: Connect to our site using VPN #6796We would be happy to SSH into your hosts to help with configuration.
Our support machines have pre-installed VPN clients for the most popular protocols: Microsoft Windows protocols (PPTP/L2TP/IPSec/IKEv2), and shared Cisco VPN protocols.
If you chose not to use one of these protocols, or you require that we install a VPN client that is locked to your VPN concentrator address, then we must build a virtual machine for our support techs to use when connecting to your system. Our support techs cannot (and may not) install any software on their machines, in order to protect our computing environment.
If you cannot use one of the pre-installed VPN protocols above, and you cannot port forward SSH from your public IP to your nodes, then we will have to charge you an additional 2 hours of support time to build and maintain a support VM dedicated to your environment. We will also archive this VM (while your maintenance agreement is active) to ensure we can continue to support you going forward.
See FAQ 10042 for additional information: https://telium.io/faq1042
- This reply was modified 4 years, 10 months ago by user.
in reply to: Different trunks on cluster nodes #6794HAAst can handle that easily using the event handler system. There are 2 aspects to your cluster that must be handled separately: the FreePBX configuration, and the Asterisk configuration. Remember that FreePBX is a pretty GUI with it’s own configuration database (in MySQL), and it regenerates the Asterisk configuration files (flat files) when you click apply changes. So we have to handle each a bit differently.
I should also point out that because FreePBX creates a relationship between DIALPLAN->ROUTES->TRUNKS, you cannot simply delete a trunk on one node but have it present on the other. To effectively remove the second trunk from London we modify one trunk configuration to ensure it cannot be activated by Asterisk (so it will be ignored in the dialplan). We do so by setting the SIP port to an invalid number.
FreePBX Configuration
To make your life simpler (and setup less confusing), on your New York FreePBX name your NY1 and NY2 trunks:Quote:
MASTER_TRUNK1 (for the trunk)
MASTER_TRUNK1_IN (for inbound)
MASTER_TRUNK1_OUT (for outbound)
MASTER_TRUNK2
MASTER_TRUNK2_IN
MASTER_TRUNK2_OUTNext, add to your New York FreePBX your LON trunk named exactly as follows:
Quote:
SLAVE_TRUNK1 (for the trunk)
SLAVE_TRUNK1_IN (for inbound)
SLAVE_TRUNK1_OUT (for outbound)Finally, add to your New York FreePBX a duplicate the above SLAVE_TRUNK1 to be named SLAVE_TRUNK2:
Quote:
SLAVE_TRUNK2
SLAVE_TRUNK2_IN
SLAVE_TRUNK2_OUTIn FreePBX (on Master) edit your routes to use:
- MASTER_TRUNK1
- SLAVE_TRUNK1
- MASTER_TRUNK2
- SLAVE_TRUNK2
in that order. Don’t worry about NY using SLAVE trunks, or London using MASTER trunks. HAAst will disable them to ensure only the right trunks are used in the right location.
HAAst FreePBX MySQL event handler
HAAst will be responsible for enabling all master trunks in New York (and disabling all slave trunks), and enabling all slave trunks in London (and disabling master trunks there), and changing the external IP address (for SIP config). HAAst will also disable SLAVE_TRUNK2 in London so it won’t be used (contents ignored). HAAst will also change the external IP address in SIP settings. Assuming that you are using the sample HAAst configuration file for Sangoma FreePBX, you will have a sync job named ‘freepbx-mysql’. You need to create a post-sync event handler (file) called sync.stop.post.freepbx-mysql in the /usr/local/haast/events folder. That event handler will be responsible for enabling/disabling trunks:
#!/bin/bash# Determine if this is the SLAVE PBX
ISSLAVE=$(hostname | grep london | wc -l)# Determine value of ‘disabled’ setting in FreePBX
if [ ${ISSLAVE} -eq 0 ] ; then
NODENAME=”NewYork”
LOCALIP=”1.2.3.4″
REMOTEIP=”5.6.7.8″
MASTERDISABLED=”off”
SLAVEDISABLED=”on”
else
NODENAME=”London”
REMOTEIP=”1.2.3.4″
LOCALIP=”5.6.7.8″
MASTERDISABLED=”on”
SLAVEDISABLED=”off”
fi#—————————————————————————-
HVERBOSE=0
if [ -f “/usr/local/haast/internal/helperfunctions.sh” ] ; then
. /usr/local/haast/internal/helperfunctions.sh
elif [ -f “../internal/helperfunctions.sh” ] ; then
. ../internal/helperfunctions.sh
else
echo “ERROR: Cannot find helperfunctions.sh”
exit 10
fi# Update the trunks table for MASTER_XXX trunks
mysql
-u ${MYSQL_SYNCUSERNAME}
-p${MYSQL_SYNCPASSWORD}
-h ${MYSQL_SYNCLOCALHOST}
-D asterisk
-P ${MYSQL_SYNCPORT}
-N
-B
–execute=”update trunks set disabled=’${MASTERDISABLED}’ where name like ‘MASTER_%'”# Update the trunks table for SLAVE_XXX trunks
mysql
-u ${MYSQL_SYNCUSERNAME}
-p${MYSQL_SYNCPASSWORD}
-h ${MYSQL_SYNCLOCALHOST}
-D asterisk
-P ${MYSQL_SYNCPORT}
-N
-B
–execute=”update trunks set disabled=’${SLAVEDISABLED}’ where name like ‘SLAVE_%'”# Update the kvblob table for the SIP settings > externip value
mysql
-u ${MYSQL_SYNCUSERNAME}
-p${MYSQL_SYNCPASSWORD}
-h ${MYSQL_SYNCLOCALHOST}
-D asterisk
-P ${MYSQL_SYNCPORT}
-N
-B
–execute=”UPDATE kvblobstore SET content = REPLACE(content, ‘${REMOTEIP}’, ‘${LOCALIP}’)”
mysql
-u ${MYSQL_SYNCUSERNAME}
-p${MYSQL_SYNCPASSWORD}
-h ${MYSQL_SYNCLOCALHOST}
-D asterisk
-P ${MYSQL_SYNCPORT}
-N
-B
–execute=”UPDATE kvstore_FreePBX_modules_Sysadmin SET val = REPLACE(val, ‘${REMOTEIP}’, ‘${LOCALIP}’)”
mysql
-u ${MYSQL_SYNCUSERNAME}
-p${MYSQL_SYNCPASSWORD}
-h ${MYSQL_SYNCLOCALHOST}
-D asterisk
-P ${MYSQL_SYNCPORT}
-N
-B
–execute=”UPDATE kvstore_Sipsettings SET val = REPLACE(val, ‘${REMOTEIP}’, ‘${LOCALIP}’)”
mysql
-u ${MYSQL_SYNCUSERNAME}
-p${MYSQL_SYNCPASSWORD}
-h ${MYSQL_SYNCLOCALHOST}
-D asterisk
-P ${MYSQL_SYNCPORT}
-N
-B
–execute=”UPDATE sysadmin_options SET value = REPLACE(value, ‘${REMOTEIP}’, ‘${LOCALIP}’)”# Tell HAAst all exitted ok
exit 0HAAst Asterisk file event handler
HAAst will be responsible for ensuring the trunk information (in sip.conf) has the contents appropriate for the node it is running on. There are also 2 distinct use cases we must consider. First use case: if SLAVE becomes active and the admin edits the configuration in FreePBX then Asterisk must accept that configuration and run normally (even if no event handlers have run). In this case there is nothing to be done since the disabled trunks will not generate any config data for Asterisk since they have been disabled in FreePBX. (Nothing to do). Second use case: The Asterisk configuration files from MASTER has been sent to SLAVE, and the SLAVE trunks contain information relevant for New York. To handler this situation we replace trunk content (in the Asterisk config files), and we also remove the MASTER_ prefix from any Asterisk config files (for clarity). Assuming that you are using the sample HAAst configuration file for Sangoma FreePBX, you will have a sync job named ‘freepbx-conf’. You need to create a post-sync event handler (file) called sync.stop.post.freepbx-conf in the /usr/local/haast/events folder. That event handler will be responsible for modify the Asterisk config files:
#!/bin/bash# Determine if this is the SLAVE PBX
ISSLAVE=$(hostname | grep london | wc -l)# Determine value of ‘disabled’ setting in FreePBX
if [ ${ISSLAVE} -eq 0 ] ; then
NODENAME=”NewYork”
SECRET=”NySeCrEt”
HOST=”12.23.34.45″
EXTERNIP=”1.2.3.4″
else
NODENAME=”London”
SECRET=”LoNSeCrEt”
HOST=”98.87.76.65″
EXTERNIP=”9.8.7.6″
fi#—————————————————————————-
HVERBOSE=0
if [ -f “/usr/local/haast/internal/helperfunctions.sh” ] ; then
. /usr/local/haast/internal/helperfunctions.sh
elif [ -f “../internal/helperfunctions.sh” ] ; then
. ../internal/helperfunctions.sh
else
echo “ERROR: Cannot find helperfunctions.sh”
exit 10
fi# Remove MASTER_ and SLAVE_ prefixes from sip config files and dialplan config files,
# to allow for shared files between MASTER and SLAVE (with shared trunk names)
sed -i ‘s/MASTER_//g’ /etc/asterisk/sip_additional.conf
sed -i ‘s/MASTER_//g’ /etc/asterisk/extensions_additional.conf
sed -i ‘s/SLAVE_//g’ /etc/asterisk/sip_additional.conf
sed -i ‘s/SLAVE_//g’ /etc/asterisk/extensions_additional.conf# Enable / disable trunks in Asterisk config files, and alter settings for common
if [ ${ISSLAVE} -eq 0 ] ; then
# THIS IS MASTER
# Enable trunk2 by removing port to a value that will never accept SIP
# TRUNK2
crudini –del –inplace /etc/asterisk/sip_additional.conf “TRUNK2_OUT” port
else
# THIS IS SLAVE
# Disable trunk2 by setting port to a value that will never accept SIP
crudini –set –inplace /etc/asterisk/sip_additional.conf “TRUNK2_OUT” port “9999”
fi# Change values to match required local node settings
# TRUNK1
echo secret=”${HOST}” | crudini –merge –inplace /etc/asterisk/sip_additional.conf “TRUNK1_OUT”
echo secret=”${SECRET}” | crudini –merge –inplace /etc/asterisk/sip_additional.Tconf “TRUNK1_OUT”
# External IP address
echo external_media_address=”${EXTERNIP}” | crudini –merge –inplace /etc/asterisk/pjsip.transports.conf “0.0.0.0-udp”
echo external_signaling_address=”${EXTERNIP}” | crudini –merge –inplace /etc/asterisk/pjsip.transports.conf “0.0.0.0-udp”
echo externip=”${EXTERNIP}” | crudini –merge –inplace /etc/asterisk/sip_general_additional.conf “”# Notify HAAst of success
exit 0Notice that the above event handler also disables TRUNK2 by adding an incorrect sip port number (9999), and uses the open source ‘crudini’ package to accomplish this. This will cause the trunk connection to fail, and Asterisk will ignore the trunk. The result is that the ROUTES as setup in FreePBX will skip this trunk.
Notice as well that we hard coded a bit of information at the start of the event handlers; this is for simplicity. If you want to get really fancy, you can extract the relevant trunk data from the MySQL database and use that to update the Asterisk files. But the above explains the concept in the simplest way possible.
in reply to: Database command failed on write to eventlog table #6792It looks like your MySQL server database is closing the connection – causing SecAst to constantly reopen the connection. Normally a support rep would connect to your system by SSH to look for a MySQL related issue, or to capture more detail about the cause of the database closure. As you are running the free edition we can’t assist much further, but I’ve opened a ticket to see if we can reproduce this in our lab prior to our next release. Could you post your Linux distro, version, and architecture? (So I can add to the ticket)
in reply to: Database command failed on write to eventlog table #6790Could you post the [database] stanza of your secast.conf file?
Does the contents of the database appear correct in the web interface?
in reply to: Database command failed on write to eventlog table #6788I assume the log excerpt you posted is not contiguous (i.e. you removed lines). Is there something in the removed lines pointing to some other issue?
It’s unusual for the database connection to close (failed write). Is the database on the same server as SecAst?
You may wish to increase logging to the DEBUG level for more information.
in reply to: Failed dependencies during qt5-base installation #6756There’s the problem: you are running a derivative of Red Hat 6 yet the rpm command you issued above was trying to install a package designed for Red Hat 7. That’s why you got the GLIBC error.
If you google how to add EPEL to your distro (CentOS 6) you will find detailed instructions; or try this link: https://www.tecmint.com/how-to-enable-epel-repository-for-rhel-centos-6-5/ That will make installation of qt5 (and other non-core packages) easier.
If you want to install a single package directly from a repo (as you did above), you can do so but ensure you are using CentOS 6 repo. (Not CentOS 7).
in reply to: Failed dependencies during qt5-base installation #6786I suspect you are mixing incompatible packages. I’m guessing that your OS is redhat based. Please post the output of:
cat /etc/redhat-release
Instead of manually picking packages from various repo’s on the internet you may wish to add a comprehensive repo like EPEL which has all of these packages available. (Assuming your OS distro is compatible)
in reply to: Failed dependencies during qt5-base installation #6781From your ldd output it appears that you are missing the Qt5 package(s). It’s not clear why you cannot install the packages qt5-qtbase and qt5-qtbase-mysql packages. The ldd output you posted just says qt5 packages are missing.
I have a feeling there is something else you are not telling. Why are you talking about glibc? (The libc.so is installed and running fine according to that ldd output).
Are you also getting a GLIBC error? In that case you probably mixing packages / programs designed for different versions of the operating system.
in reply to: USB license on Hyper-V guest #6777In order to connect a USB device to a Hyper-V guest you need to use a USB over IP solution. This means you plug the USB device into a real (physical) device(possibly even the Hyper-V host) and then attach it to the guest over a network (IP) connection.
For example, there are software packages which will share a USB device over an IP connection:
Example packages include:
- http://usbip.sourceforge.net/ (Free)
- http://www.virtualhere.com/home ($50)
- http://www.incentivespro.com/usb-redirector.html ($75)
- https://www.eltima.com/products/usb-over-ethernet/ ($179)
Note that the free solution may already be rolled into your Linux kernel (so you don’t need to install anything on the guest).
There are also commercial hardware products which will share a USB device over an IP connection:
Example devices include:
- https://www.coolgear.com/product/industrial-usb-2-0-ip-network-4-port-hub-share-usb-device-tcpip-network ($98)
- https://www.coolgear.com/product/usb-2-0-over-ip-network-4-port-hub-share-any-usb-device-over-tcpip-network ($115)
- https://cambrionix.com/products/ethersync-global-device-management-product/ ($575)
Some clients have used a Raspberry Pi to create a USB device server on their network for USB keys and other devices shared across their data center.
We try to avoid endorsing third party products unless we continually test their product with our dongles (which we do not at this time), but we have been told by customers that they have had success with a couple of the software packages above.
in reply to: AMI connection issue at startup #6775Distribution type 11 would be correct for your setup, so that’s not the problem. I would focus solely on ensuring HAAst can start your FreePBX instance properly. The problem could even be that FreePBX is starting but shutting down with an error code, or is getting severely delayed (see Sangoma notes on very slow FreePBX startup) causing HAAst to treat the startup as failed.
I would suggest you look at:
- Try to start/stop the FreePBX service using systemctl from the commandline. Does Asterisk start/stop properly with it?
- Confirm permissions on FreePBX and Asterisk resources, relative to who you are logged in as (and relative to root)
- Start FreePBX using the commands within the systemd service script directly to look for errors
- Look for FreePBX startup errors
- Look for severe FreePBX startup delays (and follow Sangoma wiki instructions on correcting very slow startup if necessary)
-
AuthorPosts