Skip to content
This repository has been archived by the owner on Aug 2, 2022. It is now read-only.

Commit

Permalink
Improve rpm windows and adding deb tar simplifications
Browse files Browse the repository at this point in the history
  • Loading branch information
peterzhuamazon committed Aug 3, 2020
1 parent 043273c commit 95c0b51
Show file tree
Hide file tree
Showing 11 changed files with 530 additions and 567 deletions.
2 changes: 1 addition & 1 deletion .github/scripts/setup_runners.sh
Original file line number Diff line number Diff line change
Expand Up @@ -68,7 +68,7 @@ fi
SETUP_ACTION=$1
SETUP_INSTANCE=`echo $2 | sed 's/,/ /g'`
SETUP_TOKEN=$3
SETUP_AMI_ID="ami-0397210a1b7e7e74c"
SETUP_AMI_ID="ami-0655d7056d3941cd2"
SETUP_AMI_USER="ec2-user"
SETUP_INSTANCE_TYPE="m5.xlarge"
SETUP_INSTANCE_SIZE=20 #GiB
Expand Down
139 changes: 87 additions & 52 deletions .github/scripts/setup_runners_service.sh
Original file line number Diff line number Diff line change
Expand Up @@ -8,9 +8,11 @@
# About: Setup ES/KIBANA for integTests on *NIX based ODFE distros w/wo Security
#
# Usage: ./setup_runners_service.sh $SETUP_DISTRO $SETUP_ACTION
# $SETUP_DISTRO: tar | deb | rpm (required)
# $SETUP_DISTRO: zip | deb | rpm (required)
# $SETUP_ACTION: --es | --es-nosec | --kibana | --kibana-nosec (required)
#
# Requirements: This script assumes java 14 is already installed on the servers
#
# Starting Date: 2020-07-27
# Modified Date: 2020-07-30
###############################################################################################
Expand All @@ -20,7 +22,7 @@ if [ "$#" -ne 2 ] || [ "$1" = "--help" ] || [ "$1" = "-h" ]
then
echo "Please assign 2 parameters when running this script"
echo "Example: $0 \$SETUP_DISTRO \$SETUP_ACTION"
echo "Example: $0 \"tar | deb | rpm\" \"--es | --es-nosec | --kibana | --kibana-nosec\""
echo "Example: $0 \"zip | deb | rpm\" \"--es | --es-nosec | --kibana | --kibana-nosec\""
exit 1
fi

Expand All @@ -36,6 +38,13 @@ ROOT=`dirname $(realpath $0)`; cd $ROOT
OD_VERSION=`python $REPO_ROOT/bin/version-info --od`
ES_VERSION=`python $REPO_ROOT/bin/version-info --es`

ES_PACKAGE_NAME="opendistroforelasticsearch-${OD_VERSION}"
ES_ROOT="${ROOT}/odfe-testing/${ES_PACKAGE_NAME}"
KIBANA_PACKAGE_NAME="opendistroforelasticsearch-kibana"
KIBANA_ROOT="${ROOT}/kibana-testing/${KIBANA_PACKAGE_NAME}"

S3_BUCKET="artifacts.opendistroforelasticsearch.amazon.com"

#####################################################################################################

echo "############################################################"
Expand All @@ -45,59 +54,70 @@ echo "############################################################"

echo "setup parameters"
echo $JAVA_HOME
export PATH=$PATH:$JAVA_HOME
export PATH=$JAVA_HOME:$PATH
which java
java -version
sudo sysctl -w vm.max_map_count=262144

if [ "$SETUP_DISTRO" = "tar" ]
if [ "$SETUP_DISTRO" = "zip" ]
then
mkdir -p odfe-testing
cd odfe-testing
aws s3 cp s3://artifacts.opendistroforelasticsearch.amazon.com/downloads/tarball/opendistro-elasticsearch/opendistroforelasticsearch-$OD_VERSION.tar.gz . --quiet; echo $?
tar -zxf opendistroforelasticsearch-$OD_VERSION.tar.gz
cd opendistroforelasticsearch-$OD_VERSION
mkdir -p $ES_ROOT
aws s3 cp s3://$S3_BUCKET/downloads/tarball/opendistro-elasticsearch/$ES_PACKAGE_NAME.tar.gz . --quiet; echo $?
tar -zxf $ES_PACKAGE_NAME.tar.gz -C $ES_ROOT --strip 1
fi

