|
@@ -13,10 +13,13 @@ Upgrade_Nginx() {
|
|
|
[ ! -e "$nginx_install_dir/sbin/nginx" ] && echo "${CWARNING}Nginx is not installed on your system! ${CEND}" && exit 1
|
|
|
OLD_Nginx_version_tmp=`$nginx_install_dir/sbin/nginx -v 2>&1`
|
|
|
OLD_Nginx_version=${OLD_Nginx_version_tmp##*/}
|
|
|
+ Latest_Nginx_version=`curl -s http://nginx.org/en/CHANGES-1.12 | awk '/Changes with nginx/{print$0}' | awk '{print $4}' | head -1`
|
|
|
+ [ -z "$Latest_Nginx_version" ] && Latest_Nginx_version=`curl -s http://nginx.org/en/CHANGES | awk '/Changes with nginx/{print$0}' | awk '{print $4}' | head -1`
|
|
|
echo
|
|
|
echo "Current Nginx Version: ${CMSG}$OLD_Nginx_version${CEND}"
|
|
|
while :; do echo
|
|
|
- read -p "Please input upgrade Nginx Version(example: 1.9.15): " NEW_Nginx_version
|
|
|
+ read -p "Please input upgrade Nginx Version(default: $Latest_Nginx_version): " NEW_Nginx_version
|
|
|
+ [ -z "$NEW_Nginx_version" ] && NEW_Nginx_version=$Latest_Nginx_version
|
|
|
if [ "$NEW_Nginx_version" != "$OLD_Nginx_version" ]; then
|
|
|
[ ! -e "nginx-$NEW_Nginx_version.tar.gz" ] && wget --no-check-certificate -c http://nginx.org/download/nginx-$NEW_Nginx_version.tar.gz > /dev/null 2>&1
|
|
|
if [ -e "nginx-$NEW_Nginx_version.tar.gz" ]; then
|
|
@@ -64,14 +67,16 @@ Upgrade_Nginx() {
|
|
|
}
|
|
|
|
|
|
Upgrade_Tengine() {
|
|
|
- pushd ${oneinstack_dir}/src
|
|
|
+ pushd ${oneinstack_dir}/src > /dev/null
|
|
|
[ ! -e "$tengine_install_dir/sbin/nginx" ] && echo "${CWARNING}Tengine is not installed on your system! ${CEND}" && exit 1
|
|
|
OLD_Tengine_version_tmp=`$tengine_install_dir/sbin/nginx -v 2>&1`
|
|
|
OLD_Tengine_version="`echo ${OLD_Tengine_version_tmp#*/} | awk '{print $1}'`"
|
|
|
+ Latest_Tengine_version=`curl -s http://tengine.taobao.org/changelog.html | grep -oE "[0-9]\.[0-9]\.[0-9]+" | head -1`
|
|
|
echo
|
|
|
echo "Current Tengine Version: ${CMSG}$OLD_Tengine_version${CEND}"
|
|
|
while :; do echo
|
|
|
- read -p "Please input upgrade Tengine Version(example: 2.1.15): " NEW_Tengine_version
|
|
|
+ read -p "Please input upgrade Tengine Version(default: $Latest_Tengine_version): " NEW_Tengine_version
|
|
|
+ [ -z "$NEW_Tengine_version" ] && NEW_Tengine_version=$Latest_Tengine_version
|
|
|
if [ "$NEW_Tengine_version" != "$OLD_Tengine_version" ]; then
|
|
|
[ ! -e "tengine-$NEW_Tengine_version.tar.gz" ] && wget --no-check-certificate -c http://tengine.taobao.org/download/tengine-$NEW_Tengine_version.tar.gz > /dev/null 2>&1
|
|
|
if [ -e "tengine-$NEW_Tengine_version.tar.gz" ]; then
|
|
@@ -124,14 +129,16 @@ Upgrade_Tengine() {
|
|
|
}
|
|
|
|
|
|
Upgrade_OpenResty() {
|
|
|
- pushd ${oneinstack_dir}/src
|
|
|
+ pushd ${oneinstack_dir}/src > /dev/null
|
|
|
[ ! -e "$openresty_install_dir/nginx/sbin/nginx" ] && echo "${CWARNING}OpenResty is not installed on your system! ${CEND}" && exit 1
|
|
|
OLD_OpenResty_version_tmp=`$openresty_install_dir/nginx/sbin/nginx -v 2>&1`
|
|
|
OLD_OpenResty_version="`echo ${OLD_OpenResty_version_tmp#*/} | awk '{print $1}'`"
|
|
|
+ Latest_OpenResty_version=`curl -s https://openresty.org/en/download.html | awk '/download\/openresty-/{print $0}' | grep -oE "[0-9]+\.[0-9]+\.[0-9]+\.[0-9]+" | head -1`
|
|
|
echo
|
|
|
echo "Current OpenResty Version: ${CMSG}$OLD_OpenResty_version${CEND}"
|
|
|
while :; do echo
|
|
|
- read -p "Please input upgrade OpenResty Version(example: 1.9.7.19): " NEW_OpenResty_version
|
|
|
+ read -p "Please input upgrade OpenResty Version(default: $Latest_OpenResty_version): " NEW_OpenResty_version
|
|
|
+ [ -z "$NEW_OpenResty_version" ] && NEW_OpenResty_version=$Latest_OpenResty_version
|
|
|
if [ "$NEW_OpenResty_version" != "$OLD_OpenResty_version" ]; then
|
|
|
[ ! -e "openresty-$NEW_OpenResty_version.tar.gz" ] && wget --no-check-certificate -c https://openresty.org/download/openresty-$NEW_OpenResty_version.tar.gz > /dev/null 2>&1
|
|
|
if [ -e "openresty-$NEW_OpenResty_version.tar.gz" ]; then
|
|
@@ -176,3 +183,65 @@ Upgrade_OpenResty() {
|
|
|
fi
|
|
|
popd > /dev/null
|
|
|
}
|
|
|
+
|
|
|
+Upgrade_Apache() {
|
|
|
+ pushd ${oneinstack_dir}/src > /dev/null
|
|
|
+ [ ! -e "$apache_install_dir/bin/httpd" ] && echo "${CWARNING}Apache is not installed on your system! ${CEND}" && exit 1
|
|
|
+ OLD_Apache_version="`/usr/local/apache/bin/httpd -v | grep version | awk -F'/| ' '{print $4}'`"
|
|
|
+ Apache_flag="`echo $OLD_Apache_version | awk -F. '{print $1 $2}'`"
|
|
|
+ Latest_Apache_version=`curl -s http://httpd.apache.org/download.cgi | awk "/#apache$Apache_flag/{print $2}" | head -1 | grep -oE "2\.[24]\.[0-9]+"`
|
|
|
+ echo
|
|
|
+ echo "Current Apache Version: ${CMSG}$OLD_Apache_version${CEND}"
|
|
|
+ while :; do echo
|
|
|
+ read -p "Please input upgrade Apache Version(Default: $Latest_Apache_version): " NEW_Apache_version
|
|
|
+ [ -z "$NEW_Apache_version" ] && NEW_Apache_version=$Latest_Apache_version
|
|
|
+ if [ "$NEW_Apache_version" != "$OLD_Apache_version" ]; then
|
|
|
+ if [ "$Apache_flag" == '24' ]; then
|
|
|
+ src_url=http://archive.apache.org/dist/apr/apr-${apr_version}.tar.gz && Download_src
|
|
|
+ src_url=http://archive.apache.org/dist/apr/apr-util-${apr_util_version}.tar.gz && Download_src
|
|
|
+ tar xzf apr-${apr_version}.tar.gz
|
|
|
+ tar xzf apr-util-${apr_util_version}.tar.gz
|
|
|
+ fi
|
|
|
+ [ ! -e "httpd-$NEW_Apache_version.tar.gz" ] && wget --no-check-certificate -c http://mirrors.linuxeye.com/apache/httpd/httpd-$NEW_Apache_version.tar.gz > /dev/null 2>&1
|
|
|
+ if [ -e "httpd-$NEW_Apache_version.tar.gz" ]; then
|
|
|
+ echo "Download [${CMSG}apache-$NEW_Apache_version.tar.gz${CEND}] successfully! "
|
|
|
+ break
|
|
|
+ else
|
|
|
+ echo "${CWARNING}Apache version does not exist! ${CEND}"
|
|
|
+ fi
|
|
|
+ else
|
|
|
+ echo "${CWARNING}input error! Upgrade Apache version is the same as the old version${CEND}"
|
|
|
+ fi
|
|
|
+ done
|
|
|
+
|
|
|
+ if [ -e "httpd-$NEW_Apache_version.tar.gz" ]; then
|
|
|
+ echo "[${CMSG}httpd-$NEW_Apache_version.tar.gz${CEND}] found"
|
|
|
+ echo "Press Ctrl+c to cancel or Press any key to continue..."
|
|
|
+ char=`get_char`
|
|
|
+ tar xzf httpd-$NEW_Apache_version.tar.gz
|
|
|
+ pushd httpd-$NEW_Apache_version
|
|
|
+ make clean
|
|
|
+ if [ "$Apache_flag" == '24' ]; then
|
|
|
+ /bin/cp -R ../apr-${apr_version} ./srclib/apr
|
|
|
+ /bin/cp -R ../apr-util-${apr_util_version} ./srclib/apr-util
|
|
|
+ LDFLAGS=-ldl LD_LIBRARY_PATH=${openssl_install_dir}/lib ./configure --prefix=${apache_install_dir} --with-mpm=prefork --with-included-apr --enable-headers --enable-deflate --enable-so --enable-dav --enable-rewrite --enable-ssl --with-ssl=${openssl_install_dir} --enable-http2 --with-nghttp2=/usr/local --enable-expires --enable-static-support --enable-suexec --enable-modules=all --enable-mods-shared=all
|
|
|
+ elif [ "$Apache_flag" == '22' ]; then
|
|
|
+ [ "${Ubuntu_version}" == "12" ] && sed -i '@SSL_PROTOCOL_SSLV2@d' modules/ssl/ssl_engine_io.c
|
|
|
+ LDFLAGS=-ldl ./configure --prefix=${apache_install_dir} --with-mpm=prefork --with-included-apr --enable-headers --enable-deflate --enable-so --enable-rewrite --enable-ssl--with-ssl=${openssl_install_dir} --enable-expires --enable-static-support --enable-suexec --enable-modules=all --enable-mods-shared=all
|
|
|
+ fi
|
|
|
+ make -j ${THREAD}
|
|
|
+ if [ -e 'httpd' ]; then
|
|
|
+ [[ -d ${apache_install_dir}.bak && -d ${apache_install_dir} ]] && rm -rf ${apache_install_dir}.bak
|
|
|
+ /etc/init.d/httpd stop
|
|
|
+ /bin/cp -R ${apache_install_dir}{,bak}
|
|
|
+ make install && unset LDFLAGS
|
|
|
+ /etc/init.d/httpd start
|
|
|
+ popd > /dev/null
|
|
|
+ echo "You have ${CMSG}successfully${CEND} upgrade from ${CWARNING}$OLD_Apache_version${CEND} to ${CWARNING}$NEW_Apache_version${CEND}"
|
|
|
+ rm -rf httpd-$NEW_Apache_version apr-${apr_version} apr-util-${apr_util_version}
|
|
|
+ else
|
|
|
+ echo "${CFAILURE}Upgrade Apache failed! ${CEND}"
|
|
|
+ fi
|
|
|
+ fi
|
|
|
+ popd > /dev/null
|
|
|
+}
|