- 程序設計
為實現源碼編譯安裝一鍵操作,同時可以實現網絡遠程安裝,這樣只要安裝好一臺主機,別的主機就可以通過網絡遠程運行網絡主機的腳本來實現本地主機的軟件安裝,省去了拷貝腳本和安裝包的時間,提高工作效率!此腳本默認局域網內安裝,腳本需提前在互聯網下載好,存放至網絡主機指定文件夾內。
- 目標功能
- 可以在Centos6,和Centos7上分別實現一鍵安裝對應匹配的apche版本;
- 同時在任意一臺機器上均可實現網絡安裝,即通過http協議運行另外一臺機器上的httpd_install.shjiao腳本實現一鍵編譯安裝本機匹配的apache版本
- 實現思路
- 在安裝前,先拷貝好需要安裝的兩個apache軟件版本,http-2.2.34(Centos6)和http.2.4.25(Centos7)的安裝包,放至單機安裝的機器上的/var/www/html/src/下,以便本機可以通過http功能,首先給自己安裝對應版本軟件。
- 通過httpd實現網絡的單機安裝,安裝之前先確認httpd功能可用,安裝好apache后,將httpd進程殺掉,將80端口釋放,另外機器通過apache軟件的http功能實現網絡安裝。
- 代碼展示
1將常量和變量在這里進行聲明,IP和安裝包可以在這里進行替換,提高腳本管理的靈活和實用性。
2
(1安裝前確認httpd 服務是正常工作的,由于不知名的問題,這里只有先卸載再重新安裝一下,才能確保它是正常工作的;
(2判斷完版本后,對Pa(安裝包變量)進行賦值,同時執行對應版本關閉防火墻的密令;
(3通過sed 密令修改SELINUX值為disable.考慮到這個值可能已經被改過,所以通過行首錨定,只檢索^SELINUX,然后替換整行;
(4判斷并且創建/app 和/root/src? 文件夾通過wget 命令通過http 協議,獲取安裝包,解壓縮至/src 下,進入文件夾內,準備安裝;
3安裝步驟很簡單,這里的killall -9 httpd 是用來釋放80端口的,安裝時,總是報錯,80端口被httpd進程占用,所以只有殺掉進程,才能最后啟動成功。
4這里存粹是為了網絡安裝做準備,apachectl start 成功后,另外一臺主機就可以通過
curl http://主機IP/httpd_install.sh|bash? 來運行腳本為本機編譯安裝軟件了!
源代碼如下:
#!/bin/bash
#
#********************************************************************
#Author: nieshaokai
#Date: 2018-07-31
#FileName: httpd_install.sh
#URL: http://www.magedu.com
#Description: The apache install suitable for Centos6 or Centos7
#Version 1.0
#The Script adheres to the OLP
#OLP-old white protocol;the changer must be handsome and don`t snore
#常量聲明
——————————————————————————————————————
IP=192.168.0.116 #遠程主機的IP
P7=httpd-2.4.25.tar.bz2 #Centos6 的源碼版本
P6=httpd-2.2.34.tar.bz2 #Centos7 的源碼版本
#變量聲明
#——————————————————————————————————————
V=`cat /etc/redhat-release| sed -r ‘s/[^0-9]+([0-9]).*/\1/’` #版本號
#Pa 代碼中源碼包變量
#安裝前準備工作
#——————————————————————————————————————
yum clean all &> /dev/null;
yum -y remove httpd || exit;
killall -9 httpd
yum -y install httpd || exit;
[ $V -eq 6 ] && { service iptables stop; chkconfig iptables off;Pa=${P6};service httpd start; }
[ $V -eq 7 ] && { systemctl stop firewalld;systemctl disable firewalld;Pa=${P7};systemctl start httpd; }
yum -y groupinstall “Development tools” || exit;
sed -i ‘s/^SELINUX.*/SELINUX=disabled/’ /etc/selinux/config # 將SELINUX=enforcing這行替換成=disabled;
[ -d /app ] || mkdir /app
[ -d /root/src ] || mkdir src; #查看是不是有src 文件夾沒有的話創建一個
cd /root/src
wget http://${IP}/src/${Pa} || exit;
tar xvf ${Pa}
cd `echo ${Pa}|sed -r ‘s/(^httpd-.*)\.tar.*/\1/’` ||exit;
#安裝模塊
#——————————————————————————————————————
./configure –prefix=/app # 將安裝目錄設置成/app
[ $? -eq 0 ] && make -j4 && make install || { echo -e”\e[31;1mThere’s a problem here\e[0m” ;exit; }
echo ‘PATH=/app/bin:$PATH’ >> /etc/profile.d/env.sh #修改環境變量
. /etc/profile.d/env.sh
killall -9 httpd # httpd進程非法占用80端口,已經被判死刑,立即執行!
apachectl start
[ $? -eq 0 ] && echo -e “\e[36;1mwelcom to use apache\e[0m” || echo -e “\e[31;1mOther problems may cause the startup to fail\e[0m”
#為做網絡安裝主機做準備
#——————————————————————————————————————
[ -d /app/htdocs/src ] || mkdir /app/htdocs/src
cd /app/htdocs/src
cp /var/www/html/src/http* /app/htdocs/src/
cp /root/bin/httpd_install.sh /app/htdocs/ &> /dev/null
本文來自投稿,不代表Linux運維部落立場,如若轉載,請注明出處:http://www.www58058.com/96888