LAMP架構實驗1

LAMP架構實驗

— 基礎架構搭建


  • 實驗實驗拓撲圖與目的

  • 實驗過程

  • 總結與問題


實驗實驗拓撲圖與目的

blob.png

1. 實驗主框架LAMP采用編譯安裝。
2. 分離HTTPD,PHP,MARIADB。
3. 兩臺服務器能夠各自被訪問且內容相同。

實驗過程

程序包準備:

apr-1.5.2.tar.gz                aprapache的運行庫,提供了軟件允許所需要的庫文件。
apr-util-1.5.4.tar.gz            可以理解為apr的擴展,支持更加多的數據接口與封裝接口。
httpd-2.4.20.tar.bz2              http程序,2.4支持了眾多新特性,最為主要的是event模型。
mariadb-5.6.20.tar.gz              完全開源的關系型數據庫,是mysql的一個分支。
php-5.6.20.tar.gz                  php程序,負責解析動態請求。
xcache-3.2.0.tar.gz                PHP的加速器程序,能夠通過緩存來加速PHP。

phpMyAdmin-4.6.0-all-languages.zip   圖形化數據庫管理工具,基于PHP開發,可選。
wordpress-4.5.zip                  基于PHP開發的開源的blog平臺,可選。
Discuz_X3.1_SC_GBK.zip          基于PHP開發的論壇,可選。

軟件:

[開發包組]
Development Tools    開發工具包

[apache]
pcre-devel            pcre正則表達式支持庫
openssl-devel        openssl開發包

[PHP]
libxml2-devel        xml的開發包
bzip2-devel            bzip2的開發包
libmcrypt-devel        加密擴展開發包
mhash-devel            mhash加密開發包

配置文件表:

blob.png

Web Server 1 (192.168.1.1)

編譯安裝:
[root@host1 ~]# yum groupinstall "Development Tools" -y                安裝依賴的包組“Development Tools”
[root@host1 ~]# yum install pcre-devel openssl-devel -y                安裝正則表達式的開發包pcre-devel 與 openssl的開發包openssl-devel
[root@host1 ~]# rpm -q apr-util && yum remove apr-util -y            查詢apr-util是否安裝,安裝了就卸載,是為了防止默認安裝了低版本的apr而使得非?;靵y。
[root@host1 ~]# rpm -q apr && yum remove apr -y                        查詢apr是否安裝,安裝了就卸載,是為了防止默認安裝了低版本的apr而使得非?;靵y。
[root@host1 ~]# rpm -q httpd && yum remove httpd -y                    查看httpd是否安裝,安裝了就卸載,是為了防止默認安裝了低版本的httpd。

[root@host1 ~]# useradd -s /sbin/nologin -r apache                     創建系統用戶并不能登陸,創建用戶時會自動創建相同名稱的組。    

[root@host1 source]# cd source/                                        cd到存放源碼的目錄。
[root@host1 source]# tar xf source/apr-1.5.2.tar.gz                      解壓apr
[root@host1 source]# tar xf source/apr-util-1.5.4.tar.gz            解壓apr-util
[root@host1 source]# tar xf source/httpd-2.4.20.tar.bz2                解壓httpd

[root@host1 source]# cd apr-1.5.2                                    cd到apr-1.5.2的目錄。
[root@host1 apr-1.5.2]# ./configure --prefix=/usr/local/apr            編譯安裝的環境檢查,生成編譯安裝配置清單文件,并制定程序存放位置。
[root@host1 apr-1.5.2]# make && make install                        編譯以及復制文件。

[root@host1 apr-1.5.2]# cd ../apr-util-1.5.4                        cd到apr-util目錄
[root@host1 apr-util-1.5.4]# ./configure --prefix=/usr/local/apr-util --with-apr=/usr/local/apr        檢查環境,生成編譯安裝配置清單文件,指定程序存放位置以及apr的安裝位置。
[root@host1 apr-util-1.5.4]# make && make install                    編譯以及復制文件。

