From be84471233b3067e57cf3d9dbbb0154b60eb21f2 Mon Sep 17 00:00:00 2001 From: Victor Morales Date: Mon, 22 Jan 2018 10:07:28 -0800 Subject: Update AAI instructions The AAI instructions were using old variables resulting in some execution errors. This change removes that old variables and updates the methods required for the service. Change-Id: I14f8e598eb8a5fd915b63135c1145ea25f6bcad0 Signed-off-by: Victor Morales Issue-ID: INT-18 --- bootstrap/vagrant-onap/Vagrantfile | 8 +- bootstrap/vagrant-onap/lib/_onap_functions | 4 +- bootstrap/vagrant-onap/lib/aai | 165 +++++++++++---------------- bootstrap/vagrant-onap/lib/files/haproxy.cfg | 4 +- bootstrap/vagrant-onap/lib/functions | 2 +- bootstrap/vagrant-onap/tests/test_aai | 18 +-- 6 files changed, 76 insertions(+), 125 deletions(-) (limited to 'bootstrap/vagrant-onap') diff --git a/bootstrap/vagrant-onap/Vagrantfile b/bootstrap/vagrant-onap/Vagrantfile index 31a9970a5..6d7900bf3 100644 --- a/bootstrap/vagrant-onap/Vagrantfile +++ b/bootstrap/vagrant-onap/Vagrantfile @@ -45,9 +45,13 @@ nodes = [ :macs => [], :cpus => 2, :cpu => "50", - :ram => 4 * 1024, + :ram => 6 * 1024, :groups => ["individual"], - :args => ["aai"] + :args => ["aai"], + :fwds => [ + { :guest => 8446, :host => 8446, :guest_ip => '192.168.50.6' }, + { :guest => 9446, :host => 9446, :guest_ip => '192.168.50.6' }, + ] }, { :name => "all-in-one", diff --git a/bootstrap/vagrant-onap/lib/_onap_functions b/bootstrap/vagrant-onap/lib/_onap_functions index 960b298ef..f68d6dbf0 100755 --- a/bootstrap/vagrant-onap/lib/_onap_functions +++ b/bootstrap/vagrant-onap/lib/_onap_functions @@ -23,7 +23,7 @@ function pull_openecomp_image { local image=$1 local tag=$2 docker_openecomp_login - pull_docker_image ${nexus_docker_repo:-nexus3.onap.org:10001}/openecomp/${image}:${docker_version-latest} $tag + pull_docker_image ${nexus_docker_repo:-nexus3.onap.org:10001}/openecomp/${image}:${docker_version:-latest} $tag docker logout } @@ -32,7 +32,7 @@ function pull_onap_image { local image=$1 local tag=$2 docker_openecomp_login - pull_docker_image ${nexus_docker_repo:-nexus3.onap.org:10001}/onap/${image}:${docker_version-latest} $tag + pull_docker_image ${nexus_docker_repo:-nexus3.onap.org:10001}/onap/${image}:${docker_version:-latest} $tag docker logout } diff --git a/bootstrap/vagrant-onap/lib/aai b/bootstrap/vagrant-onap/lib/aai index 7a68fbbf4..316a981ff 100755 --- a/bootstrap/vagrant-onap/lib/aai +++ b/bootstrap/vagrant-onap/lib/aai @@ -2,7 +2,7 @@ source /var/onap/functions -hbase_version=1.2.3 +hbase_version=1.2.0 # install_hadoop() - Function that installs Hadoop function install_hadoop { @@ -16,15 +16,16 @@ function install_hadoop { install_package unzip mkdir -p $dest_folder unzip /tmp/${filename}.zip -d $dest_folder - pushd $dest_folder/${filename} - # Change commitlog_directory and data_file_directories values (https://stackoverflow.com/a/26856246/1707651) - sed -i "s|db/cassandra/data|/tmp/data|g" conf/cassandra/cassandra.yaml - sed -i "s|db/cassandra/commitlog|/tmp/commitlog|g" conf/cassandra/cassandra.yaml - - install_java - ./bin/titan.sh start - popd fi + + pushd $dest_folder/${filename} + # Change commitlog_directory and data_file_directories values (https://stackoverflow.com/a/26856246/1707651) + sed -i "s|db/cassandra/data|/tmp/data|g" conf/cassandra/cassandra.yaml + sed -i "s|db/cassandra/commitlog|/tmp/commitlog|g" conf/cassandra/cassandra.yaml + + install_java + ./bin/titan.sh start + popd } # install_haproxy() - Function that install HAProxy @@ -34,18 +35,18 @@ function install_haproxy { fi install_package software-properties-common add-apt-repository -y ppa:vbernat/haproxy-1.7 + update_repos install_package haproxy cp /var/onap/files/haproxy.cfg /etc/haproxy/ cp /var/onap/files/aai.pem /etc/ssl/private/ chmod 640 /etc/ssl/private/aai.pem chown root:ssl-cert /etc/ssl/private/aai.pem - mkdir /usr/local/etc/haproxy + mkdir -p /usr/local/etc/haproxy #echo "127.0.0.1 localhost aai-traversal.api.simpledemo.openecomp.org aai-resources.api.simpledemo.openecomp.org" >> /etc/hosts service haproxy restart } - # compile_aai_repos() - Function that compiles AAI source repo. function compile_aai_repos { local repos="aai/aai-common aai/resources aai/logging-service aai/traversal" @@ -54,7 +55,7 @@ function compile_aai_repos { fi for repo in ${repos[@]}; do - compile_src $aai_src_folder${repo#*aai} + compile_src ${src_folders[aai]}${repo#*aai} done } @@ -65,98 +66,69 @@ function setup_titan { for dirc in resources/aai-resources traversal/aai-traversal; do for file in titan-cached.properties titan-realtime.properties; do - crudini --set "$aai_src_folder/$dirc/$subdirectory/$file" "" "storage.backend" "cassandra" - crudini --set "$aai_src_folder/$dirc/$subdirectory/$file" "" "storage.hostname" "localhost" + crudini --set "${src_folders[aai]}/$dirc/$subdirectory/$file" "" "storage.backend" "cassandra" + crudini --set "${src_folders[aai]}/$dirc/$subdirectory/$file" "" "storage.hostname" "localhost" done done - # Add the schema to the local isntance - compile_src $aai_src_folder/resources/aai-resources/ + # Add the schema to the local instance + compile_src ${src_folders[aai]}/resources/aai-resources/ uninstall_packages default-jre openjdk-7-jdk openjdk-7-jre openjdk-7-jre-headless - pushd $aai_src_folder - java -DAJSC_HOME=$aai_src_folder/resources/aai-resources -DBUNDLECONFIG_DIR="bundleconfig-local" -cp aai-common/aai-core/target/aai-core-1.1.0-SNAPSHOT.jar:resources/aai-resources/target/aai-resources.jar:resources/aai-resources/target/userjars/* org.openecomp.aai.dbgen.GenTester + pushd ${src_folders[aai]} + java -DAJSC_HOME=${src_folders[aai]}/resources/aai-resources -DBUNDLECONFIG_DIR="bundleconfig-local" -cp aai-common/aai-core/target/aai-core-*.jar:resources/aai-resources/target/aai-resources.jar:resources/aai-resources/target/userjars/* org.onap.aai.dbgen.GenTester popd } -# start_aai_microservices() - Function that starts AAI microservices -function start_aai_microservices { +# _start_data_managment() - Funtion that start a data management service +function _start_data_managment { + local service=$1 + local debug_port=$2 + install_maven - export MAVEN_OPTS="-Xms1024m -Xmx5120m -XX:PermSize=2024m -Xdebug -Xnoagent -Djava.compiler=NONE -Xrunjdwp:transport=dt_socket,address=9446,server=y,suspend=n" - for svc in resources traversal; do - pushd $aai_src_folder/resources - mvn -P runAjsc - popd - done + pushd ${src_folders[aai]}/$service + export MAVEN_OPTS="-Xms1024m -Xmx5120m -XX:PermSize=2024m -Xdebug -Xnoagent -Djava.compiler=NONE -Xrunjdwp:transport=dt_socket,address=$debug_port,server=y,suspend=n" + mvn -P runAjsc & + popd } -# install_hbase() - Install HBase Service -function install_hbase { - docker rm -f hbase - docker_openecomp_login - docker pull $nexus_docker_repo/aaidocker/aai-hbase-${hbase_version} - run_docker_image -d --net=host --name="hbase" $nexus_docker_repo/aaidocker/aai-hbase-${hbase_version} +# start_aai_microservices() - Function that starts AAI microservices +function start_aai_microservices { + _start_data_managment resources 9446 + sleep 360 + _start_data_managment traversal 9447 } -# install_ajsc() - Install ASJC Java service container -function install_ajsc_aai { - cat < /etc/ajsc-aai.conf -AAI_REPO_PATH=r/aai -AAI_CHEF_ENV=simpledemo -AAI_CHEF_LOC=/var/chef/aai-data/environments -docker_gitbranch=master -EOL - docker rm -f aai-service - if [[ "$build_image" == "True" ]]; then - build_docker_image $aai_src_folder/aai-service/ajsc-aai - else - pull_openecomp_image ajsc-aai - fi - - run_docker_image --env-file /etc/ajsc-aai.conf --name=aai-service --net=host -v /etc/ssl/certs/ca-certificates.crt:/etc/ssl/certs/ca-certificates.crt -it -d $nexus_docker_repo/openecomp/ajsc-aai:$docker_version +# install_aai() - Install AAI Services +function install_aai { + install_docker_compose + pushd ${src_folders[aai]}/test-config + ./deploy_vm2.sh + ./deploy_vm1.sh + popd } -# install_model_loader() Install Model Loader -function install_model_loader { - cat < /etc/model-loader.conf -DISTR_CLIENT_ASDC_ADDRESS=${SDC_ADDRESS:-c2.vm1.sdc.simpledemo.openecomp.org:8443} -DISTR_CLIENT_CONSUMER_GROUP=${UEB_CONSUMER_GROUP:-SDCGroup} -DISTR_CLIENT_CONSUMER_ID=${UEB_CONSUMER_GROUP_ID:-UEB} -DISTR_CLIENT_ENVIRONMENT_NAME=${dmaap_topic} -DISTR_CLIENT_PASSWORD=${SDC_PASSWORD:-OBF:1ks51l8d1o3i1pcc1r2r1e211r391kls1pyj1z7u1njf1lx51go21hnj1y0k1mli1sop1k8o1j651vu91mxw1vun1mze1vv11j8x1k5i1sp11mjc1y161hlr1gm41m111nkj1z781pw31kku1r4p1e391r571pbm1o741l4x1ksp} -DISTR_CLIENT_USER=${SDC_USER:-aai} - -APP_SERVER_BASE_URL=${APP_SERVER_URL:-https://c1.vm1.aai.simpledemo.openecomp.org:8443} -APP_SERVER_AUTH_USER=${APP_USER:-ModelLoader} -APP_SERVER_KEYSTORE_PASSWORD=OBF:1i9a1u2a1unz1lr61wn51wn11lss1unz1u301i6o -APP_SERVER_AUTH_PASSWORD=${APP_PASSWORD:-OBF:1qvu1v2h1sov1sar1wfw1j7j1wg21saj1sov1v1x1qxw} -EOL - - ARGS="" - - docker rm -f model-loader-service - if [[ "$build_image" == "True" ]]; then - build_docker_image $aai_src_folder/model-loader/ - ARGS+="--env-file /etc/model-loader.conf model-loader" - else - pull_openecomp_image model-loader - ARGS+="--name=model-loader-service -it -d --env-file /etc/model-loader.conf $nexus_docker_repo/openecomp/model-loader:$docker_version" - fi - run_docker_image ${ARGS} -} +# get_aai_images() - Function that pulls or creates AAI docker images +function get_aai_images { + pull_docker_image elasticsearch:2.4.1 + docker_openecomp_login + pull_docker_image ${nexus_docker_repo:-nexus3.onap.org:10001}/aaionap/hbase:${hbase_version} -# _wait_for_sdc() - Function that determines if SDC is up and running -function _wait_for_sdc { - if [[ -s "/opt/config/sdc_ip_addr.txt" ]]; then - SDC_IP_ADDR=$(cat /opt/config/sdc_ip_addr.txt) + if [[ "$build_image" == "True" ]]; then + unset MAVEN_OPTS + build_docker_image ${src_folders[aai]}/resources/aai-resources + build_docker_image ${src_folders[aai]}/traversal/aai-traversal + build_docker_image ${src_folders[aai]}/search-data-service + build_docker_image ${src_folders[aai]}/data-router + build_docker_image ${src_folders[aai]}/model-loader + build_docker_image ${src_folders[aai]}/sparky-be else - SDC_IP_ADDR="10.0.3.1" + pull_onap_image aai-resources + pull_onap_image aai-traversal + pull_onap_image search-data-service + pull_onap_image data-router + pull_onap_image model-loader + pull_onap_image sparky-be fi - - # Run Health Check against SDC and verify that all five components are up - RES=$(curl http://$SDC_IP_ADDR:8181/sdc1/rest/healthCheck | grep -c "OK") - while [[ $RES -lt 5 ]]; do - RES=$(curl http://$SDC_IP_ADDR:8181/sdc1/rest/healthCheck | grep -c "OK") - done } # init_aai() - Function that initialize AAI services @@ -166,25 +138,16 @@ function init_aai { if [[ "$clone_repo" == "True" ]]; then clone_repos "aai" - if [[ "$compile_repo" == "True" ]]; then - compile_aai_repos - fi fi + compile_aai_repos setup_titan #start_aai_microservices - mkdir -p /opt/openecomp/aai/logs - mkdir -p /opt/openecomp/aai/data - - install_hbase - - # Wait 3 minutes before instantiating the A&AI container - sleep 180 - - install_ajsc_aai - _wait_for_sdc + if [[ "$skip_get_images" == "False" ]]; then + get_aai_images + fi if [[ "$skip_install" == "False" ]]; then - install_model_loader + install_aai fi } diff --git a/bootstrap/vagrant-onap/lib/files/haproxy.cfg b/bootstrap/vagrant-onap/lib/files/haproxy.cfg index 9ee24e629..ac4b75498 100644 --- a/bootstrap/vagrant-onap/lib/files/haproxy.cfg +++ b/bootstrap/vagrant-onap/lib/files/haproxy.cfg @@ -95,7 +95,7 @@ backend IST_Default_8447 balance roundrobin http-request set-header X-Forwarded-Port %[src_port] http-response set-header Strict-Transport-Security max-age=16000000;\ includeSubDomains;\ preload; - server aai-resources.api.simpledemo.openecomp.org aai-resources.api.simpledemo.openecomp.org:8447 port 8447 ssl verify none + server aai aai:8447 port 8447 ssl verify none ####################### # BACKEND 8446######### @@ -105,7 +105,7 @@ backend IST_AAI_8446 balance roundrobin http-request set-header X-Forwarded-Port %[src_port] http-response set-header Strict-Transport-Security max-age=16000000;\ includeSubDomains;\ preload; - server aai-traversal.api.simpledemo.openecomp.org aai-traversal.api.simpledemo.openecomp.org:8446 port 8446 ssl verify none + server aai aai:8446 port 8446 ssl verify none listen IST_AAI_STATS mode http diff --git a/bootstrap/vagrant-onap/lib/functions b/bootstrap/vagrant-onap/lib/functions index 47966f1b2..ba128d965 100755 --- a/bootstrap/vagrant-onap/lib/functions +++ b/bootstrap/vagrant-onap/lib/functions @@ -330,7 +330,7 @@ function build_docker_image { install_maven # Cleanup external repo sed -i 's|${docker.push.registry}/||g' pom.xml - local docker_build="mvn clean package docker:build" + local docker_build="mvn clean package docker:build -DskipTests=true -Dmaven.test.skip=true -Dmaven.javadoc.skip=true" if [ $profile ]; then docker_build+=" -P $profile" fi diff --git a/bootstrap/vagrant-onap/tests/test_aai b/bootstrap/vagrant-onap/tests/test_aai index 65917e092..dd027d2bc 100755 --- a/bootstrap/vagrant-onap/tests/test_aai +++ b/bootstrap/vagrant-onap/tests/test_aai @@ -5,7 +5,7 @@ source /var/onap/aai covered_functions=( #"install_hadoop" "install_haproxy" "clone_all_aai_repos" "compile_aai_repos" "setup_titan" "start_aai_microservices" "install_hbase" "install_ajsc_aai" "install_model_loader" -"install_hadoop" "install_haproxy" "clone_all_aai_repos" "compile_aai_repos" "setup_titan" "install_hbase" "install_ajsc_aai" "install_model_loader" +"install_hadoop" "install_haproxy" "clone_all_aai_repos" "compile_aai_repos" "setup_titan" "install_hbase" ) # test_install_hadoop() - Verify that Hadoop is downloaded and started properly @@ -93,22 +93,6 @@ function test_install_hbase { asserts_image_running aai-hbase-${hbase_version} } -# test_install_ajsc_aai() - Verify that AJSC AAI service is up and running properly -function test_install_ajsc_aai { - clone_repos "aai" - install_ajsc_aai - - asserts_image_running openecomp/ajsc-aai -} - -# test_install_model_loader() - Verify that Model AAI service is up and running properly -function test_install_model_loader { - clone_repos "aai" - install_model_loader - - asserts_image openecomp/model-loader -} - if [ "$1" != '*' ]; then unset covered_functions covered_functions=$1 -- cgit 1.2.3-korg