今天配置CentOS6.5下安装Nginx + php7 + mysql5.7.15遇到了一些坑。本来家里的电脑在配置环境的时候没有问题,拿去公司的电脑上就是到处报错。不知道是不是人品问题。今晚在家重装了一个centos,安装之后进行了全部yum update。本来以为上午的问题可能是没有更新软件,图样图森破。下面总结一下今晚对nginx部分的心得。

 

因为PCRE本来是用在nginx重写rewrite的时候,解析正则的正则解析库,所以在安装nginx之前,默默的先装上基本应用:

 

yum -y install gcc automake autoconf libtool gcc-c++ gd zlib zlib-devel openssl openssl-devel libxml2 libxml2-devel libjpeg libjpeg-devel libpng libpng-devel freetype freetype-devel libmcrypt libmcrypt-devel pcre pcre-devel

 

ok,现在下载并解压:

 

  wget http://nginx.org/download/nginx-1.10.1.tar.gz

  tar zxvf nginx-1.10.1

  cd nginx-1.10.1

  ./configure --prefix=/usr/local/nginx

 

通过find,知道了pcre默认安装在/usr/local/nginx/auto/lib/pcre,那么,

 

./configure --prefix=/usr/local/nginx --with-pcre=/usr/local/nginx/auto/lib/pcre

 

接下来就是一轮报错:

 

1.发生错误为:

 

make[2]: *** 没有规则可以创建目标“distclean”。 停止。

 

网上看到的办法一一做了尝试:

./configure --prefix=/usr/local/nginx --with-http_stub_status_module --with-openssl=/usr/include/openssl   --user=www --group=www 

 

2.发生错误为:

"conf/koi-win" 与"/usr/local/nginx/conf/koi-win" 为同一文件

据说这是因为防火墙的原因。我又关了防火墙重启:

 

vi + /etc/sysconfig/iptables
#添加配置项
-A INPUT -m state --state NEW -m tcp -p tcp --dport 80 -j ACCEPT
#重启防火墙
service iptables restart

 

3.接着出现:

nginx: could not open error log file: open() "/usr/local/nginx/logs/error.log" failed (2: No such file or directory)
#0: getpwnam("www") failed

喝喝。现在log不能打开,网上说,这是nginx已经运行,被执行启动,这个不算致命错误;

然后就没有了!!!

好吧我杀进程,总算不在运行了吧:

kill -9 nginx

 

4.再次make && make install ,亲人,胡汉三我又回来了!

cp: `conf/koi-win’ and `/usr/local/nginx/conf/koi-win’ 为同一文件。

 

所以上面这一切都是在逗我咯?

好吧。仔细翻了一下,nginx/conf/koi-win,和/usr/local/nginx/conf/kol-win,终于在阿里云上面找到了答案,路径的问题嘛

./configure --prefix=/usr/local/nginx --conf-path=/usr/local/nginx/nginx.conf

 

终于在默念天灵灵地灵灵装好系统行不行的诚恳祷告下,make && make install成功了。以下部分转载自阿里云,并经过实际测试:

 

接下来启动nginx

#方法1 
[root@unique nginx]# /usr/local/nginx/sbin/nginx -c /usr/local/nginx/conf/nginx.conf 
#方法2 
[root@unique nginx]# cd /usr/local/nginx/sbin 
[root@unique sbin]# ./nginx

停止nginx

#查询nginx主进程号 
ps -ef | grep nginx
#停止进程  kill -QUIT 主进程号(我的是27854) 

#快速停止  kill -TERM 主进程号(我的是2993) 

#强制停止  pkill -9 nginx

重启nginx

[root@unique sbin]# /usr/local/nginx/sbin/nginx -s reload

这个时候如果出现nginx: [error] open() "/usr/local/nginx/logs/nginx.pid" failed

想必是需要:

/usr/local/nginx/sbin/nginx -c /usr/local/nginx/conf/nginx.conf

继续

/usr/local/nginx/sbin/nginx -c /usr/local/nginx/conf/nginx.conf

测试nginx

#测试端口 
netstat –na|grep 80
#浏览器中测试 
http://ip:80

 

做一个自定义的nginx启动停止脚本

[root@unique sbin]# vi /etc/init.d/nginx

把下面的脚本复制进去然后保存

#! /bin/sh
# Default-Start:     2 3 4 5
# Default-Stop:      0 1 6
# Short-Description: starts the nginx web server

PATH=/usr/local/sbin:/usr/local/bin:/sbin:/bin:/usr/sbin:/usr/bin
DESC="nginx daemon"
NAME=nginx
DAEMON=/usr/local/nginx/sbin/$NAME
CONFIGFILE=/usr/local/nginx/conf/$NAME.conf
PIDFILE=/usr/local/nginx/logs/$NAME.pid
SCRIPTNAME=/etc/init.d/$NAME

set -e
[ -x "$DAEMON" ] || exit 0

do_start() {
 $DAEMON -c $CONFIGFILE || echo -n "nginx already running"
}

do_stop() {
 kill -INT `cat $PIDFILE` || echo -n "nginx not running"
}

do_reload() {
 kill -HUP `cat $PIDFILE` || echo -n "nginx can't reload"
}

case "$1" in
 start)
 echo -n "Starting $DESC: $NAME"
 do_start
 echo "."
 ;;
 stop)
 echo -n "Stopping $DESC: $NAME"
 do_stop
 echo "."
 ;;
 reload|graceful)
 echo -n "Reloading $DESC configuration..."
 do_reload
 echo "."
 ;;
 restart)
 echo -n "Restarting $DESC: $NAME"
 do_stop
 do_start
 echo "."
 ;;
 *)
 echo "Usage: $SCRIPTNAME {start|stop|reload|restart}" >&2
 exit 3
 ;;
esac

exit 0


给文件添加执行权限

[root@unique sbin]# chmod +x /etc/init.d/nginx
#然后可以通过
#/etc/init.d/nginx start 命令启动nginx
#/etc/init.d/nginx stop 命令停止nginx
#/etc/init.d/nginx restart 命令重启nginx

#重启nginx
[root@unique init.d]# /etc/init.d/nginx restart
Restarting nginx daemon: nginx.

 

扩展:配置开机启动

    如果需要开机启动服务,保存好 /etc/init.d/nginx文件后,执行以下命令:

[root@unique init.d]#chkconfig --add ningx
[root@unique init.d]#chkconfig --level nginx 2345 on


于是,我开始配置php和mysql,前方必然有坑。容我慢慢趟来……