您的位置:首页 > 运维架构 > Nginx

LNMP平台的搭建

2012-04-02 20:51 465 查看

搭建LNMP平台

——源码编译安装nginx、mysql、php

写在前面的话

LNMP代表的就是:Linux系统下Nginx+MySQL+PHP这种网站服务器架构。
Linux是一类Unix计算机操作系统的统称,是目前最流行的免费操作系统。代表版本有:debian、centos、ubuntu、fedora、gentoo等。
Nginx是一个高性能的HTTP和反向代理服务器,也是一个IMAP/POP3/SMTP代理服务器;是一个小巧而高效的Linux下的Web服务器软件,是由 Igor Sysoev 为俄罗斯访问量第二的 Rambler 站点开发的,已经在一些俄罗斯的大型网站上运行多年,相当的稳定。 。
Mysql是一个小型关系型数据库管理系统。
Php是一种 HTML 内嵌式的语言,是一种在服务器端执行的嵌入HTML文档的脚本语言。
这四种软件均为免费软件,组合到一起,成为一个免费、高效的网站服务系统。

一、安装Nginx-1.0.13

1. 解决依赖关系

Nginx软件的安装依赖gcc编译器、openssl-devel、pcre-devel和zlib-devel,所以安装Nginx之前,先确保系统上已经安装上了这些软件包;若没有安装,则先配好yum源,使用yum命令安装。

#yum install gcc openssl-devel pcre-devel zlib-devel

2. 添加系统组nginx和系统用户nginx

添加系统组和用户nginx的目的是为了确保服务器的安全,以系统用户nginx的身份来运行nginx,因为系统用户nginx在系统中的权限是很低的,所以可避免nginx进程被黑客攻破后获得root权限。
# groupadd -r nginx

# useradd -r -g nginx -s /bin/false -M nginx

3. 编译安装nginx

./configure \

--prefix=/usr \   #指定安装目录

--sbin-path=/usr/sbin/nginx \   #指定nginx相关的可执行的管理类命令的存放目录

--conf-path=/etc/nginx/nginx.conf \  #指定配置文件的存放目录

--error-log-path=/var/log/nginx/error.log \  #指定错误日志文件的存放目录

--http-log-path=/var/log/nginx/access.log \  #指定访问日志文件的存放目录

--pid-path=/var/run/nginx/nginx.pid  \  #指定pid文件的存放目录

--lock-path=/var/lock/nginx.lock \ #指定进程锁文件的存放目录

--user=nginx \  #指定以哪个用户的身份运行

--group=nginx \ #指定以哪个组的身份运行

--with-http_ssl_module \  #指定支持ssl

--with-http_flv_module \ #指定添加上flv模块

--with-http_stub_status_module \ # 支持显示web服务器的运行状态

--with-http_gzip_static_module \ #支持文件压缩传送

--http-client-body-temp-path=/var/tmp/nginx/client/ \ --以下是指定关于一些临时文件的存放位置

--http-proxy-temp-path=/var/tmp/nginx/proxy/ \

--http-fastcgi-temp-path=/var/tmp/nginx/fcgi/ \

--http-uwsgi-temp-path=/var/tmp/nginx/uwsgi \

--http-scgi-temp-path=/var/tmp/nginx/scgi \

--with-pcre   #支持pcre正则表达式


make && make install

4. 提供SysV服务脚本/etc/rc.d/init.d/nginx

内容如下:
#!/bin/sh

#

# nginx - this script starts and stops the nginx daemon

#

# chkconfig:   - 85 15

# description:  Nginx is an HTTP(S) server, HTTP(S) reverse \

#               proxy and IMAP/POP3 proxy server

# processname: nginx

# config:      /etc/nginx/nginx.conf

# config:      /etc/sysconfig/nginx

# pidfile:     /var/run/nginx.pid

# 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/sbin/nginx"

prog=$(basename $nginx)

NGINX_CONF_FILE="/etc/nginx/nginx.conf"

[ -f /etc/sysconfig/nginx ] && . /etc/sysconfig/nginx

lockfile=/var/lock/subsys/nginx