[root@host1 apr-util-1.5.4]# cd ../httpd-2.4.20                    cd到httpd-2.4.20的目錄。
[root@host1 httpd-2.4.20]# ./configure \                        檢查環境,生成編譯安裝配置清單文件。
> --prefix=/web/apache \                                        指定程序存放位置。
> --sysconfdir=/etc/httpd \                                     指定配置文件存放位置。
> --enable-so \                                                 啟用共享對象
> --enable-ssl \                                                啟用ssl
> --enable-cgi \                                                啟用cgi
> --enable-rewrite \                                            啟用rewrite重寫
> --with-zlib \                                                 啟用zlib庫
> --with-pcre \                                                 啟用pcre正則
> --with-apr=/usr/local/apr \                                   指定apr位置
> --with-apr-util=/usr/local/apr-util \                         指定apr-util位置
> --enable-modules=most \                                       啟用大部分模塊
> --enable-mpms-shared=all \                                    啟用所有的MPM模型,prefork worker event
> --with-mpm=event                                              默認啟用event模型
[root@host1 source]# make && make install                       編譯以及復制文件。

[root@host1 source]# cd ~
[root@host1 ~]# echo "export PATH=/web/apache/bin:$PATH" > /etc/profile.d/httpd.sh   寫入二進制可執行文件路徑至$PATH變量。
[root@host1 ~]# ln -s /web/apache/include /usr/include/httpd                             在/usr/include中創建鏈接指向httpd的頭文件
[root@host1 ~]# echo "PidFile  \"/var/run/httpd.pid\"" >> /etc/httpd/httpd.conf\     將PID的路徑寫入httpd的配置文件
[root@host1 ~]# echo "MANPATH /web/apache/man" >> /etc/man.config                     將httpd的man文件路徑寫入man的配置文件。
[root@host1 ~]# vim /etc/rc.d/init.d/httpd                創建啟動腳本,并修改一下主要變量的參數的值,腳本在本文最后提供。
....
apachectl=/web/apache/bin/apachectl                        
httpd=${HTTPD-/web/apache/bin/httpd}
prog=httpd
pidfile=${PIDFILE-/var/run/httpd.pid}
lockfile=${LOCKFILE-/var/lock/subsys/httpd}
....
[root@host1 ~]# chmod +x /etc/rc.d/init.d/httpd                    給予啟動腳本執行權限。
[root@host1 ~]# chkconfig --add httpd                            將httpd添加進開機啟動。
[root@host1 ~]# chkconfig --level 3 httpd on                        將httpd設置為在level 3都啟動。
[root@host1 ~]# service httpd start                                腳本啟動httpd。
文件配置:
[root@host1 ~]# vim /etc/httpd/httpd.conf                        配置httpd.conf
LoadModule proxy_module modules/mod_proxy.so                    啟用代理模塊。
LoadModule proxy_fcgi_module modules/mod_proxy_fcgi.so            啟用基于fcgi的傳輸模塊。
User apache                                                        指定子進程的屬主。
Group apache                                                    指定子進程的屬組。
Include /etc/httpd/extra/httpd-vhosts.conf                        開啟此項會自動去讀hyyp-vhosts.conf這個配置文件。
AddType application/x-httpd-php  .php                            增加類型識別PHP。
AddType application/x-httpd-php-source  .phps                    增加類型識別PHPS。

[root@host1 ~]# vim /etc/httpd/extra/httpd-vhosts.conf            編輯httpd-vhost.conf
<Virtualhost *:80>                                                增加一個虛擬主機。
       documentroot "/web/data"                                此主機的根目錄。
       servername www.xiao.com                                    此主機的服務器名稱即域名。
       errorlog "/web/log/error.log"                            錯誤日志存放位置。
       customlog "/web/log/access.log" common                    訪問日志存放位置已經格式指定為common這個內置配置。

       proxyrequests off                                                        關閉正想代理。
       ProxyPassMatch ^/(.*\.php)$ fcgi://192.168.1.3:9000/web/data/$1            將.PHP結尾的文件的請求都通過fcgi轉向192.168.1.3:9000/web/data去。

       <directory "/web/data">                                    此虛擬主機目錄/web/data的屬性。
               options none                                    目錄選項為none。
               DirectoryIndex index.php index.html                默認的主頁文件為index.php 次之為index.html
               allowoverride none                                目錄配置檢查為none。
               require all granted                                允許多有主機訪問,沒有做訪問控制。
       </directory>
