Nginx 是一个轻量级,以占用系统资源少,运行效率而成为web服务器的后起之秀,国内现在很多大型网站都以使用nginx,包括腾讯、新浪等大型信息网站,还有淘宝网站使用的是nginx二次开发的web服务器。
直接php+mysql这是Linux web服务器的黄金组合。今天我们一来学如何在ubuntu 12.04 中架设lnmp。
1. 使用官方PPA安装 Nginx 最新版本,使用以下命令:
sudo add-apt-repository ppa:nginx/stable
sudo apt-get update
sudo apt-get install nginx
Nginx相关控制命令:
启动 Nginx:
sudo /etc/init.d/nginx start
浏览器浏览运行情况输入:http://localhost ; 如果现实”Welcome to nginx!”,表明你的 Nginx 服务器安装成功!
关闭 Nginx:sudo /etc/init.d/nginx stop;
重启 nginx:sudo /etc/init.d/nginx restart;
2. 安装 PHP,输入以下命令:
sudo apt-get install php5-cli php5-cgi php5-fpm php5-mcrypt php5-mysql spawn-fcgi
配置Nginx站点,设置:
sudo vi /etc/nginx/sites-available/default
修改 “index” 为:“index index.html index.htm index.php;”
删除以下内容的注释:
location ~ .php$ {
fastcgi_pass 127.0.0.1:9000;
fastcgi_index index.php;
include fastcgi_params;
}
测试,创建网站目录
sudo mkdir /var/www/
建立一个虚拟站点:
sudo vi /etc/nginx/sites-available/default
修改root目录: “root /var/www;”
建立一个测试页面:
sudo vi /var/www/test.php
在测试页面test.php中加入以下代码:
<?php phpinfo();?>
配置Nginx和spawn-fcgi配合运行
(1) 在/etc/nginx/fastcgi_params 文件,加入一行:
1
|
fastcgi_param SCRIPT_FILENAME $document_root$fastcgi_script_name;
|
(2) 另外需要在PHP-CGI的配置文件(Ubuntu 上此配置文件位于/etc/php5/cgi/php.ini)中,找到cgi.fix_pathinfo选项,修改为:
1
|
cgi.fix_pathinfo=1;
|
这样php-cgi方能正常使用SCRIPT_FILENAME这个变量.
重启nginx和php-cgi
sudo /etc/init.d/nginx restart
php-cgi -b 127.0.0.1:9000
浏览器输入以下地址,看看有没有安装成功!
http://localhost/test.php
直接使用php-cgi的FastCGI运行方式有两个问题(貌似应该有解决方案,如果知道的话可以教教我):
如果进程崩溃,难以配置重新启动、单进程的效率低
因此,我们可以利用spawn-fcgi来控制进程的运行:
参数含义如下:
-f <fcgiapp> 指定调用FastCGI的进程的执行程序位置,根据系统上所装的PHP的情况具体设置
-a <addr> 绑定到地址addr
-p <port> 绑定到端口port
-s <path> 绑定到unix socket的路径path
-C <childs> 指定产生的FastCGI的进程数,默认为5(仅用于PHP)
-P <path> 指定产生的进程的PID文件路径
-u和-g FastCGI使用什么身份(-u 用户 -g 用户组)运行,Ubuntu下可以使用www-data,其他的根据情况配置,如nobody、apache等
/usr/bin/spawn-fcgi.standalone -a 127.0.0.1 -p 9000 -C 8 -u www-data -g www-data -f /usr/bin/php5-cgi -P /var/run/fastcgi-php.pid
3. 安装 MySQL,输入以下命令:
sudo apt-get install mysql-server mysql-client
中间会提示输入Root用户密码,依次输入即可.
启动MySQL
1
|
sudo /etc/init.d/mysql start
|
测试mysql服务是否正常:
运行
1
|
mysql -uroot -p
|
输入mysql密码
1
|
show databases;
|
如果看到下面的内容
| Database |
| information_schema |
| mysql |
则mysql已正确安装了.
http://www.lupaworld.com/article-217779-1.html
http://www.jb51.net/article/23901.htm
http://www.cnblogs.com/goodspeed/archive/2010/03/27/1698609.html
http://www.cnblogs.com/mchina/archive/2012/05/17/2507102.html
http://my.oschina.net/lht007/blog/112455