#!/bin/bash # Author: yeho # BLOG: https://blog.linuxeye.cn # # Notes: OneinStack for CentOS/RadHat 6+ Debian 7+ and Ubuntu 12+ # # Project home page: # https://oneinstack.com # https://github.com/lj2007331/oneinstack export PATH=/sbin:/bin:/usr/sbin:/usr/bin:/usr/local/sbin:/usr/local/bin clear printf " ####################################################################### # OneinStack for CentOS/RadHat 6+ Debian 7+ and Ubuntu 12+ # # Setup the backup parameters # # For more information please visit https://oneinstack.com # ####################################################################### " # Check if user is root [ $(id -u) != "0" ] && { echo "${CFAILURE}Error: You must be root to run this script${CEND}"; exit 1; } oneinstack_dir=$(dirname "`readlink -f $0`") pushd ${oneinstack_dir} > /dev/null . ./options.conf . ./versions.txt . ./include/color.sh . ./include/check_os.sh . ./include/check_dir.sh . ./include/download.sh . ./include/python.sh while :; do echo echo 'Please select your backup destination:' echo -e "\t${CMSG}1${CEND}. Localhost" echo -e "\t${CMSG}2${CEND}. Remote host" echo -e "\t${CMSG}3${CEND}. Aliyun OSS" echo -e "\t${CMSG}4${CEND}. Qcloud COS" echo -e "\t${CMSG}5${CEND}. UPYUN(又拍云)" read -p "Please input a number:(Default 1 press Enter) " desc_bk [ -z "${desc_bk}" ] && desc_bk=1 ary=(1 2 3 4 5 12 13 14 15 23 24 25 34 35 45 123 124 125 134 135 145 234 235 245 345 1234 1235 2345 12345) if [[ "${ary[@]}" =~ "${desc_bk}" ]]; then break else echo "${CWARNING}input error! Please only input number 1,2,12,23,234 and so on${CEND}" fi done sed -i 's@^backup_destination=.*@backup_destination=@' ./options.conf [ `echo ${desc_bk} | grep -e 1` ] && sed -i 's@^backup_destination=.*@backup_destination=local@' ./options.conf [ `echo ${desc_bk} | grep -e 2` ] && sed -i 's@^backup_destination=.*@&,remote@' ./options.conf [ `echo ${desc_bk} | grep -e 3` ] && sed -i 's@^backup_destination=.*@&,oss@' ./options.conf [ `echo ${desc_bk} | grep -e 4` ] && sed -i 's@^backup_destination=.*@&,cos@' ./options.conf [ `echo ${desc_bk} | grep -e 5` ] && sed -i 's@^backup_destination=.*@&,upyun@' ./options.conf sed -i 's@^backup_destination=,@backup_destination=@' ./options.conf while :; do echo echo 'Please select your backup content:' echo -e "\t${CMSG}1${CEND}. Only Database" echo -e "\t${CMSG}2${CEND}. Only Website" echo -e "\t${CMSG}3${CEND}. Database and Website" read -p "Please input a number:(Default 1 press Enter) " content_bk [ -z "${content_bk}" ] && content_bk=1 if [[ ! ${content_bk} =~ ^[1-3]$ ]]; then echo "${CWARNING}input error! Please only input number 1~3${CEND}" else break fi done [ "${content_bk}" == '1' ] && sed -i 's@^backup_content=.*@backup_content=db@' ./options.conf [ "${content_bk}" == '2' ] && sed -i 's@^backup_content=.*@backup_content=web@' ./options.conf [ "${content_bk}" == '3' ] && sed -i 's@^backup_content=.*@backup_content=db,web@' ./options.conf if [[ ${desc_bk} =~ ^[1,2]$ ]]; then while :; do echo echo "Please enter the directory for save the backup file: " read -p "(Default directory: ${backup_dir}): " new_backup_dir [ -z "${new_backup_dir}" ] && new_backup_dir="${backup_dir}" if [ -z "`echo ${new_backup_dir}| grep '^/'`" ]; then echo "${CWARNING}input error! ${CEND}" else break fi done sed -i "s@^backup_dir=.*@backup_dir=${new_backup_dir}@" ./options.conf fi while :; do echo echo "Pleas enter a valid backup number of days: " read -p "(Default days: 5): " expired_days [ -z "${expired_days}" ] && expired_days=5 [ -n "`echo ${expired_days} | sed -n "/^[0-9]\+$/p"`" ] && break || echo "${CWARNING}input error! Please only enter numbers! ${CEND}" done sed -i "s@^expired_days=.*@expired_days=${expired_days}@" ./options.conf if [ "${content_bk}" != '2' ]; then databases=`${db_install_dir}/bin/mysql -uroot -p$dbrootpwd -e "show databases\G" | grep Database | awk '{print $2}' | grep -Evw "(performance_schema|information_schema|mysql|sys)"` while :; do echo echo "Please enter one or more name for database, separate multiple database names with commas: " read -p "(Default database: `echo $databases | tr ' ' ','`) " db_name db_name=`echo ${db_name} | tr -d ' '` [ -z "${db_name}" ] && db_name="`echo $databases | tr ' ' ','`" D_tmp=0 for D in `echo ${db_name} | tr ',' ' '` do [ -z "`echo $databases | grep -w $D`" ] && { echo "${CWARNING}$D was not exist! ${CEND}" ; D_tmp=1; } done [ "$D_tmp" != '1' ] && break done sed -i "s@^db_name=.*@db_name=${db_name}@" ./options.conf fi if [ "${content_bk}" != '1' ]; then websites=`ls ${wwwroot_dir}` while :; do echo echo "Please enter one or more name for website, separate multiple website names with commas: " read -p "(Default website: `echo $websites | tr ' ' ','`) " website_name website_name=`echo ${website_name} | tr -d ' '` [ -z "${website_name}" ] && website_name="`echo $websites | tr ' ' ','`" W_tmp=0 for W in `echo ${website_name} | tr ',' ' '` do [ ! -e "${wwwroot_dir}/$W" ] && { echo "${CWARNING}${wwwroot_dir}/$W not exist! ${CEND}" ; W_tmp=1; } done [ "$W_tmp" != '1' ] && break done sed -i "s@^website_name=.*@website_name=${website_name}@" ./options.conf fi echo echo "You have to backup the content:" [ "${content_bk}" != '2' ] && echo "Database: ${CMSG}${db_name}${CEND}" [ "${content_bk}" != '1' ] && echo "Website: ${CMSG}${website_name}${CEND}" if [ `echo ${desc_bk} | grep -e 2` ]; then > tools/iplist.txt while :; do echo read -p "Please enter the remote host ip: " remote_ip [ -z "${remote_ip}" -o "${remote_ip}" == '127.0.0.1' ] && continue echo read -p "Please enter the remote host port(Default: 22) : " remote_port [ -z "${remote_port}" ] && remote_port=22 echo read -p "Please enter the remote host user(Default: root) : " remote_user [ -z "${remote_user}" ] && remote_user=root echo read -p "Please enter the remote host password: " remote_password IPcode=$(echo "ibase=16;$(echo "${remote_ip}" | xxd -ps -u)"|bc|tr -d '\\'|tr -d '\n') Portcode=$(echo "ibase=16;$(echo "${remote_port}" | xxd -ps -u)"|bc|tr -d '\\'|tr -d '\n') PWcode=$(echo "ibase=16;$(echo "$remote_password" | xxd -ps -u)"|bc|tr -d '\\'|tr -d '\n') [ -e "~/.ssh/known_hosts" ] && grep ${remote_ip} ~/.ssh/known_hosts | sed -i "/${remote_ip}/d" ~/.ssh/known_hosts ./tools/mssh.exp ${IPcode}P ${remote_user} ${PWcode}P ${Portcode}P true 10 if [ $? -eq 0 ]; then [ -z "`grep ${remote_ip} tools/iplist.txt`" ] && echo "${remote_ip} ${remote_port} ${remote_user} $remote_password" >> tools/iplist.txt || echo "${CWARNING}${remote_ip} has been added! ${CEND}" while :; do read -p "Do you want to add more host ? [y/n]: " morehost_yn if [[ ! ${morehost_yn} =~ ^[y,n]$ ]]; then echo "${CWARNING}input error! Please only input 'y' or 'n'${CEND}" else break fi done [ "${morehost_yn}" == 'n' ] && break fi done fi if [ `echo ${desc_bk} | grep -e 3` ]; then if [ ! -e "/usr/local/bin/ossutil" ]; then if [ "${OS_BIT}" == '64' ]; then wget -qc http://docs-aliyun.cn-hangzhou.oss.aliyun-inc.com/assets/attach/50452/cn_zh/1516454058701/ossutil64 -O /usr/local/bin/ossutil elif [ "${OS_BIT}" == '32' ]; then wget -qc http://docs-aliyun.cn-hangzhou.oss.aliyun-inc.com/assets/attach/50452/cn_zh/1516453988016/ossutil32 -O /usr/local/bin/ossutil fi chmod +x /usr/local/bin/ossutil fi while :; do echo echo 'Please select your backup datacenter:' echo -e "\t ${CMSG}1${CEND}. cn-hangzhou-华东 1 (杭州) ${CMSG}2${CEND}. cn-shanghai-华东 2 (上海)" echo -e "\t ${CMSG}3${CEND}. cn-qingdao-华北 1 (青岛) ${CMSG}4${CEND}. cn-beijing-华北 2 (北京)" echo -e "\t ${CMSG}5${CEND}. cn-zhangjiakou-华北 3 (张家口) ${CMSG}6${CEND}. cn-huhehaote-华北 5(呼和浩特)" echo -e "\t ${CMSG}7${CEND}. cn-shenzhen-华南 1 (深圳) ${CMSG}8${CEND}. cn-hongkong-香港" echo -e "\t ${CMSG}9${CEND}. us-west-美西 1 (硅谷) ${CMSG}10${CEND}. us-east-美东 1 (弗吉尼亚)" echo -e "\t${CMSG}11${CEND}. ap-southeast-亚太东南 1 (新加坡) ${CMSG}12${CEND}. ap-southeast-亚太东南 2 (悉尼)" echo -e "\t${CMSG}13${CEND}. ap-southeast-亚太东南 3 (吉隆坡) ${CMSG}14${CEND}. ap-northeast-亚太东北 1 (日本)" echo -e "\t${CMSG}15${CEND}. eu-central-欧洲中部 1 (法兰克福) ${CMSG}16${CEND}. me-east-中东东部 1 (迪拜)" read -p "Please input a number:(Default 1 press Enter) " Location [ -z "${Location}" ] && Location=1 if [[ "${Location}" =~ ^[1-9]$|^1[0-6]$ ]]; then break else echo "${CWARNING}input error! Please only input number 1~16${CEND}" fi done [ "${Location}" == '1' ] && Host=oss-cn-hangzhou-internal.aliyuncs.com [ "${Location}" == '2' ] && Host=oss-cn-shanghai-internal.aliyuncs.com [ "${Location}" == '3' ] && Host=oss-cn-qingdao-internal.aliyuncs.com [ "${Location}" == '4' ] && Host=oss-cn-beijing-internal.aliyuncs.com [ "${Location}" == '5' ] && Host=oss-cn-zhangjiakou-internal.aliyuncs.com [ "${Location}" == '6' ] && Host=oss-cn-huhehaote-internal.aliyuncs.com [ "${Location}" == '7' ] && Host=oss-cn-shenzhen-internal.aliyuncs.com [ "${Location}" == '8' ] && Host=oss-cn-hongkong-internal.aliyuncs.com [ "${Location}" == '9' ] && Host=oss-us-west-1-internal.aliyuncs.com [ "${Location}" == '10' ] && Host=oss-us-east-1-internal.aliyuncs.com [ "${Location}" == '11' ] && Host=oss-ap-southeast-1-internal.aliyuncs.com [ "${Location}" == '12' ] && Host=oss-ap-southeast-2-internal.aliyuncs.com [ "${Location}" == '13' ] && Host=oss-ap-southeast-3-internal.aliyuncs.com [ "${Location}" == '14' ] && Host=oss-ap-northeast-1-internal.aliyuncs.com [ "${Location}" == '15' ] && Host=oss-eu-central-1-internal.aliyuncs.com [ "${Location}" == '16' ] && Host=oss-me-east-1-internal.aliyuncs.com [ "$(./include/check_port.py ${Host} 80)" == "False" ] && Host=`echo ${Host} | sed 's@-internal@@g'` [ -e "/root/.ossutilconfig" ] && rm -f /root/.ossutilconfig while :; do echo read -p "Please enter the aliyun oss Access Key ID: " KeyID [ -z "${KeyID}" ] && continue echo read -p "Please enter the aliyun oss Access Key Secret: " KeySecret [ -z "${KeySecret}" ] && continue /usr/local/bin/ossutil ls -e ${Host} -i ${KeyID} -k ${KeySecret} >/dev/null 2>&1 if [ $? -eq 0 ];then /usr/local/bin/ossutil config -e ${Host} -i ${KeyID} -k ${KeySecret} >/dev/null 2>&1 while :; do echo read -p "Please enter the aliyun oss bucket: " Bucket /usr/local/bin/ossutil mb oss://${Bucket} >/dev/null 2>&1 [ $? -eq 0 ] && { echo "${CMSG}[${Bucket}] createbucket OK${CEND}"; sed -i "s@^oss_bucket=.*@oss_bucket=${Bucket}@" ./options.conf; break; } || echo "${CWARNING}[${Bucket}] already exists, You need to use the OSS Console to create a bucket for storing.${CEND}" done break fi done fi if [ `echo ${desc_bk} | grep -e 4` ]; then [ ! -e "${python_install_dir}/bin/python" ] && Install_Python [ ! -e "${python_install_dir}/lib/coscmd" ] && ${python_install_dir}/bin/pip install coscmd >/dev/null 2>&1 while :; do echo echo 'Please select your backup datacenter:' echo -e "\t ${CMSG}1${CEND}. 北京一区(华北) ${CMSG}2${CEND}. 北京" echo -e "\t ${CMSG}3${CEND}. 上海(华东) ${CMSG}4${CEND}. 广州(华南)" echo -e "\t ${CMSG}5${CEND}. 成都(西南) ${CMSG}6${CEND}. 新加坡" echo -e "\t ${CMSG}7${CEND}. 香港 ${CMSG}8${CEND}. 多伦多" echo -e "\t ${CMSG}9${CEND}. 法兰克福" read -p "Please input a number:(Default 1 press Enter) " Location [ -z "${Location}" ] && Location=1 if [[ "${Location}" =~ ^[1-9]$ ]]; then break else echo "${CWARNING}input error! Please only input number 1~9${CEND}" fi done [ "${Location}" == '1' ] && region='ap-beijing-1' [ "${Location}" == '2' ] && region='ap-beijing' [ "${Location}" == '3' ] && region='ap-shanghai' [ "${Location}" == '4' ] && region='ap-guangzhou' [ "${Location}" == '5' ] && region='ap-chengdu' [ "${Location}" == '6' ] && region='ap-singapore' [ "${Location}" == '7' ] && region='ap-hongkong' [ "${Location}" == '8' ] && region='na-toronto' [ "${Location}" == '9' ] && region='eu-frankfurt' while :; do echo read -p "Please enter the Qcloud COS APPID: " APPID [ -z "${APPID}" ] && continue echo read -p "Please enter the Qcloud COS SecretId: " SecretId [ -z "${SecretId}" ] && continue echo read -p "Please enter the Qcloud COS SecretKey: " SecretKey [ -z "$SecretKey" ] && continue echo read -p "Please enter the Qcloud COS bucket: " bucket [ -z "${bucket}" ] && continue echo ${python_install_dir}/bin/coscmd config -u ${APPID} -a ${SecretId} -s $SecretKey -r $region -b ${bucket} >/dev/null 2>&1 ${python_install_dir}/bin/coscmd list >/dev/null 2>&1 if [ $? = 0 ]; then echo "${CMSG}APPID/SecretId/SecretKey/region/bucket OK${CEND}" echo break else echo "${CWARNING}input error! APPID/SecretId/SecretKey/region/bucket invalid${CEND}" fi done fi if [ `echo ${desc_bk} | grep -e 5` ]; then if [ ! -e "/usr/local/bin/upx" ]; then if [ "${OS_BIT}" == '64' ]; then wget -qc http://collection.b0.upaiyun.com/softwares/upx/upx-linux-amd64-v0.2.3 -O /usr/local/bin/upx elif [ "${OS_BIT}" == '32' ]; then wget -qc http://collection.b0.upaiyun.com/softwares/upx/upx-linux-386-v0.2.3 -O /usr/local/bin/upx fi chmod +x /usr/local/bin/upx fi while :; do echo read -p "Please enter the ServiceName: " ServiceName [ -z "${ServiceName}" ] && continue echo read -p "Please enter the Operator: " Operator [ -z "${Operator}" ] && continue echo read -p "Please enter the Password: " Password [ -z "${Password}" ] && continue echo /usr/local/bin/upx login ${ServiceName} ${Operator} ${Password} >/dev/null 2>&1 if [ $? = 0 ]; then echo "${CMSG}ServiceName/Operator/Password OK${CEND}" echo break else echo "${CWARNING}input error! ServiceName/Operator/Password invalid${CEND}" fi done fi