</Virtualhost>
[root@host1 ~]# mkdir -pv /web/{data,log}                        創建日志文件存放目錄。
[root@host1 ~]# service httpd reload                            重載配置文件。
網頁部署:
[root@host1 ~]# cd source/
[root@host1 source]# cp Discuz_X3.2_SC_UTF8.zip /web/data        
[root@host1 data]# unzip Discuz_X3.2_SC_UTF8.zip
[root@host1 data]# chown -R apache:apache .
注:需要在fastcgi指定的PHP服務器中的路徑下擁有相同的文件才可通過http訪問192.168.1.1來調用PHP服務器,也就是說此處服務器只是存放一個對應的文件用來映射訪問,真正的操作在PHP服務器上執行。

Web Server 2 (192.168.1.2)

編譯安裝:
編譯安裝過程與web sever1相同
文件配置:
[root@host2 ~]# vim /etc/httpd/httpd.conf                        與web1基本一致,就不做解釋了。
LoadModule proxy_module modules/mod_proxy.so
LoadModule proxy_fcgi_module modules/mod_proxy_fcgi.so
User apache
Group apache
Include /etc/httpd/extra/httpd-vhosts.conf
AddType application/x-httpd-php  .php
AddType application/x-httpd-php-source  .phps

[root@host2 ~]# vim /etc/httpd/extra/httpd-vhosts.conf
<Virtualhost *:80>
       documentroot "/web/data"
       servername www.xiao.com
       errorlog "/web/log/error.log"
       customlog "/web/log/access.log" common

       proxyrequests off
       ProxyPassMatch ^/(.*\.php)$ fcgi://192.168.1.3:9000/web/data/$1

       <directory "/web/data">
               options none
               DirectoryIndex index.php index.html
               allowoverride none
               require all granted
       </directory>
</Virtualhost>
[root@host2 ~]# mkdir -pv /web/{data,log}
[root@host2 ~]# service httpd restart
網頁部署:
[root@host2 ~]# cd source/
[root@host2 source]# cp Discuz_X3.2_SC_UTF8.zip /web/data
[root@host2 data]# unzip Discuz_X3.2_SC_UTF8.zip
[root@host2 data]# chown -R apache:apache .
注:需要在fastcgi指定的PHP服務器中的路徑下擁有相同的文件才可通過http訪問192.168.1.2來調用PHP服務器,也就是說此處服務器只是存放一個對應的文件用來映射訪問,真正的操作在PHP服務器上執行。

php server (192.168.1.3)

編譯安裝:
[root@host3 ~]# yum groupinstall "Development Tools" -y            安裝依賴包組。
[root@host3 ~]# yum install "libxml2-devel" "bzip2-devel" "libmcrypt-devel" "mhash-devel" -y         安裝依賴的包。

[root@host3 ~]# useradd -s /sbin/nologin -r php                    創建php程序的屬主。

[root@host3 ~]# cd source/                                            
[root@host3 source]# tar xf php-5.6.20.tar.gz                    解壓php源碼包
[root@host3 source]# cd php-5.6.20                                CD進php-5.6.20目錄
[root@host3 php-5.6.20]# ./configure \                            檢查環境,生成編譯安裝配置清單文件。
--prefix=/usr/local/php \                                        指定php程序安裝位置。
--with-mysql=mysqlnd \                                            指定mysql為mysqlnd驅動,mysqlnd是新版的mysql的驅動。
--with-openssl \                                                啟用openssl
--with-mysqli=mysqlnd \                                            指定mysqli為mysqlnd驅動,mysqli為php-mysql的進階擴展。
--enable-mbstring \                                                支持Multi-Byte String ,編碼庫。
--with-freetype-dir \                                            啟用freetype字體引擎。    
--with-jpeg-dir \                                                啟用支持jpeg格式的圖片。
--with-png-dir \                                                啟用支持png格式的圖片。
--with-zlib \                                                    啟用支持zlib數據壓縮。
--with-libxml-dir=/usr \                                        啟用xml的支持庫,支持xml格式的文件
--enable-xml  \                                                    啟用xml功能。
--enable-sockets \                                                啟用套接字。
--enable-fpm \                                                    啟用fpm,fastcgi管理器。
--with-mcrypt  \                                                啟用加密擴展庫mcrypt。
--with-config-file-path=/etc \                                    指定配置文件php.ini路徑。
--with-config-file-scan-dir=/etc/php.d \                        指定配置文件目錄,php.d
--with-bz2
[root@host3 php-5.6.20]# make && make install                編譯安裝,復制文件

