CentOS 7安装nginx

1,090 阅读4分钟

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

解压nginx文件

5.复制一份nginx到/usr/local 中,并cd 进入 /usr/local/nginx中

复制nginx到/usr/local

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

安装nginx

7.等待nginx安装完成,完成后,会多出一个Makefile文件夹,这是就可以进行make编译,make 完后,再输入 make install 进行安装

# 编译
make

make install

多了Makefile文件夹

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

进入sbin

报错,nginx中没有logs文件夹

创建并赋值

查看nginx 启动状态和访问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

vi 编辑rc.local文件 在rc.local文件中设置nginx的启动路径

  • 在/etc/init.d创建nginx文件 在/etc/init.d创建nginx文件

  • 编辑 nginx 开机自启动文件 编辑 nginx 开机自启动文件

  • 给nginx赋予权限之类的操作 给nginx赋予权限之类的操作

  • 修改nginx.conf 端口

修改nginx.conf

修改nginx访问端口

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; 

查看nginx进程

kill nginx进程

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

设置为自己的目录