make_dirs() {

# make required directories

user=`nginx -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() {

restart

}

configtest() {

$nginx -t -c $NGINX_CONF_FILE

}

rh_status() {

status $prog

}

rh_status_q() {

rh_status >/dev/null 2>&1

}

case "$1" in

start)

rh_status_q && exit 0

$1

;;

stop)

rh_status_q || exit 0

$1

;;

restart|configtest)

$1

;;

reload)

rh_status_q || exit 7

$1

;;

force-reload)

force_reload

;;

status)

rh_status

;;

condrestart|try-restart)

rh_status_q || exit 0

;;

*)

echo $"Usage: $0 {start|stop|status|restart|condrestart|try-restart|reload|force-reload|configtest}"

exit 2

esac

5. 为脚本添加执行权限

chmod +x  /etc/rc.d/init.d/nginx

6. 添加至服务列表

chkconfig --add nginx

7. 让服务开机启动

chkconfig nginx on

接下来可以启动服务进行测试

二、安装mysql-5.5.20

1、准备数据存放的文件系统

新建一个逻辑卷,并将其挂载至特定目录即可。
这里假设其逻辑卷的挂载目录为/mydata,而后需要创建/mydata/data目录做为mysql数据的存放目录。
#pvcreate /dev/sda5 --这里假设将sda5分区作为物理卷

#vgcreate myvg /dev/sda5

#lvcreate -L 2G -n lv1 myvg --这里假设逻辑卷的大小为2G

2、新建用户以安全方式运行进程

# groupadd -r mysql

# useradd -g mysql -r -s /sbin/nologin -M -d /mydata/data mysql

# chown -R mysql:mysql /mydata/data

3、安装并初始化mysql-5.5.20

首先下载平台对应的mysql版本,这里选择mysql-5.5.19-linux2.6-i686.tar.gz,

# tar xf mysql-5.5.19-linux2.6-i686.tar.gz -C /usr/local

# cd /usr/local/

# ln -sv mysql-5.5.19-linux2.6-i686  mysql

# cd mysql

# chown -R mysql:mysql  .

# scripts/mysql_install_db --user=mysql --datadir=/mydata/data

# chown -R root  .

4、为mysql提供主配置文件

# cd /usr/local/mysql

# cp support-files/my-large.cnf  /etc/my.cnf

并修改此文件中thread_concurrency的值为你的CPU个数乘以2,比如这里使用如下行:

thread_concurrency = 2

另外还需要添加如下行指定mysql数据文件的存放位置:

datadir = /mydata/data

5、为mysql提供sysv服务脚本

# cd /usr/local/mysql

# cp support-files/mysql.server  /etc/rc.d/init.d/mysqld

添加至服务列表
# chkconfig --add mysqld

# chkconfig mysqld on

而后就可以启动服务测试使用了。
为了使用mysql的安装符合系统使用规范,并将其开发组件导出给系统使用,这里还需要进行如下步骤:

6、输出mysql的man手册至man命令的查找路径

编辑/etc/man.config,添加如下行即可:

MANPATH  /usr/local/mysql/man

7、输出mysql的头文件至系统头文件路径/usr/include

这可以通过简单的创建链接实现

# ln -sv /usr/local/mysql/include  /usr/include/mysql

8、输出mysql的库文件给系统库查找路径

# echo '/usr/local/mysql/lib' > /etc/ld.so.conf.d/mysql.conf

而后让系统重新载入系统库:

# ldconfig

9、修改PATH环境变量

让系统可以直接使用mysql的相关命令。

三、安装PHP-5.3.10

1. 解决依赖关系

Php-5.3.10的安装需要依赖以下软件及对应的开发包组;
libevent (nginx是基于event drive,libevent 的API提供了当特定事件发生时应执行的对应的函数);
libiconv (编码转换库);
libmcrypt (双向加密库);
mhash(单向加密算法);
这里用这些软件的rpm包来安装
#rpm -Uvh  libevent-2.0.17-2.i386.rpm \

libevent-devel-2.0.17-2.i386.rpm \

libmcrypt-2.5.7-5.el5.i386.rpm \

libmcrypt-devel-2.5.7-5.el5.i386.rpm\

mcrypt-2.6.8-1.el5.i386.rpm \

mhash-0.9.2-6.el5.i386.rpm \

mhash-devel-0.9.2-6.el5.i386.rpm

2. 编译安装php-5.3.10

首先下载源码包至本地目录
# tar xf php-5.3.10.tar.bz2

# cd php-5.3.10

./configure --prefix=/usr/local/php \

--with-mysql=/usr/local/mysql \

--with-openssl \

--enable-fpm \

--with-mysqli=/usr/local/mysql/bin/mysql_config \

--enable-mbstring \

--with-freetype-dir \

--with-jpeg-dir \

--with-png-dir \

--with-zlib-dir \

--with-libxml-dir=/usr \

--enable-xml \

--with-mhash \

--with-mcrypt \

--with-config-file-path=/etc/php \

--with-config-file-scan-dir=/etc/php \

--with-bz2 --with-curl

【--with-iconv=/usr/local #若前面安装了libconv的话,需加上这一项;】

# make 【ZEND_EXTRA_LIBS='-liconv' 】 #若前面没有安装了libconv的话,则只使用make

# make install

3. 为php提供配置文件

# cp  php.ini-production  /usr/local/php/etc/php.ini

4. 添加php-fpm的服务脚本

# cp sapi/fpm/init.d.php-fpm  /etc/rc.d/init.d/php-fpm

添加php-fpm到服务列表

#chkconfig --add php-fpm

开机启动php-fpm

#chkconfig php-fpm on

5. 启动fastcgi:

# cp /usr/local/php/etc/php-fpm.conf.default /usr/local/php/etc/php-fpm.conf

# vim /usr/local/php/etc/php-fpm.conf --启用如下选项:
pm.max_children = 50

pm.start_servers = 5

pm.min_spare_servers = 2

pm.max_spare_servers = 8

pid = /var/run/php-fpm.pid

接下来整合nginx和php5
编辑/etc/nginx/nginx.conf,启用如下选项:
location ~ \.php$ {

root           html;

fastcgi_pass   127.0.0.1:9000;

fastcgi_index  index.php;

fastcgi_param  SCRIPT_FILENAME  /scripts$fastcgi_script_name;

include        fastcgi_params;

}


6. 编辑FastCGI 的文件

内容如下:

#vim fastcgi_params

fastcgi_param  GATEWAY_INTERFACE  CGI/1.1;

fastcgi_param  SERVER_SOFTWARE    nginx;

fastcgi_param  QUERY_STRING       $query_string;

fastcgi_param  REQUEST_METHOD     $request_method;

fastcgi_param  CONTENT_TYPE       $content_type;

fastcgi_param  CONTENT_LENGTH     $content_length;

fastcgi_param  SCRIPT_FILENAME    $document_root$fastcgi_script_name;

fastcgi_param  SCRIPT_NAME        $fastcgi_script_name;

fastcgi_param  REQUEST_URI        $request_uri;

fastcgi_param  DOCUMENT_URI       $document_uri;

fastcgi_param  DOCUMENT_ROOT      $document_root;

fastcgi_param  SERVER_PROTOCOL    $server_protocol;

fastcgi_param  REMOTE_ADDR        $remote_addr;

fastcgi_param  REMOTE_PORT        $remote_port;

fastcgi_param  SERVER_ADDR        $server_addr;

fastcgi_param  SERVER_PORT        $server_port;

fastcgi_param  SERVER_NAME        $server_name;

7. 在所支持的主页面格式中添加php格式的主页

类似如下:
location / {

root   html;

index  index.php index.html index.htm;

}


而后重启nginx。

# service nginx restart

8. 为FCGI设定缓存,提高服务器的可用性

http {

fastcgi_cache_path /www/cache levels=1:2

keys_zone=fcgicache:10m

inactive=5m;

server {

server_name www.aydon.com;

...

location / {

...

fastcgi_pass 127.0.0.1:9000;

fastcgi_cache fcgicache;

fastcgi_cache_valid 200 302 1h;

fastcgi_cache_valid 301 1d;

fastcgi_cache_valid any 1m;

fastcgi_cache_min_uses 1;

fastcgi_cache_use_stale error timeout invalid_header http_500;

}

}

}

到此LNMP平台的安装和一些基本配置工作已经完成了,接下来便可以测试LNMP平台是否能正常工作。
内容来自用户分享和网络整理,不保证内容的准确性,如有侵权内容,可联系管理员处理 点击这里给我发消息
标签:  PHP MySQL RedHat Nginx LNMP