[root@host3 php-5.6.20]# cp php.ini-production /etc/php.ini            復制的配置文件php.ini。
[root@host3 php-5.6.20]# cp lamp/php-5.6.20/sapi/fpm/init.d.php-fpm /etc/rc.d/init.d/php-fpm        復制php-fpm的啟動腳本。
[root@host3 php-5.6.20]# chmod +x /etc/rc.d/init.d/php-fpm            給予啟動腳本執行權限。
[root@host3 php-5.6.20]# echo "export PATH=/usr/local/php/bin:/usr/local/php/sbin:$PATH" > /etc/profile.d/php.sh    指定二進制可執行文件。
[root@host3 php-5.6.20]# echo "/usr/local/php/lib" > /etc/ld.so.conf.d/php.conf     寫入庫文件。
[root@host3 php-5.6.20]# ln -sv /usr/local/php/include /usr/include/php        寫入頭文件。
[root@host3 php-5.6.20]# echo "MANPATH /usr/local/php/man" >> /etc/man.config    寫入man文件。
[root@host3 php-5.6.20]# cp etc/php-fpm.conf.default etc/php-fpm.conf    復制php-fpm的配置文件。
[root@host3 php-5.6.20]# vim etc/php-fpm.conf        編輯php-fpm.conf
pid = /usr/local/php/var/run/php-fpm.pid            PID路徑
user = php                進程屬主
group = php                進程屬組
listen = 192.168.1.3:9000                監聽的IP,端口。
pm = dynamic                            指定進程管理方式為dynamic,動態調整。也可設置為靜態static。
pm.max_children = 50                    允許的最大的php-fpm子進程數。
pm.start_servers = 5                    動態模式下,PHP啟動時的php-fpm進程數。
pm.min_spare_servers = 2                動態模式下服務器空閑時最小的php-fpm進程數。
pm.max_spare_servers = 8                動態模式下服務器空閑時最大的php-fpm進程數。
[root@host3 php-5.6.20]# chkconfig --add php-fpm        加入開機自啟。
[root@host3 php-5.6.20]# chkconfig --level 3 php-fpm on        在level 3下開機自啟動。

[root@host3 php-5.6.20]# service php-fpm start    腳本啟動。
xcache加速PHP:
[root@host3 source]# tar xf xcache-3.2.0.tar.gz
[root@host3 source]# cd xcache-3.2.0
[root@host3 xcache-3.2.0]# /usr/local/php/bin/phpize        啟用php的環境檢查,通過后生成xcache的configure文件
[root@host3 xcache-3.2.0]# ./configure --enable-xcache --with-php-config=/usr/local/php/bin/php-config        檢查環境,生成編譯安裝配置清單文件,開啟xcache,指定php-config的位置,php-config存放了php的配置信息。
[root@host3 xcache-3.2.0]# make && make install

[root@host3 xcache-3.2.0]# mkdir /etc/php.d
[root@host3 xcache-3.2.0]# cp xcache.ini /etc/php.d        復制xcache.ini到php.d目錄下。
[root@host3 xcache-3.2.0]# vim /etc/php.d/xcache.ini        配置xcache.ini
extension = /usr/local/php5/lib/php/extensions/no-debug-non-zts-20131226/xcache.so        指定共享對象位置。
網頁部署:
[root@host3 ~]# mkdir -pv /web/data
[root@host3 ~]# cd source/
[root@host3 source]# cp Discuz_X3.2_SC_UTF8.zip /web/data
[root@host3 data]# unzip Discuz_X3.2_SC_UTF8.zip
[root@host3 data]# chown -R php:php .
注:此處的網頁文件才是用戶通過httpd訪問到的網頁文件,也就是說用戶在訪問192.168.1.1時訪問的網頁是位于192.168.1.3上的。

DBserver (192.168.1.4)

二進制文件安裝:
[root@host4 ~]# useradd -s /sbin/nologin -r mysql            創建系統用戶musql,不允許登陸。

