nginx 设置自定义header -----------------------------------------

vim   nginx.conf   在http模块中加入:

add_header  myheader  "the coments of myheader";

这里的myheader 是自定义的名字,你自己随便写。

加完后,测试:curl  -I  http://IP

Nginx中禁止访问.txt文件----------------------------------------

location ~* \.(txt|doc)$ {               if (-f $request_filename) {                  root /home/domain/public_html/test;                  break;                  }               }

Nginx 404 跳转至首页--------------------------------------------

之前用Apache的时候,只需要设置ErrorDocument 404 /404.php

就可以在 404.php 中根据不同的 REQUEST_URI 跳转到不同的页面去,让从搜索引擎过来的失效URL可以跳转到新的地址去

nginx 设置是这样的:

error_page 404  /404.php;

另外也可以通过rewrite规则实现在 rewrite rule 的最后增加

if (!-e $request_filename) {      rewrite ^(.*)$ /404.php last;}

nginx的301与302如何配置-----------------------------------------

#301跳转设置:server {listen 80;server_name 123.com;rewrite ^/(.*) http://456.com/$1 permanent;access_log off;}#302跳转设置:server {listen 80;server_name 123.com;rewrite ^/(.*) http://456.com/$1 redirect;access_log off;}

nginx 配置虚拟目录并支持php-------------------------------------

问题:www.111.com 站点的root目录为 /data/web/ ,现在想在www.111.com 下放一个站点,www.111.com/abc/ 但不能直接在/data/web/下创建abc目录,要放在 /data1/abc/下。

解决办法:使用nginx的alias功能实现虚拟目录

在配置文件中加入

location ~ /abc/(.*)$ {

       alias /data1/abc/$1;

}

当然,alias后面跟的目录可以随意,只要是你放程序的目录即可。也就是说,alias后面定义的/data1/abc/ 也可以使/data1/123/此时,访问图片,网页,css以及js都没有问题,但是访问php就会报404. 怎么办?

继续加如下配置,但注意,要加在上面那段location配置的前面,否则不生效。

location ~ /abc/.+\.php$ {            root /data1/;            rewrite /abc/(.*\.php) /$1 break;            include fastcgi_params;            fastcgi_pass  unix:/tmp/php-fcgi.sock;            fastcgi_index index.php;            fastcgi_param SCRIPT_FILENAME /data1/abc/$fastcgi_script_name;}

到此,也可以支持php了。

用Nginx配置https加密站点----------------------------------------

一、Nginx安装

安装的时候需要注意加上 --with-http_ssl_module,因为http_ssl_module不属于Nginx的基本模块。

Nginx安装方法:

./configure --user=username --group=groupname --prefix=/usr/local/nginx --with-http_stub_status_module --with-http_ssl_module

make && make install

二、生成证书

$ cd /usr/local/nginx/conf$ openssl genrsa -des3 -out server.key 1024$ openssl req -new -key server.key -out server.csr$ cp server.key server.key.org$ openssl rsa -in server.key.org -out server.key$ openssl x509 -req -days 365 -in server.csr -signkey server.key -out server.crt

三、修改Nginx配置:

server{listen 443;server_name test.sina.com.cn;ssl                  on;ssl_certificate      /usr/local/nginx/conf/server.crt;ssl_certificate_key  /usr/local/nginx/conf/server.key;}

nginx 限定下载速度---------------------------------------------

nginx可以通过HTTPLimitZoneModule和HTTPCoreModule两个组件来对目录进行限速。

http {limit_zone   one  $binary_remote_addr  10m;server {location /download/ {limit_conn   one  1;limit_rate 300k;}}}

limit_zone,是针对每个IP定义一个存储session状态的容器。这个示例中定义了一个10m的容器,按照32bytes/session,可以处理320000个session。

limit_conn one 1;限制每个IP只能发起一个并发连接。

limit_rate 300k;对每个连接限速300k. 注意,这里是对连接限速,而不是对IP限速。如果一个IP允许两个并发连接,那么这个IP就是限速limit_rate×2。还可以用来显示每个IP的并发数

nginx限制ip并发数,也是说限制同一个ip同时连接服务器的数量

1.添加limit_zone 

这个变量只能在http使用

vi /usr/local/nginx/conf/nginx.conf

