Linux编译安装nginx详细步骤
首先为什么linux有些软件需要编译安装(相对于rpm安装:包yum安装:仓库,这两个安装来说真的有些繁琐)?
为什么服务器软件需要编译安装?一个流传很广的说法是编译安装性能更好,其实这是个谣言
服务器CPU事实已经被Intel垄断了,就那么几种型号,编来编去生成的机器码是一样的。Intel宣传自己的编译工具Intel C++ Compiler 比GCC编译出来性能要提升10%-20%,这就是一广告,生产环境很少用人用它,何况它还要收费
性能真不是问题,比如 strip 命令可以大大减小可执行文件的size,但是我装过几千遍软件,都没有见有人在安装脚本里面使用。
软件需要编译安装的真实理由有如下3点:
1.软件在编译期间需要配置,比如说nginx,需要在编译的时候指定包含哪些module,php,apache 也是一样。
同样的是数据库,mysql 通过编译安装,因为要定制存储引擎(是否支持innodb .. ),而sqlite却绝少有人编译,都是直接下载二进制文件来用。
2.软件需要统一安装路径,每个team都会自己的安装目录约定,有些喜欢装在 /opt/下面,有些喜欢装在 /usr/local/ ,编译安装可以方便的指定这些路径(configure –prefix=xxx )
3.需要最新的版本,软件仓库的版本一般都比较低,这个理由其实不充分,生产环境倾向保守,不追求最新版本,但是对于geek来说,这可能是最重要的原因
弄明白原因之后,就很容易判断编译还是下载:
nginx/apache/php/mysql 编译安装
python/ruby/java 直接下载
下面可能出现的报错:
yum No more mirrors to try 解决方法
输入下面的命令即可解决问题:
yum clean all
yum makecache
接下来使用编译安装来安装nginx:
1、上传解压
2、根据README的提示一步步进行编译安装
(1)./configure
[aaa@qq.com tengine-2.2.2]# ./configure –prefix=/opt/software/nginx
发现报错了:需要安装C语言的编译器
使用yum命令安装gcc
[aaa@qq.com tengine-2.2.2]# yum install gcc
安装完成后,再次执行命令
[aaa@qq.com tengine-2.2.2]# ./configure –prefix=/opt/software/nginx
发现又报错:
使用yum命令安装pcre
[aaa@qq.com tengine-2.2.2]# yum install prce-devel
安装完成后,再次执行命令
[aaa@qq.com tengine-2.2.2]# ./configure –prefix=/opt/software/nginx
发现又报错:
使用yum命令安装openssl
[aaa@qq.com tengine-2.2.2]# yum install openssl-devel
安装完成后,再次执行命令
[aaa@qq.com tengine-2.2.2]# ./configure –prefix=/opt/software/nginx
这次终于没有报错了,发现目录下多了一个文件Makefile(注意:有些文件解压后就会有这个文件夹,这样的话,就省了上面的这些操作了)
(2)make
[aaa@qq.com tengine-2.2.2]# make
(3)make install
[aaa@qq.com tengine-2.2.2]# make install
至此nginx编译完成,可以在指定的安装目录下的sbin中执行./nginx命令了
这里补充一个知识点:每次启动、停止、重启linux都需要切换到sbin目录下,未免有点繁琐,所以写一个脚本如下:
#!/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="/opt/software/nginx/sbin/nginx"
prog=$(basename $nginx)
NGINX_CONF_FILE="/opt/software/nginx/conf/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
那么这个脚本应该放在什么地方呢?
在/etc/init.d目录下vi一个nginx文件,然后把上面的脚本复制进去:
修改为可执行权限:
[aaa@qq.com init.d]# chmod +x nginx
这个时候就可以使用脚本启动nginx了:
启动nginx服务器后,可以在web端访问:
http://unisk01:80
这里有一个地方需要注意:当查看nginx状态的时候会发现启动了两个进程
这里可以看到两个进程分别为master和worker,worker的父进程就是master,而master的作用仅仅是用来启动worker的,master的用户是root,而worker默认的用户是nobody。
worker进程是用来负责连接的, 所以用于不能为root,不然很容易被攻击。
上一篇: mysql - 存储过程及分支语句
下一篇: Android开发 为应用设置自定义字体
推荐阅读
-
在linux系统中安装virtualbox增强功能(增强包)的详细步骤
-
LInux下安装MySQL5.6 X64版本步骤详解
-
linux安装mysql 8.0.x的完整步骤
-
phonegap3.4.0安装详细步骤
-
windows7下vs2010安装opencv2.4.3详细步骤(图)
-
linux 用yum命令安装mysql的步骤分享
-
win7系统安装SQLServer2000的详细步骤(图文)
-
Autodesk T-Splines 4.0怎么安装?Autodesk T-Splines 4.0详细安装以及破解步骤
-
centOS7安装docker的详细步骤
-
linux安装vsftpd和vsftpd配置步骤