[root@host4 ~]# cd source/        
[root@host4 source]# tar xf mariadb-5.5.48-linux-x86_64.tar.gz -C /usr/local/        解壓源碼文件并且解壓至指定目錄。
[root@host4 source]# cd /usr/local                
[root@host4 local]# ln -sv mariadb-5.5.48-linux-x86_64 mysql        連接目錄為mysql目錄
[root@host4 local]# cd mysql            
[root@host4 mysql]# chown -R mysql:mysql .        將mysql目錄下的文件遞歸的屬主屬組都改為mysql
[root@host4 mysql]# bash scripts/mysql_install_db --user=mysql --datadir=/mysql/data      執行安裝腳本并且指定進程用戶與數據存放路徑。
[root@host4 mysql]# chown -R root .        更改屬主為root
[root@host4 mysql]# cp support-files/my-large.cnf /etc/my.cnf        復制mysql的配置文件
[root@host4 mysql]# vim /etc/my.cnf        配置my.cnf
thread_concurrency = 4                    內核數量*2,指定內部并發數量,決定性能。
datadir= /mysql/data                    指定數據存放位置。
[root@host4 mysql]# echo "export PATH=/usr/local/mysql/bin:$PATH" > /etc/profile.d/mysql.sh        寫入二進制文件路徑。
[root@host4 mysql]# echo "/usr/local/mysql/lib" > /etc/ld.so.conf.d/mysql.conf                    寫入庫文件。
[root@host4 mysql]# ln -sv /usr/local/mysql/include /usr/include/mysql                            寫入頭文件。
[root@host4 mysql]# echo "MANPATH /usr/local/mysql/man" >> /etc/man.config                        寫入man文件。
[root@host4 mysql]# cp support-files/mysql.server /etc/rc.d/init.d/mysqld                        復制腳本啟動文件至指定目錄。
[root@host4 mysql]#    chmod +x /etc/rc.d/init.d/mysqld                        執行權限給腳本啟動文件。

[root@host4 mysql]# chkconfig --add mysqld        添加進開機自啟。
[root@host4 mysql]# chkconfig --level mysqld on   啟用開機自啟。

[root@host4 mysql]# service mysqld start   啟動mysql
網頁部署:
[root@host4 ~]# mysql
MariaDB [(none)]> create database dz ;
MariaDB [(none)]> use dz ;
MariaDB [dz]> create table ;
MariaDB [dz]> grant all on dz.* to dzadmin@'192.168.1.3' identified by 'redhat' ;
MariaDB [dz]> flush privileges ;
MariaDB [dz]> exit

總結與問題

總結

  1. LAMP架構的實驗拖了好多天才動手,結果現在進度到nginx了才開始動手實驗,實驗過程中,編譯安裝就是不斷出錯與解決的問題,遇到出錯一般都是軟件沒有安裝。

  2. 在編譯安裝前,一定要檢查是不是已經默認安裝過了程序,不然會非常亂,比如在這次試驗中,因為本機已經默認安裝了httpd-2.2與apr-1.3.9,apr-util-1.3.X ,所以導致在start httpd的時候啟動了2.2的版本,通過rpm -qi才知道。

  3. 在編譯安裝完成后,要完成收尾工作,比如配置文件,鏈接庫,鏈接二進制文件,鏈接include文件,加啟動腳本等。

  4. 最后的網頁部署沒有仔細列出步驟,但大致以寫出,可以通過google等方式自行查詢,這里選擇使用的php網頁為discuz! 根據喜好也可選擇其他如word press等。

  5. 此次架構實驗為第一步的初步搭建LAMP的基本架構,后續會在學習的基礎上進一步迭代添加如日志服務器,DNS服務器,負載均衡服務器,代理服務器等。

  6. 由于本次實驗PHP是基于FASTCGI來將PHP服務器獨立出來的,所以所有網頁文件都需要在每一個服務器上存放一份,會非常麻煩,解決方案就是NFS,留在下一次實驗來補充完善。

