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而使得非常混乱。
[root@host1 ~]# rpm -q apr && yum remove apr -y                        查询apr是否安装,安装了就卸载,是为了防止默认安装了低版本的apr而使得非常混乱。
[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.178linux.com/16118

(0)
上一篇 2016-05-10 14:07
下一篇 2016-05-10 21:09

相关推荐

  • RAID

    RAID:       Redunant ARRAYS OF Inexpensive Disks       廉价磁盘阵列 Independent        Berkeley: A case for Redundent Arrays of Inexpens…

    Linux干货 2016-12-23
  • 浅谈vim使用

    vim常用命令总结 2013年10月12日 ⁄ 综合 ⁄ 共 3264字 ⁄ 字号 小 中 大 ⁄  评论关闭        vim 选择文本,删除,复制,粘贴   文本的选择,对于编辑器来说,是很基本的东西,也经常被用到,总结如下: v    从光标当前位置开始,光标所经过的地…

    Linux干货 2016-08-12
  • iptables基础实战练习

    (1) 放行ssh (端口:22) 1 iptables -A INPUT -d 192.168.42.153 -p tcp –dport 22 -j ACCEPT 2 iptables -A OUTPUT -s 192.168.42.153 -p tcp –sport 22 -j ACCEPT (2)修改默认规则链(关闭所有端口) 1 iptables…

    2017-09-10
  • 从“黑掉Github”学Web安全开发

    Egor Homakov(Twitter: @homakov 个人网站: EgorHomakov.com)是一个Web安全的布道士,他这两天把github给黑了,并给github报了5个安全方面的bug,他在他的这篇blog——《How I hacked Github again》(墙)说明了这5个安全bug以及他把github…

    Linux干货 2016-08-15
  • 马哥教育网络班21期+第2周课程练习

    一、Linux文件管理类命令     1、文件的复制、移动和删除        A、cp  文件的复制          cp命令的用法:    &n…

    Linux干货 2016-06-26
  • linux进程管理及计划任务

    进程管理: 什么是进程?   在Linux系统当中:触法任何一个事件时,系统都会将它定义成为一个进程,并且给予这个进程一个ID,称为PID,同时依据触发这个进程的用户与相关属性关系,给予这个PID一组有效的权限设置。 进程与程序: 程序(program):通常为二进制程序放置在存储媒介中,以物理文件的形式存在。 进程(process):程序被触发后…

    Linux干货 2016-09-13