1. 登录CentOS 后,先 cd 到你想存放nginx的文件夹里面,比如:
cd /data/softWare
2. 用 wget 加 url下载对应的nginx 版本,这里以nginx-1.10.3 为例子
wget http://nginx.org/download/nginx-1.10.3.tar.gz
#PS: 安装nginx 之前需要检查是否有安装 gcc、pcre-devel、zlib-devel、openssl-devel
yum list installed | grep "gcc"
yum list installed | grep "pcre-devel"
yum list installed | grep "zlib-devel"
yum list installed | grep "openssl-devel"
或者
yum -y install gcc pcre-devel zlib-devel openssl openssl-devel
3.等待下载完成,下载完成后的这里以nginx文件会出现一开始cd 的文件夹里面
4. 解压下载好的nginx压缩文件
# Linux 解压命令行
tar -zxvf nginx-1.10.3.tar.gz
5.复制一份nginx到/usr/local 中,并cd 进入 /usr/local/nginx中
6.运行 使用 ./configure --prefix=/usr/local/nginx/ ,prefix= 后面跟着得是安装地址,也可以不设置,直接 ./configure 。 如果出现权限不够问题,给 congigure添加权限,重新再运行,如果是需要支持https的话,安装方法改为 ./configure --prefix=/usr/local/nginx --with-http_stub_status_module --with-http_ssl_module
## 配置
./configure --prefix=/usr/local/nginx/
## 支持https的nginx
./configure --prefix=/usr/local/nginx --with-http_stub_status_module --with-http_ssl_module
## 添加权限
chmod +x configure
7.等待nginx安装完成,完成后,会多出一个Makefile文件夹,这是就可以进行make编译,make 完后,再输入 make install 进行安装
# 编译
make
make install
8. 进入到sbin目录 然后./nginx启动 nginx默认是80端口 如果你想修改端口就进入到conf目录下找到nginx.conf修改。如果出现下面报错,说明在nginx中没有对应的文件夹,需要去创建并赋值,图三中需要返回nginx文件夹再创建logs,赋予权限,进入sbin,启动 ./nginx
nginx: [alert] could not open error log file: open() "/usr/local/nginx//logs/error.log" failed (2: No such file or directory)
12785#0: open() "/usr/local/nginx//logs/access.log" failed (2: No such file or directory)
# 查看nginx 启动状态
ps -ef|grep nginx
# 访问80端口
curl localhost:80
9.如果需要让外部访问,需要开放端口,开机自启动
# 检查端口是否开放
firewall-cmd --query-port=3306/tcp
# 检查端口是否开放遇到下面英文时,说明服务器的防火墙没有开启,需要启动防火墙
FirewallD is not running
# 启动防火墙
systemctl start firewalld
# 允许哪些端口开放
firewall-cmd --zone=public --add-port=80/tcp --permanent
firewall-cmd --zone=public --add-port=8080/tcp --permanent
firewall-cmd --zone=public --add-port=443/tcp --permanent
firewall-cmd --zone=public --add-port=3306/tcp --permanent
firewall-cmd --zone=public --add-port=6379/tcp --permanent
# 上面的端口打开后,还需要刷新防火墙才行
# 禁止哪些端口开放
firewall-cmd --zone=public --remove-port=80/tcp --permanent
firewall-cmd --zone=public --remove-port=8080/tcp --permanent
firewall-cmd --zone=public --remove-port=443/tcp --permanent
firewall-cmd --reload
- 开机自启动
vi /etc/rc.d/rc.local
# 放到rc.local 文件中
# 开机自启动
/usr/local/nginx/sbin/nginx
# 在/etc/init.d创建nginx文件
vi /etc/init.d/nginx
# 在需要编辑的 nginx 文件中输入下面内容,看下面的第11点
# 进入init.d 文件夹,然后给 nginx 赋予权限,当然也可以不进入init.d文件夹进行赋值
cd /etc/init.d
chmod a+x nginx
或
chmod a+x /etc/init.d/nginx
# 把脚本添加到系统服务
chkconfig --add /etc/init.d/nginx
# 可以验证系统服务是否开启
service nginx start //开户nginx
service nginx stop //关闭nginx
# 添加到开机自启
chkconfig nginx on
-
在/etc/init.d创建nginx文件
-
编辑 nginx 开机自启动文件
-
给nginx赋予权限之类的操作
-
修改nginx.conf 端口
10. 补充 nginx 的一些命令操作
# 查看进程
ps -ef|grep nginx
# 杀死nginx 进程 方法一
kill -QUIT 7238
# 杀死nginx 进程 方法二
kill -TERM 7238
# 杀死nginx 进程 方法三
kill -INT 7238
# 重启 nginx ,需要在 nginx的sbin 里面运行
./nginx -s reload
#允许或者禁止某ip访问
ip段:x.x.x.1-x.x.x.255 的表示方法:10.0.0.0/24
ip段:x.x.0.1-x.x.255.255 的表示方法:10.0.0.0/16
ip段:x.0.0.1-x.255.255.255 的表示方法:10.0.0.0/8
# 允许访问
allow 182.239.1.0/24;
allow 182.239.0.0/16;
allow 182.0.0.0/8;
# 禁止访问
deny 182.239.1.0/24;
deny 182.239.0.0/16;
deny 182.0.0.0/8;
# 禁止所有IP访问
deny all;
11. 在 etc/init.d/nginx 文件中需要添加的内容下面内容
- 其中 nginx="/usr/sbin/nginx" 和 NGINX_CONF_FILE="/etc/nginx/nginx.conf", =后面的内容修改为自己的目录
#!/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="/usr/sbin/nginx"
prog=$(basename $nginx)
NGINX_CONF_FILE="/etc/nginx/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:.*--user=" | sed 's/[^*]*--user=\([^ ]*\).*/\1/g' -`
if [ -n "$user" ]; then
if [ -z "`grep $user /etc/passwd`" ]; then
useradd -M -s /bin/nologin $user
fi
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
fi
}
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 $prog -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