分类:web

nginx 301 rewrite 跳转到带 www 域名方法

首先一、得在你的域名管理里面定义 test.com和www.test.com指向你的主机ip地址,我们可以使用nslookup命令测试:
直接输入 nslookup test.com和nslookup www.test.com 都有指向ip的A记录即可。

第二、我们才能在nginx里面配置rewrite规则。
打开 nginx.conf文件找到你的server配置段:

1
2
3
4
5
6
7
8
server
{
listen 80;
server_name www.test.com test.com;
if ($host != 'www.test.com' ) {
    rewrite ^/(.*)$ http://www.test.com/$1 permanent;
}
........

这样就是用户直接访问 test.com 直接跳转 的www.test.com。
即让不带 www 的域名跳转到带 www 的域名,根据需要,也可以把带 www 的域名跳转到不带 www 的(比如本博)。

办法2:在配置文件里面写两个 server,第一个里面把不带 www 的域名去掉

1
2
3
4
server
 {
  listen       80;
  server_name www.test.com;

在配置文件的最下面添加上,这样就可以了。

1
2
3
4
server {
                server_name test.com;
                rewrite ^(.*) http://www.test.com/$1 permanent;
        }

如果有多个不同的域名都绑定在同一个目录下不带 www 的 301 到带 www 的方法和上面的一样
在 vhost 的完整配制里后面加上

1
2
3
4
5
6
7
8
9
10
11
12
13
14
server {
server_name test1.com;
rewrite ^(.*) http://www.test1.com$1 permanent;
}
server {
server_name test2.com;
rewrite ^(.*) http://www.test2.com$1 permanent;
}
server {
server_name test3.com;
rewrite ^(.*) http://www.test3.com$1 permanent;
}

301 永久跳转,当用户或搜索引擎向网站服务器发出浏览请求时,服务器返回的 HTTP 数据流中头信息中的状态码的一种,表示本网页永久性转移到另一个地址。
302 临时跳转,也是状态码的一种,意义是暂时转向到另外一个网址。
二者的区别主要是,一句话,302 容易被搜索引擎视为 spam,301则不会。
permanent 代表301永久跳转,改为 redirect 则为302临时跳转。
nginx 官方 rewrite 文档:传送门

解决 WordPress 3.4 主题列表里所有主题都消失的问题

升级 WordPress 3.4 之后我的所有主题都从仪表盘的主题管理页面消失了,除了那个正在使用的主题。今天终于找到了原因所在,顺利解决问题。原来是优化服务器的时候将 PHP 的 scandir 函数禁用掉了,而新版 WordPress 引入了 WP_Theme 类来处理主题问题,该类使用 scandir 函数来检测 /wp-content/themes/ 中的所有主题。

我使用的是的 Linode 的 VPS,自己安装的 lnmp,默认的 php.ini 文件,在大约 210 行的 disable_functions = 后面列上了一堆 PHP 函数,其中就有 scandir(我忘了是不是自己改过了,瀑布汗 -__-|||)。一直以来都没注意这个问题,没想到这次想试试新主题, 就出现这样的事情。上网搜索了一下,找到解决办法:编辑 php.ini 文件,将 scandir 从那一行里删除,然后重新启动服务器。

PS,开始我我用 nginx -s reload 重启 nginx,但是这个改动不生效,后来重启服务器才搞定的。

参考博客: http://cnzhx.net/blog/solve-problem-of-no-available-themes/

Godaddy 域名 DNS 被墙免费解决办法

继前几天Google服务抽风无法访问后,我们伟大的墙,终于看上我这个小站了,域名解析被屏蔽(IP 地址并没有屏蔽掉),解决办法有两种,1.通过访问电脑的 DNS 到 8.8.8.8,2.在 Host 文件里写一条记录。但是不能要求所有的网站来宾都这样做呀。 Read More.

Nginx目录自动加斜杠

最近调整了一个网站的结构,把原来 bbs.domain.com 的论坛,移到 主域名下的 bbs 目录。弄好后一切正常,只有一个问题,就是如果我访问 http://www.domain.com/bbs/ 就可以显示出地址,但如果我访问 http://www.domain.com/bbs 结果却提示说找不到所需要的页面。

发生这种情况,是因为 nginx不会自动判断请求的是一个文件还是一个目录,所以不会自动在请求的最后加上一个斜杠 / ,解决方法为:

在配置文件中 server 里加入如下代码

if (-d $request_filename) {
rewrite ^/(.*)([^/])$ http://$host/$1$2/ permanent;
}

这样再对 http://www.domain.com/bbs 请求,nginx 就会进行判断了,如果请求的是一个文件夹,会自动在最后加上 / 符号,如果请求的是一个文件,则不会改变原有 url。 Read More.

给 windows 下的 nginx + php 添加 zend 和 eAc

昨天我们简单搭建了 Windows 平台下的 nginx + php 环境,但是没有添加 zend 和 eac 加速器。原来添加 zend 的方法不行了,因为我们安装的是 nts (非线程安全)的 php,而原来的 zend 只是为 ts 的 php 编译的,直接装上会报错。

我找了下互联网,找到这么个东西 ZendOptimizer for PHP 5.2.1 nts,虽然不是最新版本,好歹能用。下载回来解压到 d:\wnmp\zend。在 php.ini 里最末位添加

[Zend]
zend_extension=”D:\wnmp\zend\ZendOptimizer.dll”

eAccelerator 也一样,要用 nts 版本的。到这里下载

另外,这个网站编译了很多 php 5.3.x 的版本提供下载,给安装 php 5.3 系列的朋友用。

下载回来后,放到 d:\php\ext 目录下,在 php.ini 末尾添加

[eAccelerator]
extension=”eAccelerator_nts.dll
eaccelerator.shm_size=”16″
eaccelerator.cache_dir=”D:\Temp\eAccelerator”
eaccelerator.enable=”1″
eaccelerator.optimizer=”1″
eaccelerator.check_mtime=”1″
eaccelerator.debug=”0″
eaccelerator.filter=””
eaccelerator.shm_max=”0″
eaccelerator.shm_ttl=”0″
eaccelerator.shm_prune_period=”0″
eaccelerator.shm_only=”0″
eaccelerator.compress=”1″
eaccelerator.compress_level=”9″
eaccelerator.content = “shm_and_disk”

保存,重启 nginx + php,打开phpinfo,验证通过,结束。

windows 下的 nginx + php 环境搭建

这几天有一台 Web 服务器一直不定时出现无法访问的情况,远程一看,Apache 进程占用内存极高,而这台服务器偏偏内存不富裕,就像换成目前极度流行的 nginx 试试。

nginx 是一个轻量级的高性能 Http WebServer,以事件驱动方式编写,因此相比 Apache 而言,Nginx 更加稳定、性能更好,而且配置简单,资源占用较低。目前 Windows 下的稳定版本是 1.0.14,可以在官网免费下载。 Read More.

在 IIS6 下架设 MDaemon Wordclient

最近公司用的 Hotmail Domain 服务越来越慢了,考虑自己搭建一个邮件系统,瞄准了MDaemon 这个 Windows 下流行程度仅次于微软 Exchange 的神器。

MDaemon 最新版本已经是 12.5.2 了(昨天刚发布的),下载回来,安装在 D:\MDaemon 目录。(不要问我除了官网还有哪里有下载。)

MDaemon 自己有内置的 Web 服务器,运行它的 Web 界面 WorldClient,但是我们的服务器已经运行了 IIS6 了,如果你有预算可以支持一台单独的邮件服务器,请关闭本页面。WorldClient 可不可以运行在 IIS6 下呢,当然可以,MDaemon 的用户手册里也有说明,这里再详细说下。

Read More.

wordpress在nginx的伪静态规则

原来的apache代码不能用了,放狗搜了下,有个现成的

还是在网站根目录建立一个 .htaccess 文件,把下面的内容粘贴进去

location / {
if (-f $request_filename/index.html){
rewrite (.*) $1/index.html break;
}
if (-f $request_filename/index.php){
rewrite (.*) $1/index.php;
}
if (!-f $request_filename){
rewrite (.*) /index.php;
}
}

nginx常用命令

基本命令

快速关闭服务
nginx -s stop

完全关闭服务
nginx -s quit

重启服务
nginx -s reload

重新打开log文件
nginx -s reopen

重新加载conf文件
nginx -c /usr/nginx/conf/nginx.conf

启动操作
命令:
nginx -c /usr/nginx/conf/nginx.conf
-c参数指定了要加载的nginx配置文件路径。

停止操作
停止操作是通过向nginx进程发送信号(什么是信号请参阅linux文章)来进行的
步骤1:查询nginx主进程号
ps -ef | grep nginx
在进程列表里面找master进程,它的编号就是主进程号了。
步骤2:发送信号
从容停止Nginx:
kill -QUIT 主进程号
快速停止Nginx:
kill -TERM 主进程号
强制停止Nginx:
pkill -9 nginx

另外,若在nginx.conf配置了pid文件存放路径则该文件存放的就是Nginx主进程号,如果没指定则放在nginx的logs目录下。有了pid文件,我们就不用先查询Nginx的主进程号,而直接向Nginx发送信号了,命令如下:
kill -信号类型 ‘/usr/nginx/logs/nginx.pid’

平滑重启
如果更改了配置就要重启Nginx,要先关闭Nginx再打开?不是的,可以向Nginx发送信号,平滑重启。
平滑重启命令:
kill -HUP 住进称号或进程号文件路径

注意,修改了配置文件后最好先检查一下修改过的配置文件是否正确,以免重启后Nginx出现错误影响服务器稳定运行。判断Nginx配置是否正确命令如下:
nginx -t -c /usr/nginx/conf/nginx.conf

平滑升级
如果服务器正在运行的Nginx要进行升级、添加或删除模块时,我们需要停掉服务器并做相应修改,这样服务器就要在一段时间内停止服务,Nginx可以在不停机的情况下进行各种升级动作而不影响服务器运行。
步骤1:
如果升级Nginx程序,先用新程序替换旧程序文件,编译安装的话新程序直接编译到Nginx安装目录中。
步骤2:执行命令
kill -USR2 旧版程序的主进程号或进程文件名
此时旧的Nginx主进程将会把自己的进程文件改名为.oldbin,然后执行新版Nginx。新旧Nginx会同时运行,共同处理请求。
这时要逐步停止旧版Nginx,输入命令:
kill -WINCH 旧版主进程号
慢慢旧的工作进程就都会随着任务执行完毕而退出,新版的Nginx的工作进程会逐渐取代旧版工作进程。

此时,我们可以决定使用新版还是恢复到旧版。
不重载配置启动新/旧工作进程
kill -HUP 旧/新版主进程号
从容关闭旧/新进程
kill -QUIT 旧/新主进程号
如果此时报错,提示还有进程没有结束就用下面命令先关闭旧/新工作进程,再关闭主进程号:
kill -TERM 旧/新工作进程号

这样下来,如果要恢复到旧版本,只需要上面的几个步骤都是操作新版主进程号,如果要用新版本就上面的几个步骤都操作旧版主进程号就行了。

上面就是Nginx的一些基本的操作,希望以后Nginx能有更好的方法来处理这些操作,最好是Nginx的命令而不是向Nginx进程发送系统信号。