if [ "$SETUP_DISTRO" = "deb" ]
then
sudo add-apt-repository ppa:openjdk-r/ppa
sudo apt update
sudo sudo apt install -y net-tools
wget -qO - https://d3g5vo6xdbdb9a.cloudfront.net/GPG-KEY-opendistroforelasticsearch | sudo apt-key add -
echo "deb https://d3g5vo6xdbdb9a.cloudfront.net/staging/apt stable main" | sudo tee -a /etc/apt/sources.list.d/opendistroforelasticsearch.list
wget https://artifacts.elastic.co/downloads/elasticsearch/elasticsearch-oss-$ES_VERSION-amd64.deb
wget -q https://artifacts.elastic.co/downloads/elasticsearch/elasticsearch-oss-$ES_VERSION-amd64.deb
sudo dpkg -i elasticsearch-oss-$ES_VERSION-amd64.deb
sudo apt update -y
sudo apt install -y opendistroforelasticsearch-$OD_VERSION
sudo apt install -y opendistroforelasticsearch=$OD_VERSION*
fi

if [ "$SETUP_DISTRO" = "rpm" ]
then
sudo curl https://d3g5vo6xdbdb9a.cloudfront.net/yum/staging-opendistroforelasticsearch-artifacts.repo -o /etc/yum.repos.d/staging-opendistroforelasticsearch-artifacts.repo
sudo yum update
sudo yum install opendistroforelasticsearch-$OD_VERSION -y
sudo yum install $ES_PACKAGE_NAME -y
fi

#####################################################################################################

echo "setup es"

# everything needs es
if [ "$SETUP_DISTRO" = "tar" ]
if [ "$SETUP_DISTRO" = "zip" ]
then
sed -i /install_demo_configuration/d opendistro-tar-install.sh
sed -i '/http\.port/s/^# *//' config/elasticsearch.yml
nohup ./opendistro-tar-install.sh &
sed -i /install_demo_configuration/d $ES_ROOT/opendistro-tar-install.sh
sed -i /^node.max_local_storage_nodes/d $ES_ROOT/config/elasticsearch.yml
mkdir -p snapshots
echo "path.repo: [\"$PWD/snapshots\"]" >> $ES_ROOT/config/elasticsearch.yml
else
sudo mkdir -p /home/repo
sudo chmod 777 /home/repo
sudo chmod 777 /etc/elasticsearch/elasticsearch.yml
sudo sed -i '/path.logs/a path.repo: ["/home/repo"]' /etc/elasticsearch/elasticsearch.yml
sudo sed -i /^node.max_local_storage_nodes/d /etc/elasticsearch/elasticsearch.yml
sudo systemctl restart elasticsearch.service
fi

if [ "$SETUP_ACTION" = "--es" ]
then
sleep 60
if [ "$SETUP_DISTRO" = "zip" ]
then
cd $ES_ROOT
nohup ./opendistro-tar-install.sh > /dev/null 2>&1 &
else
sudo systemctl restart elasticsearch.service
fi
echo "Sleep 120 seconds"
sleep 120
curl -XGET https://localhost:9200 -u admin:admin --insecure
curl -XGET https://localhost:9200/_cluster/health?pretty -u admin:admin --insecure
echo "es start"
cd $REPO_ROOT
exit 0
Expand All @@ -110,23 +130,32 @@ if [ "$SETUP_ACTION" = "--es-nosec" ] || [ "$SETUP_ACTION" = "--kibana-nosec" ]
then
echo "remove es security"

if [ "$SETUP_DISTRO" = "tar" ]
if [ "$SETUP_DISTRO" = "zip" ]
then
./bin/elasticsearch-plugin remove opendistro_security
nohup ./opendistro-tar-install.sh &
$ES_ROOT/bin/elasticsearch-plugin remove opendistro_security
sed -i '/http\.port/s/^# *//' $ES_ROOT/config/elasticsearch.yml
else
sudo /usr/share/elasticsearch/bin/elasticsearch-plugin remove opendistro_security
sudo sed -i '/http\.port/s/^# *//' /etc/elasticsearch/elasticsearch.yml
sudo sed -i /^opendistro_security/d /etc/elasticsearch/elasticsearch.yml
sudo sed -i /CN=kirk/d /etc/elasticsearch/elasticsearch.yml
sudo sed -i /^cluster.routing.allocation.disk.threshold_enabled/d /etc/elasticsearch/elasticsearch.yml
sudo systemctl restart elasticsearch.service
fi
fi

if [ "$SETUP_ACTION" = "--es-nosec" ]
then
sleep 60
if [ "$SETUP_DISTRO" = "zip" ]
then
cd $ES_ROOT
nohup ./opendistro-tar-install.sh > /dev/null 2>&1 &
else
sudo systemctl restart elasticsearch.service
fi
echo "Sleep 120 seconds"
sleep 120
curl -XGET http://localhost:9200
curl -XGET http://localhost:9200/_cluster/health?pretty
echo "es-nosec start"
cd $REPO_ROOT
exit 0
Expand All @@ -139,31 +168,34 @@ if [ "$SETUP_ACTION" = "--kibana" ] || [ "$SETUP_ACTION" = "--kibana-nosec" ]
then
echo "setup kibana"