limit_zone one $remote_addr 10m;

2.添加limit_conn   这个变量可以在http, server, location使用

我只限制一个站点,所以添加到server里面

vim /usr/local/nginx/conf/vhost/taobap.cn.conf

limit_conn   one 10;

3.重启nginx :killall -HUP nginx

========================================练习题===================================

1. 到mysql官方下载一个源码包,尝试编译安装,编译参数可以参考我们已经安装过的mysql的编译参数。操作略,有问题的话把问题发出来。mysql官网 

http://dev.mysql.com/downloads/mysql/5.1.html#downloads  选择source code

查看mysql编译参数的方法是 ?cat /usr/local/mysql/bin/mysqlbug|grep configure 

2. mysql的配置文件my.cnf,是否可以放到除了/etc/目录下的其他目录下?

可以放到其他目录下,不过启动的时候需要指定配置文件,或者在启动脚本中定义一下配置文件的路径

手动启动mysql的命令: 

/usr/local/mysql/bin/mysqld_safe --defaults-file=/data/my.cnf --user=mysql --datadir=/data/mysql

或者在启动脚本中/etc/init.d/mysqld 中,搜索conf=/etc/my.cnf,并修改

3. 比较一下,lamp环境和lnmp环境编译php时,编译参数有哪些区别?

lamp的php有指定 apxs,lnmp中没有指定;lnmp中有一项叫做 --enable-fpm,lamp没有

4. 安装好php后,比较一下lamp的php和lnmp的php的目录结构有什么不同?

lnmp的php比lamp的php多出来几个目录:sbin, share, var

5. 想一想,lamp环境下的php安装目录 /usr/local/php 是否可以删除?

可以删除掉,因为lamp中的php是作为apache的一个动态模块libphp5.so来调用的,唯一有影响的是如果指定了php的配置文件php.ini在php的目录下,如果删除后则配置文件失效。

6. php的配置文件是什么? php-fpm 的配置文件是什么?

php的配置文件时php.ini, php-fpm的配置文件时 php-fpm.conf

7. 如何检测nginx配置文件是否有错?如何检测php-fpm的配置文件是否有错?

/usr/local/nginx/sbin/nginx -t

/usr/local/php/sbin/php-fpm -t

8. 在本章中,出现了两次 "chmod 755 /etc/init.d/xxx" 其中xxx 为php-fpm 和 nginx, 想一想为什么要更改他们的权限,如果不改,会有什么问题?

因为php-fpm和nginx是启动脚本,脚本执行必须要有执行权限,如果不给执行权限,不能正确把它们加入到系统服务中。

9. nginx是如何做到解析php文件的?它是如何和php联系在一起的?

nginx解析php,是以代理的方式代理的php-fpm,在nginx的配置文件中有这样一段:

location ~ \.php$ {        include fastcgi_params;        fastcgi_pass unix:/tmp/php-fcgi.sock;        fastcgi_index index.php;        fastcgi_param SCRIPT_FILENAME /backup/sphinx/build/html$fastcgi_script_name;    }

这就是用来指定php-fpm的,nginx本身不能解析php,它只是一个简单的web服务软件,但nginx有一个很好的功能就是可以作为代理服务器,而php-fpm是可以解析php的,所以只要nginx代理一下php-fpm就可以解析php啦。

10. 配置nginx的访问日志,并编写日志切割脚本按天切割。

配置nginx的日志,首先需要定义一下日志格式,这个格式在 nginx.conf的 httpd模块下配置,参考格式:

log_format main1 '$proxy_add_x_forwarded_for - $remote_user [$time_local] '                       '"$request" $status $body_bytes_sent '                      '"$http_referer" "$http_user_agent"';

其中 main1为日志格式的名字,这个会用到。然后在虚拟主机配置段中,也就是server部分中配置加上

access_log /var/log/xxx/access.log  main1;

日志切割脚本(已知访问日志为/var/log/xxx/access.log):

#! /bin/bashd=`date -d "-1 day" +%Y%m%d`/bin/mv /var/log/xxx/access.log /var/log/xxx/$d-access.log/bin/kill -HUP `cat /usr/local/nginx/logs/nginx.pid`  //其中nginx的pid文件为/usr/local/nginx/logs/nginx.pid#假如脚本的名字为 /usr/local/sbin/nginx_logrotate.sh,加入计划任务

