linux:shell實例eGW_install.sh

#!/bin/bash -

#########################################################################################
#install
#安裝程序,安裝eGW,設(shè)置系統(tǒng)環(huán)境
#version:2.1
#dongfeng@baicells.com 20170425
#########################################################################################


#停止eGW服務(wù)
monitor_run=`systemctl status monitor.service |grep running`
if [ -n "$monitor_run" ];then
        echo "start to stop monitor.service"
        systemctl stop monitor.service
        sleep 2
fi
#安裝eGW
echo "start to install eGW"
DIR=/home/baicells/eGW
if [ ! -d "$DIR" ];then
    echo "eGW is not exist"
    echo "mkdir $DIR"
    mkdir $DIR    #如果主目錄不存在,則創(chuàng)建目錄
    echo "tar -zxvf eGW.tar.gz"
    echo "********************"
    tar -zxvf eGW.tar.gz -C $DIR    #解壓安裝文件
    echo "********************"
    echo "create config.txt and networkcfg.conf"
    echo "#config file" > ${DIR}/config.txt    #初始化網(wǎng)關(guān)配置文件
    echo "#networkcfg file" > ${DIR}/networkcfg.conf    #初始化網(wǎng)絡(luò)配置文件
else
    date=`date +%Y%m%d%H%M`
    DIR_bak=${DIR}_bak
    DIR_date=${DIR}_$date
    echo "eGW is already exist"
    echo "mv $DIR $DIR_bak"
    mv $DIR $DIR_bak    #如果目錄存在,備份目錄
    echo "mkdir $DIR"
    mkdir $DIR    #然后創(chuàng)建目錄
    echo "********************"
    tar -zxvf eGW.tar.gz -C $DIR    #解壓安裝文件
    echo "********************"
    if [ -f "${DIR_bak}/config.txt" ];then
        echo "cp ${DIR_bak}/config.txt $DIR"
        cp ${DIR_bak}/config.txt $DIR    #替換網(wǎng)關(guān)配置文件
    else
        echo "config.txt is not exist"
    fi
    if [ -f "${DIR_bak}/networkcfg.conf" ];then
        echo "cp ${DIR_bak}/networkcfg.conf $DIR"
        cp ${DIR_bak}/networkcfg.conf $DIR  #替換網(wǎng)絡(luò)配置文件
    else
        echo "networkcfg.conf is not exist"
    fi
    cd $DIR_bak
    folder_CDR=CDR
    if [ -d "$folder_CDR" ];then
        echo "cp -rf ${DIR_bak}/$folder_CDR $DIR"
        cp -rf ${DIR_bak}/$folder_CDR $DIR      #保留話單到新版本
#   else
#       cd ${DIR}
#       mkdir -p $folder_CDR/$folder_cdrDat
    fi

    folder_Dailystatic=Dailystatic
    if [ -d "$folder_Dailystatic" ];then
        echo "cp -rf ${DIR_bak}/$folder_Dailystatic $DIR"
        cp -rf ${DIR_bak}/$folder_Dailystatic $DIR   #保留流量統(tǒng)計到新版本
    fi

    folder_Userstatic=Userstatic
    if [ -d "$folder_Userstatic" ];then
        echo "cp -rf ${DIR_bak}/$folder_Userstatic $DIR"
        cp -rf ${DIR_bak}/$folder_Userstatic $DIR   #保留用戶數(shù)統(tǒng)計到新版本
    fi

    mv $DIR_bak $DIR_date
fi

#修改文件執(zhí)行權(quán)限
cd $DIR
echo "chmod +x"
chmod +x startAll.sh    #修改執(zhí)行權(quán)限
chmod +x monitor        #修改執(zhí)行權(quán)限
chmod +x ltegwd         #修改執(zhí)行權(quán)限
chmod +x ltegw.sh       #修改執(zhí)行權(quán)限
chmod +x lccmd          #修改執(zhí)行權(quán)限
chmod +x watchdog.sh    #修改執(zhí)行權(quán)限
chmod +x dailystatic.py #修改執(zhí)行權(quán)限
chmod +x vtysh          #修改執(zhí)行權(quán)限
chmod +x emailontime.py #修改執(zhí)行權(quán)限
chmod +x checkMD5.py    #修改執(zhí)行權(quán)限