if [ "$SETUP_DISTRO" = "tar" ]
if [ "$SETUP_DISTRO" = "zip" ]
then
cd ../../
mkdir -p kibana-testing
cd kibana-testing
aws s3 cp s3://artifacts.opendistroforelasticsearch.amazon.com/downloads/tarball/opendistroforelasticsearch-kibana/opendistroforelasticsearch-kibana-$odfe_version.tar.gz . --quiet; echo $?
tar -zxf opendistroforelasticsearch-kibana-$odfe_version.tar.gz
cd opendistroforelasticsearch-kibana
sed -i /install_demo_configuration/d opendistro-tar-install.sh
cd ../../odfe-testing
nohup ./opendistro-tar-install.sh &
cd ../../kibana-testing
nohup ./bin/kibana &
mkdir -p $KIBANA_ROOT
aws s3 cp s3://$S3_BUCKET/downloads/tarball/$KIBANA_PACKAGE_NAME/$KIBANA_PACKAGE_NAME-$OD_VERSION.tar.gz . --quiet; echo $?
tar -zxf $KIBANA_PACKAGE_NAME-$OD_VERSION.tar.gz -C $KIBANA_ROOT --strip 1
else
sudo apt install opendistroforelasticsearch-kibana-$OD_VERSION -y || sudo yum install opendistroforelasticsearch-kibana-$OD_VERSION -y
sudo systemctl restart elasticsearch.service
sudo systemctl restart kibana.service
sudo apt install $KIBANA_PACKAGE_NAME=$OD_VERSION* -y || sudo yum install $KIBANA_PACKAGE_NAME-$OD_VERSION -y
fi
fi

if [ "$SETUP_ACTION" = "--kibana" ]
then
if [ "$SETUP_DISTRO" = "zip" ]
then
cd $ES_ROOT
nohup ./opendistro-tar-install.sh > /dev/null 2>&1 &
cd $KIBANA_ROOT
nohup ./bin/kibana > /dev/null 2>&1 &
else
sudo systemctl restart elasticsearch.service
sudo systemctl restart kibana.service
fi
echo "Sleep 120 seconds"
sleep 120
curl -XGET https://localhost:9200 -u admin:admin --insecure
curl -XGET https://localhost:9200/_cluster/health?pretty -u admin:admin --insecure
curl -v -XGET https://localhost:5601 --insecure
curl -v -XGET https://localhost:5601/api/status --insecure
echo "es & kibana start"
cd $REPO_ROOT
exit 0
Expand All @@ -176,28 +208,31 @@ if [ "$SETUP_ACTION" = "--kibana-nosec" ]
then
echo "remove kibana security"

if [ "$SETUP_DISTRO" = "tar" ]
if [ "$SETUP_DISTRO" = "zip" ]
then
./bin/kibana-plugin remove opendistro_security
sed -i /^opendistro_security/d ./config/kibana.yml
sed -i 's/https/http/' ./config/kibana.yml
cd ../../odfe-testing
nohup ./opendistro-tar-install.sh &
cd ../../kibana-testing
nohup ./bin/kibana &
$KIBANA_ROOT/bin/kibana-plugin remove opendistro_security
sed -i /^opendistro_security/d $KIBANA_ROOT/config/kibana.yml
sed -i 's/https/http/' $KIBANA_ROOT/config/kibana.yml

cd $ES_ROOT
nohup ./opendistro-tar-install.sh > /dev/null 2>&1 &
cd $KIBANA_ROOT
nohup ./bin/kibana > /dev/null 2>&1 &
else
sudo /usr/share/kibana/bin/kibana-plugin remove opendistro_security --allow-root
sudo sed -i /^opendistro_security/d /etc/kibana/kibana.yml
sudo sed -i 's/https/http/' /etc/kibana/kibana.yml
sudo systemctl restart elasticsearch.service
sudo systemctl restart kibana.service
fi

sleep 120
curl -XGET http://localhost:9200
curl -v -XGET http://localhost:5601
echo "es & kibana-nosec start"
echo "Sleep 120 seconds"
sleep 120
curl -XGET http://localhost:9200
curl -XGET http://localhost:9200/_cluster/health?pretty
curl -v -XGET http://localhost:5601
curl -v -XGET http://localhost:5601/api/status
echo "es & kibana-nosec start"
cd $REPO_ROOT
exit 0
exit 0
fi

Loading

0 comments on commit 95c0b51

Please sign in to comment.