Saiku数据库迁移后的刷新脚本

之前有谈过对saiku中的数据进行刷新,因为saiku默认会从缓存中查询数据,但是配置不使用缓存又会效率低下...

所以这里就需要做一个数据刷新,每次ETL之后都需要执行一遍数据刷新脚本。

 

刷新脚本主要分为两部分

1.使用shell命令从数据库中读取已有的用户信息 (因为已经做过数据迁移,数据库已经从h2转为我们自己的mysql)

saikuRefresh.sh

#!/bin/bash

#数据库连接信息
HOSTNAME="10.11.22.33"  #数据库信息
PORT="3306"
USERNAME="root"
PASSWORD="root"
DBNAME="saiku"  #数据库名称
TABLENAME="users" #数据库中表的名称

#查詢數據
select_sql="select username from ${TABLENAME}"
mysql -h${HOSTNAME} -P${PORT} -u${USERNAME} -p${PASSWORD} ${DBNAME} -e "${select_sql}"

 使用命令 sh  saikuRefresh.sh 执行脚本,即会看到已有的用户信息

 

2. 循环取出用户信息,然后分别对每个用户执行刷新缓存命令 (以下便是完整的 saikuRefresh.sh 脚本信息)

>>> 接收shell脚本查询数据库的查询结果:  query_result=`mysql -h${HOSTNAME} -P${PORT} -u${USERNAME} -p${PASSWORD} ${DBNAME} -e "${select_sql}"`    #注意这个` `符号不要丢哦

>>> shell判断文件是否存在:

 if [ -f  '/app/Saiku/saiku_rfresh.txt' ] ; then

  echo 'exists!!!.'
fi

>>> shell判断字符串是否相等:

if [ "hello" != "hello" ] ; then
  echo 'equals!!!'
fi

>>>shell循环取出数据:

for currusername in $query_result;
do
  echo $currusername
done;

#!/bin/bash

#数据库连接信息
HOSTNAME="10.22.33.44"  #数据库信息
PORT="3306"
USERNAME="root"
PASSWORD="root"
DBNAME="report"  #数据库名称
TABLENAME="users" #数据库中表的名称

#cookies存储文件相关信息
dir=`pwd` #得到当前目录
filename=/saikuUserCookie.txt
filePath=${dir}${filename}

#查詢數據
select_sql="select username from ${TABLENAME}"
mysql -h${HOSTNAME} -P${PORT} -u${USERNAME} -p${PASSWORD} ${DBNAME} -e "${select_sql}"

#使用变量query_result接收查询结果 所有用户名
query_result=`mysql -h${HOSTNAME} -P${PORT} -u${USERNAME} -p${PASSWORD} ${DBNAME} -e "${select_sql}"`

#根据用户名进行统一刷新当前用户
for currusername in $query_result;
do
    if [ -f $filePath ] ; then
        rm -rf $filePath
        echo 'The saikuUserCookie.txt exists,old saikuUserCookie.txt is removed.'
    fi
  	
    if [ $currusername != "username" ] ; then
        echo 'Begin to get new Cookie into saikuUserCookie.txt.'
	curl -c ./saikuUserCookie.txt -d "language=zh&password=password124&username=$currusername" http://10.22.33.44:8080/saiku/rest/saiku/session
	curl -b ./saikuUserCookie.txt "http://10.22.33.44:8080/saiku/rest/saiku/$currusername/discover/refresh" 1>saiku_refresh_data.txt
	echo $currusername ' refresh OK............' 1>>saiku_refresh_data.txt
	echo '---------------------' $currusername 'refresh finished! ---------------------'
    fi
done;

  

 

 posted on 2019-04-15 18:26  阿叮339  阅读(396)  评论(0编辑  收藏  举报