CentOS 下 LNMP 搭建
1. 准备工作
1.1 软件包
1. CentOS-5.4-final
2. nginx-1.4.2.tar.gz
3. php-5.4.19.tar.gz
4. mysql-5.5.14.tar.gz
5. cmake-2.8.8.tar.gz
6. libmcrypt-2.5.8.tar.gz
1.2 其他工具
1. WinSCP:用于与 Cent 之间方便的传输文件。
2. SecureCRT:提供一种方便的终端操作,避免直接在虚拟机终端操作带来的不便。
2. 编译安装
本文是在已安装 CentOS 的前提下进行的,未安装 Cent 请先安装。
2.1 安装 Nginx
2.1.1 依赖包安装
安装 lnmp 的过程中,需要比较多的依赖包,因此先安装这些依赖包,避免之后安装
报错。使用 yum 命令,安装一些常用的依赖包。
1) yum -y install gcc gcc-c++ autoconf libjpeg libjpeg-devel libpng libpng-devel freetype
freetype-devel libxml2 libxml2-devel zlib zlib-devel glibc glibc-devel glib2 glib2-devel
bzip2 bzip2-devel ncurses ncurses-devel curl curl-devel e2fsprogs e2fsprogs-devel krb5
krb5-devel libidn libidn-devel openssl openssl-devel openldap openldap-devel nss_ldap
openldap-clients openldap-servers
2) yum -y install ntp vim-enhanced gcc gcc-c++ gcc-g77 flex bison autoconf automake glibc
glibc-devel glib2 glib2-devel bzip2 bzip2-devel ncurses ncurses-devel libtool* zlib-devel
libxml2-devel libjpeg-devel libpng-devel libtiff-devel fontconfig-devel freetype-devel
libXpm-devel gettext-devel curl curl-devel pam-devel e2fsprogs-devel krb5-devel libidn
libidn-devel openssl openssl-devel openldap openldap-devel nss_ldap openldap-clients
openldap-servers gzip
3) yum install make apr* autoconf automake curl curl-devel gcc gcc-c++ zlib-devel openssl
openssl-devel pcre-devel gd kernel keyutils patch perl kernel-headers compat* mpfr cpp
glibc libgomp libstdc++-devel ppl cloog-ppl keyutils-libs-devel libcom_err-devel libsepol-
devel libselinux-devel krb5-devel zlib-devel libXpm* freetype libjpeg* libpng* php-common
php-gd ncurses* libtool* libxml2 libxml2-devel patch
这些依赖包有重复的,重复安装只会更新或不操作。安装好这些依赖包后,就可正式
进行 nginx 的安装了。
2.1.2 nginx 安装
本文是将 1.1 中的所有软件包放在/home/klaus 目录下。首先 cd /home/klaus 进入
目标目录,以下是具体操作步骤。另外,所有操作都是以 root 用户进行的。
为 nginx 创建执行的用户及组,本文创建 www 用户及 www 组。
groupadd www #创建 www 用户
useradd –g www www –s /sbin/nologin #创建无法登录的 www 用户,属于 www 组。
tar xf nginx-1.4.2.tar.gz #解压 nginx 包
cd nginx-1.4.2 #进入解压后的 nginx 目录,执行以下命令:
[root@localhost nginx-1.4.2] ./configure \
--prefix=/usr/local/nginx \ #ngix 安装目录
--pid-path= /var/nginx/nginx.pid \ #nginx pid 存放目录,可以查看当前 nginx 服务的 pid
--lock-path=/var/nginx/nginx.lock \ #锁文件存放路径
--with-http_gzip_static_module \ #开启 gzip 静态压缩模块
--http-client-body-temp-path=/var/nginx/client/ \ #客户端请求缓存目录
--http-proxy-temp-path=/var/nginx/proxy/ \ #代理缓存目录
--http-fastcgi-temp-path=/var/nginx/fcgi/ \ #fcgi 缓存目录
--with-http_stub_status_module \ #启用状态检测模块
--error-log-path=/var/nginx/error.log \ #nginx 错误存放目录
--http-log-path=/var/nginx/access.log \ #访问记录存放目录
--with-http_ssl_module \ #开启 SSL 加密模块
--with-http_flv_module \ #开启支持 flv 流媒体模块
--user=www \ #指定运行 nginx 用户
--group=www #指定运行 nginx 组
编译如果没有出错,执行 make && make install 进行实际安装。
安装完成后,创建对应脚本以使 nginx 开机启动。
vi /etc/init.d/nginxd #创建脚本
输入以下内容:
#!/bin/sh
#
# nginx - this script starts and stops the nginx daemon
#
# description: Nginx is an HTTP(S) server, HTTP(S) reverse \
# proxy and IMAP/POP3 proxy server
# processname: nginx
# Source function library.
. /etc/rc.d/init.d/functions
# Source networking configuration.
. /etc/sysconfig/network
# Check that networking is up.
[ "$NETWORKING" = "no" ] && exit 0
nginx="/usr/local/nginx/sbin/nginx"
prog=$(basename $nginx)
NGINX_CONF_FILE="/usr/local/nginx/conf/nginx.conf"
[ -f /etc/sysconfig/nginx ] && . /etc/sysconfig/nginx
lockfile=/var/lock/subsys/nginx
make_dirs() {
# make required directories,此处注意将用户替换创建的用户
user=`www -V 2 > &1 | grep "configure arguments:" | sed 's/[^*]*--user=\([^ ]*\).*/\1/g' -`
options=`$nginx -V 2 > &1 | grep 'configure arguments:'`
for opt in $options; do
if [ `echo $opt | grep '.*-temp-path'` ]; then
value=`echo $opt | cut -d "=" -f 2`
if [ ! -d "$value" ]; then
# echo "creating" $value
mkdir -p $value && chown -R $user $value
fi
fi
done
}
start() {
[ -x $nginx ] || exit 5
[ -f $NGINX_CONF_FILE ] || exit 6
make_dirs
echo -n $"Starting $prog: "
daemon $nginx -c $NGINX_CONF_FILE
retval=$?
echo
[ $retval -eq 0 ] && touch $lockfile
return $retval
}
stop() {
echo -n $"Stopping $prog: "
killproc $prog -QUIT
retval=$?
echo
[ $retval -eq 0 ] && rm -f $lockfile
return $retval
}
restart() {
configtest || return $?
stop
sleep 1
start
}
reload() {
configtest || return $?
echo -n $"Reloading $prog: "
killproc $nginx -HUP
RETVAL=$?
echo
}
force_reload() {