Scaling up and performance features. #22
|
@ -0,0 +1,148 @@
|
||||||
|
#!/bin/bash
|
||||||
|
# Custom Selenium Grid-Node fro Jitsi Meet
|
||||||
|
# Pandian - https://community.jitsi.org/u/Pandian
|
||||||
|
# SwITNet Ltd © - 2020, https://switnet.net/
|
||||||
|
# GPLv3 or later.
|
||||||
|
|
||||||
|
#Check if user is root
|
||||||
|
if ! [ $(id -u) = 0 ]; then
|
||||||
|
echo "You need to be root or have sudo privileges!"
|
||||||
|
exit 0
|
||||||
|
fi
|
||||||
|
|
||||||
|
WAN_IP="$(dig +short myip.opendns.com @resolver1.opendns.com)"
|
||||||
|
AV_SPACE="$(df -h .|grep -v File|awk '{print$4}'|sed -e 's|G||')"
|
||||||
|
|
||||||
|
echo -e "\n-- Make sure you have at least 20GB of disk space\n"
|
||||||
|
if [ $(echo "$AV_SPACE > 19" | bc) -ne 0 ]; then
|
||||||
|
echo "> Seems we have enough disk space."
|
||||||
|
else
|
||||||
|
echo "> Please meet the minimum required disk space for this installer, exiting..."
|
||||||
|
exit
|
||||||
|
fi
|
||||||
|
|
||||||
|
|
||||||
|
apt-get update
|
||||||
|
apt-get dist-upgrade -y
|
||||||
|
apt-get install -y \
|
||||||
|
gnupg \
|
||||||
|
bmon \
|
||||||
|
curl \
|
||||||
|
wget \
|
||||||
|
unzip \
|
||||||
|
maven \
|
||||||
|
openjdk-8-jdk
|
||||||
|
|
||||||
|
curl -fsSL https://get.docker.com -o get-docker.sh
|
||||||
|
sh get-docker.sh
|
||||||
|
|
||||||
|
curl -L "https://github.com/docker/compose/releases/download/1.27.4/docker-compose-$(uname -s)-$(uname -m)" -o /usr/local/bin/docker-compose
|
||||||
|
chmod +x /usr/local/bin/docker-compose
|
||||||
|
ln -s /usr/local/bin/docker-compose /usr/bin/docker-compose
|
||||||
|
|
||||||
|
cd /opt
|
||||||
|
git clone https://github.com/jitsi/jitsi-meet-torture
|
||||||
|
cd /opt/jitsi-meet-torture/resources
|
||||||
|
wget -c https://media.xiph.org/video/derf/y4m/FourPeople_1280x720_60.y4m
|
||||||
|
cp FourPeople_1280x720_60.y4m FourPeople_1280x720_30.y4m
|
||||||
|
cd /opt
|
||||||
|
|
||||||
|
#150 "participants" available
|
||||||
|
## Tested up to 120 with AWS c5.24xlarge
|
||||||
|
cat << SELENIUM_GRID_DOCKER > selenium.yml
|
||||||
|
version: "3"
|
||||||
|
services:
|
||||||
|
selenium-hub:
|
||||||
|
image: selenium/hub:3.141.59-20200525
|
||||||
|
container_name: selenium-hub
|
||||||
|
ports:
|
||||||
|
- "4444:4444"
|
||||||
|
restart: always
|
||||||
|
chrome:
|
||||||
|
image: selenium/node-chrome:3.141.59-20200525
|
||||||
|
volumes:
|
||||||
|
- /dev/shm:/dev/shm
|
||||||
|
- ./resources:/usr/share/jitsi-meet-torture/resources
|
||||||
|
depends_on:
|
||||||
|
- selenium-hub
|
||||||
|
environment:
|
||||||
|
- HUB_HOST=selenium-hub
|
||||||
|
- HUB_PORT=4444
|
||||||
|
- NODE_MAX_INSTANCES=30
|
||||||
|
- NODE_MAX_SESSION=30
|
||||||
|
restart: always
|
||||||
|
chrome2:
|
||||||
|
image: selenium/node-chrome:3.141.59-20200525
|
||||||
|
volumes:
|
||||||
|
- /dev/shm:/dev/shm
|
||||||
|
- ./resources:/usr/share/jitsi-meet-torture/resources
|
||||||
|
depends_on:
|
||||||
|
- selenium-hub
|
||||||
|
environment:
|
||||||
|
- HUB_HOST=selenium-hub
|
||||||
|
- HUB_PORT=4444
|
||||||
|
- NODE_MAX_INSTANCES=30
|
||||||
|
- NODE_MAX_SESSION=30
|
||||||
|
restart: always
|
||||||
|
chrome3:
|
||||||
|
image: selenium/node-chrome:3.141.59-20200525
|
||||||
|
volumes:
|
||||||
|
- /dev/shm:/dev/shm
|
||||||
|
- ./resources:/usr/share/jitsi-meet-torture/resources
|
||||||
|
depends_on:
|
||||||
|
- selenium-hub
|
||||||
|
environment:
|
||||||
|
- HUB_HOST=selenium-hub
|
||||||
|
- HUB_PORT=4444
|
||||||
|
- NODE_MAX_INSTANCES=30
|
||||||
|
- NODE_MAX_SESSION=30
|
||||||
|
restart: always
|
||||||
|
chrome4:
|
||||||
|
image: selenium/node-chrome:3.141.59-20200525
|
||||||
|
volumes:
|
||||||
|
- /dev/shm:/dev/shm
|
||||||
|
- ./resources:/usr/share/jitsi-meet-torture/resources
|
||||||
|
depends_on:
|
||||||
|
- selenium-hub
|
||||||
|
environment:
|
||||||
|
- HUB_HOST=selenium-hub
|
||||||
|
- HUB_PORT=4444
|
||||||
|
- NODE_MAX_INSTANCES=30
|
||||||
|
- NODE_MAX_SESSION=30
|
||||||
|
restart: always
|
||||||
|
chrome5:
|
||||||
|
image: selenium/node-chrome:3.141.59-20200525
|
||||||
|
volumes:
|
||||||
|
- /dev/shm:/dev/shm
|
||||||
|
- ./resources:/usr/share/jitsi-meet-torture/resources
|
||||||
|
depends_on:
|
||||||
|
- selenium-hub
|
||||||
|
environment:
|
||||||
|
- HUB_HOST=selenium-hub
|
||||||
|
- HUB_PORT=4444
|
||||||
|
- NODE_MAX_INSTANCES=30
|
||||||
|
- NODE_MAX_SESSION=30
|
||||||
|
restart: always
|
||||||
|
SELENIUM_GRID_DOCKER
|
||||||
|
|
||||||
|
docker-compose -f /opt/selenium.yml up -d
|
||||||
|
|
||||||
|
echo "Change the values acording to you testusing something like;"
|
||||||
|
echo "sudo bash /opt/jitsi-meet-torture/scripts/malleus.sh \\
|
||||||
|
--conferences=1 \\
|
||||||
|
--participants=30 \\
|
||||||
|
--senders=2 \\
|
||||||
|
--audio-senders=1 \\
|
||||||
|
--duration=120 \\
|
||||||
|
--room-name-prefix=hamertesting \\
|
||||||
|
--hub-url=http://localhost:4444/wd/hub \\
|
||||||
|
--instance-url=https://YOUR.JITSI-MEET-INSTANCE.DOMAIN
|
||||||
|
"
|
||||||
|
echo -e "\n-- If using 'hamertesting' you can join the room
|
||||||
|
hamertesting0, hamertesting1, hamertestingN
|
||||||
|
acording to the 'N' number of conferences set to watch the test."
|
||||||
|
|
||||||
|
|
||||||
|
echo -e "\n-- You can check the grid status at:
|
||||||
|
http://$WAN_IP:4444/grid/console
|
||||||
|
"
|
Loading…
Reference in New Issue