問題

  1. HTTPD搭建完成后無法啟動,檢查配置文件,發現PID沒有指定路徑,加上即解決。

  2. 數據庫無法在其他服務器上遠程訪問,因為用戶權限沒有賦予指定主機 如 admin@’IPADDR’ 。

  3. DISCUZ!在安裝完成后,訪問主頁時CSS錯誤的問題,是因為采用了FASTCUGI分離了PHP,所以導致生成的緩存的CSS數據只存在在PHP服務器上,而靜態數據是要存放在前段的web服務器上的,所以就使得用戶訪問時,web服務器是找不到緩存中的CSS文件的,解決方法,將遠程主機上的CSS緩存文件復制并存放到web服務器的對應目錄下。

  4. 發現遠程無法訪問的情況,請檢查你的selinux與iptables,iptables的具體配置問題會在后續的文章中再來完善。


httpd自動部署腳本(不夠完善,漏洞超級多,而且適用環境非常小,只是為了偷懶順手寫的,僅供參考!)

需要將所有的包都存放在/root/source目錄下,且請自行修改對應的包名,或者也可以和我使用相同版本的所有包?。?!
程序包列表:
apr-1.5.2.tar.gz
apr-util-1.5.4.tar.gz
httpd-2.4.20.tar.bz2

-------------------------------------------------------------------------

腳本代碼:

dir=/root/source/

function env() {
yum groupinstall "Development Tools" -y
yum install pcre-devel openssl-devel -y
rpm -q apr-util && yum remove apr-util -y
rpm -q apr && yum remove apr -y
rpm -q httpd && yum remove httpd -y
}

function apr() {
cd ${dir}
tar xf  ${dir}apr-1.5.2.tar.gz
tar xf ${dir}apr-util-1.5.4.tar.gz
cd ${dir}apr-1.5.2
./configure --prefix=/usr/local/apr
make && make install
cd ${dir}apr-util-1.5.4
./configure --prefix=/usr/local/apr-util --with-apr=/usr/local/apr
make && make install
}

function http() {
[ -e "/web" ] ||  mkdir -pv /web
cd ${dir}
tar xf ${dir}httpd-2.4.20.tar.bz2
cd ${dir}httpd-2.4.20
./configure --prefix=/web/apache --sysconfdir=/etc/httpd --enable-so --enable-ssl --enable-cgi --enable-rewrite --with-zlib --with-pcre --with-apr=/usr/local/apr --with-apr-util=/usr/local/apr-util --enable-modules=most --enable-mpms-shared=all --with-mpm=event
make && make install
touch /etc/profile.d/httpd.sh
echo "PATH=/web/apache/bin:$PATH" > /etc/profile.d/httpd.sh
ln -s /web/apache/include /usr/include/httpd
echo "PidFile  \"/var/run/httpd.pid\"" >> /etc/httpd/httpd.conf
cd /etc/rc.d/init.d
wget ftp://139.129.54.50/httpd
chmod +x /etc/rc.d/init.d/httpd
chkconfig --add httpd
chkconfig httpd on
}

env
apr
http
service httpd start
ss -tnl | grep "80" && echo "httpd started"

httpd啟動腳本(centos6)

#!/bin/bash
#
# httpd        Startup script for the Apache HTTP Server
#
# chkconfig: - 85 15
# description: Apache is a World Wide Web server.  It is used to serve \
#        HTML files and CGI.
# processname: httpd
# config: /etc/httpd/conf/httpd.conf
# config: /etc/sysconfig/httpd
# pidfile: /var/run/httpd.pid

# Source function library.
. /etc/rc.d/init.d/functions

if [ -f /etc/sysconfig/httpd ]; then
       . /etc/sysconfig/httpd
fi

# Start httpd in the C locale by default.
HTTPD_LANG=${HTTPD_LANG-"C"}

# This will prevent initlog from swallowing up a pass-phrase prompt if
# mod_ssl needs a pass-phrase from the user.
INITLOG_ARGS=""

# Set HTTPD=/usr/sbin/httpd.worker in /etc/sysconfig/httpd to use a server
# with the thread-based "worker" MPM; BE WARNED that some modules may not
# work correctly with a thread-based MPM; notably PHP will refuse to start.

# Path to the apachectl script, server binary, and short-form for messages.
apachectl=/web/apache/bin/apachectl
httpd=${HTTPD-/web/apache/bin/httpd}
prog=httpd
pidfile=${PIDFILE-/var/run/httpd.pid}
lockfile=${LOCKFILE-/var/lock/subsys/httpd}
RETVAL=0