echo "cp monitor.service /usr/lib/systemd/system/ " 
cp monitor.service /usr/lib/systemd/system/      #復(fù)制腳本到服務(wù)目錄
echo "mv libzebra.so.0 /usr/local/lib"
mv libzebra.so.0 /usr/local/lib   #復(fù)制庫文件到指定目錄
echo "systemctl daemon-reload"
systemctl daemon-reload        #更新服務(wù)目錄
echo "systemctl enable monitor.service"
systemctl enable monitor.service #設(shè)置服務(wù)開機(jī)自啟動

#設(shè)置系統(tǒng)環(huán)境
echo "start to set system"
#配置ipsec寫入自啟動
ipsec_autostart=`find /etc/rc.d -name "rc.local" |xargs grep "^ipsec start"`
if [ ! -n "$ipsec_autostart" ];then
    echo "set ipsec start"
        echo "ipsec start" >> /etc/rc.d/rc.local
    chmod +x /etc/rc.d/rc.local
fi
echo "systemctl stop firewalld.service"
systemctl stop firewalld.service #為了防止系統(tǒng)防火墻屏蔽接口,先關(guān)閉防火墻
echo "systemctl disable firewalld.service"
systemctl disable firewalld.service #關(guān)閉開機(jī)啟動
#ulimit -c unlimited  #不限制用戶資源
echo "set SELINUX closed"
setenforce 0
sed -i "s/SELINUX=enforcing/SELINUX=disabled/g"  /etc/selinux/config #關(guān)閉selinux
#sed -i "s/Defaults    requiretty/#Defaults    requiretty/g"  /etc/sudoers #修改root權(quán)限
echo "mkdir lc and mo"
if [ ! -d "/var/opc/lc" ];then
    mkdir -p /var/opt/lc
fi
if [ ! -d "/var/opc/mo" ];then
        mkdir -p /var/opt/mo
fi

ip_forward=`find /etc -name "sysctl.conf" |xargs grep "net.ipv4.ip_forward"`
if [ ! -n "$ip_forward" ];then
    echo "set net.ipv4.ip_forward=1"
        echo "net.ipv4.ip_forward=1" >> /etc/sysctl.conf
else    
    echo "set net.ipv4.ip_forward=1"
    sed -i "s/net.ipv4.ip_forward=0/net.ipv4.ip_forward=1/g"  /etc/sysctl.conf
fi

#設(shè)置coredump
cd /home/baicells
folder_coredump=coredump
echo "set coredump"
if [ ! -d "$folder_coredump" ];then
    mkdir $folder_coredump
    chmod 0773 $folder_coredump
fi

echo "kernel.core_pattern = /home/baicells/coredump/core-%e-sig%s-user%u-group%g-pid%p-time%t" > /etc/sysctl.d/core.conf
echo "kernel.core_uses_pid = 1" >> /etc/sysctl.d/core.conf
echo "fs.suid_dumpable = 2" >> /etc/sysctl.d/core.conf

echo "*       hard        core        unlimited" > /etc/security/limits.d/core.conf
echo "*       soft        core        unlimited" >> /etc/security/limits.d/core.conf

default_limit_core=`find /etc/systemd -name "system.conf" |xargs grep "DefaultLimitCORE=infinity"`
if [ ! -n "$default_limit_core" ];then
        echo "DefaultLimitCORE=infinity" >> /etc/systemd/system.conf
fi

systemctl daemon-reload
systemctl daemon-reexec
sysctl -p /etc/sysctl.d/core.conf
sysctl -p

#啟動eGW服務(wù)
echo "start to start monitor.service"
systemctl start monitor.service

最后編輯于
?著作權(quán)歸作者所有,轉(zhuǎn)載或內(nèi)容合作請聯(lián)系作者
【社區(qū)內(nèi)容提示】社區(qū)部分內(nèi)容疑似由AI輔助生成,瀏覽時請結(jié)合常識與多方信息審慎甄別。
平臺聲明:文章內(nèi)容(如有圖片或視頻亦包括在內(nèi))由作者上傳并發(fā)布,文章內(nèi)容僅代表作者本人觀點,簡書系信息發(fā)布平臺,僅提供信息存儲服務(wù)。

相關(guān)閱讀更多精彩內(nèi)容

友情鏈接更多精彩內(nèi)容