0 0 * * * /bin/bash /usr/local/sbin/nginx_logrotate.sh

11. 配置Nginx域名重定向,比如一个虚拟主机支持多个域名访问,abc.com  和 123.com 那么让123.com的访问跳转到 abc.com

在相应的虚拟配置文件中加入:

if ($host != 'abc.com' ) {        rewrite  ^/(.*)$  http://abc.com/$1  permanent;    }

12. 配置Nginx的用户验证

需要先安装 htpasswd命令: yum install -y httpd

htpasswd -c /usr/local/nginx/conf/htpasswd  test // 添加test用户,第一次添加时需要加-c参数,第二次添加时不需要-c参数

在nginx相应虚拟主机配置文件中添加

location  / {                      root /data/www/wwwroot/count;                      auth_basic              "Auth";                      auth_basic_user_file   /usr/local/nginx/conf/htpasswd;            }

13. 针对Nginx站点,设置禁止某个目录下的php程序解析

比如说,禁止abc目录下的php解析:

location ~ .*abc/.*\.php?$        {         deny all;        }

14. 使用Nginx代理一个站点

例如,想在我们的nginx服务器上代理www.baidu.com, 可以创建一个新的虚拟配置文件baidu.conf

server {            listen 80;            server_name www.baidu.com;             proxy_set_header Host   $host;               location / {                proxy_pass      http://61.135.169.125/;                proxy_set_header X-Real-IP      $remote_addr;                proxy_set_header X-Forwarded-For $proxy_add_x_forwarded_for;            }#            access_log  /tmp/1.log;        }

15. 配置nginx限制只让某个ip访问 

在相应的虚拟主机配置文件中,加入

allow 1.1.1.1;

allow 2.2.2.2;

deny all;

16. 设置Nginx 防盗链,比如只想让www.lishiming.net 这个域名的referer访问,其他站点不能访问

首先一点需要明确,防盗链是针对图片或者其他静态文件来设置的,比如我不想让其他网站引用我网站的图片,就可以这样设置防盗链。在相应虚拟配置文件中加入:

location ~* ^.+\.(gif|jpg|png|swf|flv|rar|zip|doc|pdf|gz|bz2|jpeg|bmp|xls)$ {                   valid_referers none blocked server_names  www.lishiming.net;  // 对这些域名的网站不进行盗链。                if ($invalid_referer) {                        return 403;                        }                }

当还可以写多个白名单域名,或者使用通配符:

valid_referers none blocked server_names  *.lishiming.net *.baidu.com;

有时,我们也有这样的需求,如果别的网站引用了我们的图片,可以让它显示成我们自己指定的一张图片:

               if ($invalid_referer) {                        rewrite ^/ http://www.example.com/nophoto.gif;                        }

17. Nginx设置根据user_agent来限制访问,比如禁止baidu的蜘蛛访问站点baidu蜘蛛的user_agent 为 Mozilla/5.0 (compatible; Baiduspider/2.0; +http://www.baidu.com/search/spider.html)

所以,我们可以写成这样:  

    location / {            if ($http_user_agent ~ 'Baiduspider'){                return 403;            }        }

18. Nginx配置虚拟目录

问题:www.111.com 站点的root目录为 /data/web/ ,现在想在www.111.com 下放一个站点,www.111.com/abc/ 但不能直接在/data/web/下创建abc目录,要放在 /data1/abc/下。

解决:使用nginx的alias功能实现虚拟目录,在配置文件中加入

location ~ /abc/(.*)$ {       alias /data1/abc/$1;}

19. Php-fpm.conf 中配置多个pool,如何针对每一个pool配置open_basedir 以及slow_log

php-fpm.conf中可以配置多个pool,并且可以针对每一个pool配置open_basedir和slow_log

首先,php-fpm.conf的配置文件格式为:

[global].........[www.domain1.com].........[www.domain2.com].........

配置open_basedir和slow_log需要在相应的pool中加入:

slowlog = log/www.default.com.slow

request_slowlog_timeout = 1

php_admin_value[open_basedir]=/data/release/www.domain.com/:/tmp/

其中,open_basedir可以写多个目录,多个目录间使用:分隔