start() {
       echo -n $"Starting $prog: "
       LANG=$HTTPD_LANG daemon --pidfile=${pidfile} $httpd $OPTIONS
       RETVAL=$?
       echo
       [ $RETVAL = 0 ] && touch ${lockfile}
       return $RETVAL
}

stop() {
 echo -n $"Stopping $prog: "
 killproc -p ${pidfile} -d 10 $httpd
 RETVAL=$?
 echo
 [ $RETVAL = 0 ] && rm -f ${lockfile} ${pidfile}
}
reload() {
   echo -n $"Reloading $prog: "
   if ! LANG=$HTTPD_LANG $httpd $OPTIONS -t >&/dev/null; then
       RETVAL=$?
       echo $"not reloading due to configuration syntax error"
       failure $"not reloading $httpd due to configuration syntax error"
   else
       killproc -p ${pidfile} $httpd -HUP
       RETVAL=$?
   fi
   echo
}

# See how we were called.
case "$1" in
 start)
 start
 ;;
 stop)
 stop
 ;;
 status)
       status -p ${pidfile} $httpd
 RETVAL=$?
 ;;
 restart)
 stop
 start
 ;;
 condrestart)
 if [ -f ${pidfile} ] ; then
   stop
   start
 fi
 ;;
 reload)
       reload
 ;;
 graceful|help|configtest|fullstatus)
 $apachectl $@
 RETVAL=$?
 ;;
 *)
 echo $"Usage: $prog {start|stop|restart|condrestart|reload|status|fullstatus|graceful|help|configtest}"
 exit 1
esac

exit $RETVAL

原創文章,作者:Net18_肖肖,如若轉載,請注明出處:http://www.www58058.com/16118

(0)
Net18_肖肖Net18_肖肖
上一篇 2016-05-10
下一篇 2016-05-10

相關推薦

  • linux之netfilter與 iptables學習

    Linux之netfilter與iptables學習 一、為什么我們的主機需要防火墻 二、Linux下防火墻如何實現 三、四表五鏈學習 四、主機防火墻 五、網絡防火墻 六、iptables命令學習 七、主機防火墻規則備份與恢復 ====================================== 一、為什么我們的主機需要防火墻?  &nbs…

    Linux干貨 2016-06-23
  • Linux系統下的翻譯神器——Goldendict

    Linux系統下的翻譯神器——Goldendict 學習Linux時明顯感受到學習英文的重要性。絕大多數Linux的發行版英文版的功能要遠強于中文。因此一款好的翻譯軟件是了解熟悉Linux系統的必需品。在Windows系統下有各種好用的詞典程序,包括有道詞典、bing詞典、金山詞霸等等,而這些軟件都不能在linux下使用,即使能夠使用也只是測試版,功能太少。…

    Linux干貨 2017-04-24
  • 文件權限管理

    文件權限               [root@CentOS6 ~]# ll 3.txt            &nb…

    Linux干貨 2016-08-04
  • 特殊權限

    特殊權限 文件特殊權限 一、SUID(4) SUID:當s這個標志出現在文件所有者的x權限上時,就被稱作SUID。 SUID的功能和限制:1、僅僅對二進制程序有效; 2、執行者對程序需要X的執行權限; 3、本權限僅僅在執行該程序的過程中有效; 4、執行者將具有該程序所有者的權限。 5、SUID僅僅可以用在二進制程序上,…

    Linux干貨 2016-08-05
  • GlusterFS測試報告-01

    一、GlusterFS基礎環境的介紹 1、關于GlusterFS文件系統和架構的介紹 http://jingyan.baidu.com/article/046a7b3ef65250f9c27fa9d9.html 2、實驗的目的 a. 利用多臺性能較低并且老舊的服務器,實現企業的云盤功能 b. GlusterFS服務端和客戶端的部署和配置 c. 實現Glust…

    Linux干貨 2016-07-22
  • CentOS 6的開機流程及root密碼破解

    一、CentOS 6的開機流程詳解 啟動流程詳解 1、POST:    Power-On-Self-Test,加電自檢,是BIOS功能的一個主要部分。負責完成對CPU、主板、內存、硬盤子系統、顯示子系統、串并行接口、鍵盤、CD-ROM光驅等硬件情況的檢測。 2、BootSequence(BIOS):    決定那個磁盤…

    Linux干貨 2016-09-13
欧美性久久久久