#!/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
linux:shell實例eGW_install.sh
最后編輯于 :
?著作權(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ù)。
【社區(qū)內(nèi)容提示】社區(qū)部分內(nèi)容疑似由AI輔助生成,瀏覽時請結(jié)合常識與多方信息審慎甄別。
平臺聲明:文章內(nèi)容(如有圖片或視頻亦包括在內(nèi))由作者上傳并發(fā)布,文章內(nèi)容僅代表作者本人觀點,簡書系信息發(fā)布平臺,僅提供信息存儲服務(wù)。
相關(guān)閱讀更多精彩內(nèi)容
- 背景: 閱讀新聞 10個 Linux/Unix下 Bash 和 KSH shell 的作業(yè)控制實例 [日期:201...
- 說到shell通配符(wildcard),大家在使用時候會經(jīng)常用到。下面是一個實例: Linux shell通配符...
- Shell中字符串與數(shù)組操作實例 前言 本篇主要介紹了介紹在Shell腳本中對于字符串的處理,數(shù)據(jù)變量的定義與使用...