`
rq2_79
  • 浏览: 240270 次
  • 性别: Icon_minigender_1
  • 来自: 上海
社区版块
存档分类
最新评论

Nginx---linux安装,重启脚本

 
阅读更多

安装

首先到这个网站可以下载源码包:

http://nginx.org/en/download.html

 

tar -zxvf nginx-1.1.0.tar.gz 

cd nginx-1.1.0

./configure

(由于我的电脑中没有安装PCRE库,所以只有把增加    --without-http_rewrite_moduleoption 才能通过编译。)

make

make install

启动脚本

第一步

先运行命令关闭nginx

sudo kill `cat /usr/local/nginx/logs/nginx.pid`

第二步

vi /etc/init.d/nginx

输入以下内容

#!/bin/sh
#
# nginx - this script starts and stops the nginx daemin
#
# chkconfig:   - 85 15 
# description:  Nginx is an HTTP(S) server, HTTP(S) reverse \
#               proxy and IMAP/POP3 proxy server
# processname: nginx
# config:      /usr/local/nginx/conf/nginx.conf
# pidfile:     /usr/local/nginx/logs/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/local/nginx/sbin/nginx"
prog=$(basename $nginx)

NGINX_CONF_FILE="/usr/local/nginx/conf/nginx.conf"

lockfile=/var/lock/subsys/nginx

start() {
    [ -x $nginx ] || exit 5
    [ -f $NGINX_CONF_FILE ] || exit 6
    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
    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
 

保存退出

第三步

chmod 777 /etc/init.d/nginx

第四步

/sbin/chkconfig nginx on

检查一下

sudo /sbin/chkconfig --list nginx
nginx           0:off   1:off   2:on    3:on    4:on    5:on    6:off

完成!

之后,就可以使用以下命令了

service nginx start
service nginx stop
service nginx restart
service nginx reload

/etc/init.d/nginx start
/etc/init.d/nginx stop
/etc/init.d/nginx restart
/etc/init.d/nginx reload

 

******************************************************************

 

以下是./configure的选项

--prefix=<path> - Nginx安装路径。如果没有指定,默认为 /usr/local/nginx

--sbin-path=<path> - Nginx可执行文件安装路径。只能安装时指定,如果没有指定,默认为<prefix>/sbin/nginx

--conf-path=<path> - 在没有给定-c选项下默认的nginx.conf的路径。如果没有指定,默认为<prefix>/conf/nginx.conf

--pid-path=<path> - nginx.conf中没有指定pid指令的情况下,默认的nginx.pid的路径。如果没有指定,默认为 <prefix>/logs/nginx.pid

--lock-path=<path> - nginx.lock文件的路径。

--error-log-path=<path> - nginx.conf中没有指定error_log指令的情况下,默认的错误日志的路径。如果没有指定,默认为 <prefix>/logs/error.log

--http-log-path=<path> - nginx.conf中没有指定access_log指令的情况下,默认的访问日志的路径。如果没有指定,默认为 <prefix>/logs/access.log

--user=<user> - nginx.conf中没有指定user指令的情况下,默认的nginx使用的用户。如果没有指定,默认为 nobody

--group=<group> - nginx.conf中没有指定user指令的情况下,默认的nginx使用的组。如果没有指定,默认为 nobody

--builddir=DIR - 指定编译的目录

--with-rtsig_module - 启用 rtsig 模块

--with-select_module --without-select_module - Whether or not to enable the select module. This module is enabled by default if a more suitable method such as kqueue, epoll, rtsig or /dev/poll is not discovered by configure.

//允许或不允许开启SELECT模式,如果 configure 没有找到更合适的模式,比如:kqueue(sun os),epoll (linux kenel 2.6+), rtsig(实时信号)或者/dev/poll(一种类似select的模式,底层实现与SELECT基本相 同,都是采用轮训方法) SELECT模式将是默认安装模式

--with-poll_module --without-poll_module - Whether or not to enable the poll module. This module is enabled by default if a more suitable method such as kqueue, epoll, rtsig or /dev/poll is not discovered by configure.

--with-http_ssl_module - Enable ngx_http_ssl_module. Enables SSL support and the ability to handle HTTPS requests. Requires OpenSSL. On Debian, this is libssl-dev.

//开启HTTP SSL模块,使NGINX可以支持HTTPS请求。这个模块需要已经安装了OPENSSL,在DEBIAN上是libssl

--with-http_realip_module - 启用 ngx_http_realip_module

--with-http_addition_module - 启用 ngx_http_addition_module

--with-http_sub_module - 启用 ngx_http_sub_module

--with-http_dav_module - 启用 ngx_http_dav_module

--with-http_flv_module - 启用 ngx_http_flv_module

--with-http_stub_status_module - 启用 "server status" 

--without-http_charset_module - 禁用 ngx_http_charset_module

--without-http_gzip_module - 禁用 ngx_http_gzip_module. 如果启用,需要 zlib 

--without-http_ssi_module - 禁用 ngx_http_ssi_module

--without-http_userid_module - 禁用 ngx_http_userid_module

--without-http_access_module - 禁用 ngx_http_access_module

--without-http_auth_basic_module - 禁用 ngx_http_auth_basic_module

--without-http_autoindex_module - 禁用 ngx_http_autoindex_module

--without-http_geo_module - 禁用 ngx_http_geo_module

--without-http_map_module - 禁用 ngx_http_map_module

--without-http_referer_module - 禁用 ngx_http_referer_module

--without-http_rewrite_module - 禁用 ngx_http_rewrite_module. 如果启用需要 PCRE 

--without-http_proxy_module - 禁用 ngx_http_proxy_module

--without-http_fastcgi_module - 禁用 ngx_http_fastcgi_module

--without-http_memcached_module - 禁用 ngx_http_memcached_module

--without-http_limit_zone_module - 禁用 ngx_http_limit_zone_module

--without-http_empty_gif_module - 禁用 ngx_http_empty_gif_module

--without-http_browser_module - 禁用 ngx_http_browser_module

--without-http_upstream_ip_hash_module - 禁用 ngx_http_upstream_ip_hash_module

--with-http_perl_module - 启用 ngx_http_perl_module

--with-perl_modules_path=PATH - 指定 perl 模块的路径

--with-perl=PATH - 指定 perl 执行文件的路径

--http-log-path=PATH - Set path to the http access log

--http-client-body-temp-path=PATH - Set path to the http client request body temporary files

--http-proxy-temp-path=PATH - Set path to the http proxy temporary files

--http-fastcgi-temp-path=PATH - Set path to the http fastcgi temporary files

--without-http - 禁用 HTTP server

--with-mail - 启用 IMAP4/POP3/SMTP 代理模块

--with-mail_ssl_module - 启用 ngx_mail_ssl_module

--with-cc=PATH - 指定 C 编译器的路径

--with-cpp=PATH - 指定 C 预处理器的路径

--with-cc-opt=OPTIONS - Additional parameters which will be added to the variable CFLAGS. With the use of the system library PCRE in FreeBSD, it is necessary to indicate --with-cc-opt="-I /usr/local/include". If we are using select() and it is necessary to increase the number of file descriptors, then this also can be assigned here: --with-cc-opt="-D FD_SETSIZE=2048".

--with-ld-opt=OPTIONS - Additional parameters passed to the linker. With the use of the system library PCRE in FreeBSD, it is necessary to indicate --with-ld-opt="-L /usr/local/lib".

--with-cpu-opt=CPU - 为特定的 CPU 编译,有效的值包括:pentium, pentiumpro, pentium3, pentium4, athlon, opteron, amd64, sparc32, sparc64, ppc64

--without-pcre - 禁止 PCRE 库的使用。同时也会禁止 HTTP rewrite 模块。在 "location" 配置指令中的正则表达式也需要 PCRE 

--with-pcre=DIR - 指定 PCRE 库的源代码的路径。

--with-pcre-opt=OPTIONS - Set additional options for PCRE building.

--with-md5=DIR - Set path to md5 library sources.

--with-md5-opt=OPTIONS - Set additional options for md5 building.

--with-md5-asm - Use md5 assembler sources.

--with-sha1=DIR - Set path to sha1 library sources.

--with-sha1-opt=OPTIONS - Set additional options for sha1 building.

--with-sha1-asm - Use sha1 assembler sources.

--with-zlib=DIR - Set path to zlib library sources.

--with-zlib-opt=OPTIONS - Set additional options for zlib building.

--with-zlib-asm=CPU - Use zlib assembler sources optimized for specified CPU, valid values are: pentium, pentiumpro

--with-openssl=DIR - Set path to OpenSSL library sources

--with-openssl-opt=OPTIONS - Set additional options for OpenSSL building

--with-debug - 启用调试日志

--add-module=PATH - Add in a third-party module found in directory PATH

 

分享到:
评论

相关推荐

    nginx-linux-1.24.0.tar.gz

    以下将详细介绍如何在Linux环境下安装和使用这个版本的Nginx。 首先,我们需要了解Linux的基础操作。Linux是一种多用户、多任务的分时操作系统,它的命令行界面提供了丰富的工具进行文件管理、网络通信等任务。对于...

    nginx-1.20.2.tar.gz

    在Linux操作系统中,Nginx 的安装通常涉及下载源码包、编译和配置等步骤。`nginx-1.20.2.tar.gz` 是 Nginx 1.20.2 版本的源码压缩包,它包含了所有构建和运行Nginx所需的文件。 ### 一、下载与解压 首先,你需要在...

    nginx-1.15.5-linux

    **Nginx 1.15.5在Linux系统中的安装与配置详解** Nginx是一款高性能、轻量级的Web服务器/反向代理服务器,因其高效稳定、配置简单、资源消耗低等特点,在互联网行业中被广泛应用。本篇将详细介绍如何在Linux系统中...

    nginx-1.10.0 系统服务安装

    - `sudo systemctl restart nginx`:重启 Nginx 服务 - `sudo systemctl status nginx`:查看 Nginx 服务状态 ### 六、安全注意事项 为了提升安全性,建议: 1. 修改默认的 Nginx 监听端口(80 和 443)。 2. 配置...

    nginx-1.19.6正版资源包

    在 Linux 系统中,通常通过编译源码的方式来安装Nginx。首先,你需要确保系统上安装了必要的编译工具,如GCC、Make等。然后,下载nginx-1.19.6压缩包并解压,进入解压后的目录,执行以下步骤: 1. **配置**: ``` ...

    nginx-1.17.4.tar.gz

    5. **启动与管理:** 安装完成后,可以使用Nginx提供的控制脚本来启动、停止或重启服务。例如: - 启动Nginx:`sudo /usr/local/nginx/sbin/nginx` - 停止Nginx:`sudo /usr/local/nginx/sbin/nginx -s stop` - ...

    nginx-1.15.12.tar.gz

    在 Linux 环境下,Nginx 的安装与配置是运维工作中常见的任务。针对提供的“nginx-1.15.12.tar.gz”文件,我们将详细介绍如何在 Linux 上部署这个特定版本的 Nginx。 1. **下载与解压**: 首先,你需要在 Linux ...

    Linux下自动安装nginx1.19.9,包括依赖环境

    在Linux环境中,自动安装Nginx ...总之,通过使用提供的shell脚本,Linux用户可以在不熟悉复杂编译过程的情况下,轻松地安装和配置Nginx 1.19.9,并确保其在系统重启后自动启动。这极大地简化了运维工作,提高了效率。

    nginx-1.16.1.tar , nginx-1.18.0.tar

    6. **启动和管理 Nginx**:安装完成后,可以通过以下命令启动、停止或重启 Nginx: ``` sudo /usr/local/nginx/sbin/nginx sudo /usr/local/nginx/sbin/nginx -s stop sudo /usr/local/nginx/sbin/nginx -s ...

    nginx-1.15.9.tar.gz

    6. **启动与配置**: 安装完成后,设置Nginx服务启动脚本,配置服务器块,启动Nginx服务。 **四、Nginx 配置文件详解** Nginx 的配置文件通常位于`/etc/nginx/nginx.conf`,主要包含以下部分: 1. **全局块**: 设置...

    nginx-1.17.2.zip

    10. **热更新与重载**:Nginx支持在线热更新配置,通过`nginx -s reload`命令无需重启服务即可应用新的配置,减少了服务中断的可能性。 在Nginx-1.17.2的压缩包中,用户通常会找到以下文件和目录: - `sbin/nginx`:...

    nginx-1.10.3.tar.gz

    6. **管理服务**:在大多数Linux发行版中,你可以使用`systemctl`命令来管理Nginx服务,如启动、停止、重启等: ``` sudo systemctl start nginx sudo systemctl stop nginx sudo systemctl restart nginx ``` ...

    linux centos jdk,mysql,gitlab,docker,nginx-lua安装手册

    本手册将详细讲解在Linux CentOS系统上安装与配置Java JDK、MySQL数据库、GitLab代码管理工具、Docker容器化平台以及Nginx-Lua模块的过程。 1. **Java JDK安装**: - JDK(Java Development Kit)是Java编程语言的...

    nginx-1.11.11.tar.gz

    6. **启动与管理**:通过命令行启动、停止、重启Nginx服务。 7. **错误排查**:当Nginx无法正常启动或运行时,检查错误日志来定位问题。 总之,Nginx-1.11.11.tar.gz是一个包含了Nginx服务器源码的压缩包,通过...

    nginx-1.20.1.zip

    总之,Nginx 1.20.1在Linux环境下的安装和配置涉及多步骤,包括解压源码、编译安装、添加启动脚本等。了解其主要功能和配置方法,有助于运维人员高效地管理Web服务。在实际应用中,根据需求调整配置,可以实现更复杂...

    nginx-rtmp搭建rtmp流媒体服务

    在大多数Linux发行版中,可以通过包管理器安装nginx和nginx-rtmp模块。以Ubuntu为例,执行以下命令: ```bash sudo apt-get update sudo apt-get install nginx ``` 然后,从GitHub下载nginx-rtmp源码并编译安装:...

    nginx-1.15.3.tar.gz

    在Linux环境下,要安装和使用Nginx-1.15.3,你需要按照以下步骤操作: 1. **解压源代码**: 首先,你需要将下载的`nginx-1.15.3.tar.gz`解压。在终端中,使用`cd`命令切换到下载文件所在的目录,然后执行: ``` ...

    nginx-1.11.4.tar.gz

    "nginx-1.11.4.tar.gz"是Nginx的源码包,版本为1.11.4,它采用tar和gzip两种工具进行压缩,通常在Linux或类Unix系统中使用,便于开发者下载、解压和编译安装。 1. **Nginx的特性** - **事件驱动模型**:Nginx采用...

    nginx-1.22.1.tar.gz安装包

    安装完成后,Nginx的启动脚本通常位于`/usr/local/nginx/sbin`目录下。你可以使用`nginx`命令启动服务: ``` /usr/local/nginx/sbin/nginx ``` 要停止或重启Nginx,使用`nginx -s stop`或`nginx -s reload`命令...

Global site tag (gtag.js) - Google Analytics