zoukankan      html  css  js  c++  java
  • Linux环境nginx的配置

    1.创建nginx运行账户www并加入到www组,不允许www用户直接登录系统,查看创建。

    groupadd www
    useradd -g www www -s /bin/false
    tail /etc/passwd

    2.进入nginx的配置文件目录

    cd /usr/local/nginx/conf

    3.看一下目录下文件

    ll

    4.编辑配置文件nginx.conf,可以一项一项配置使用【/usr/local/nginx/sbin/nginx -t】查看是否配置出错。

    vi nginx.conf

      4.1、上边创建了用户,#user nobody 打开注释,修改为user www www

      4.2、worker_processes 2; #设置值和CPU核心数一致

      4.3、error_log定义错误日志文件的位置及输出级别【debug / info / notice / warn / error / crit】

    error_log  /usr/local/nginx/logs/error.log error;
    user  www www;#用来指定nginx worker进程运行用户以及用户组,默认nobody账号运行
    worker_processes  1;#指定nginx要开启的子进程数量,运行过程中监控每个进程消耗内存(一般几M~几十M不等)根据实际情况进行调整,通常数量是CPU内核数量的整数倍
    
    #定义错误日志文件的位置及输出级别【debug / info / notice / warn / error / crit】
    error_log  /usr/local/nginx/logs/error.log error;
    #error_log  logs/error.log  notice;
    #error_log  logs/error.log  info;
    
    #用来指定进程id的存储文件的位置
    #pid        logs/nginx.pid;
    
    #用于指定一个进程可以打开最多文件数量的描述
    worker_rlimit_nofile 1024;
    
    #针对nginx服务器的工作模式的一些操作配置
    events {
        worker_connections  1024;#指定最大可以同时接收的连接数量,这里一定要注意,最大连接数量是和worker processes共同决定的
        multi_accept on;#配置指定nginx在收到一个新连接通知后尽可能多的接受更多的连接
        use epoll;#配置指定了线程轮询的方法,如果是linux2.6+,使用epoll,如果是BSD如Mac请使用Kqueue
    }
    
    
    http {
        include       mime.types;#指定在当前文件中包含另一个文件的指令
        default_type  application/octet-stream;#指定默认处理的文件类型可以是二进制
    
        log_format  main  '$remote_addr - $remote_user [$time_local] "$request" '
                          '$status $body_bytes_sent "$http_referer" '
                          '"$http_user_agent" "$http_x_forwarded_for"';
    
        access_log  /usr/local/nginx/logs/access.log  main;##用于指定该虚拟主机服务器中的访问记录日志存放路径,main是上边log_format定义的格式
    
        sendfile        on;#配置on让sendfile发挥作用,将文件的回写过程交给数据缓冲去去完成,而不是放在应用中完成,这样的话在性能提升有有好处
        tcp_nopush     on;#让nginx在一个数据包中发送所有的头文件,而不是一个一个单独发
        tcp_nodelay on;#让nginx不要缓存数据,而是一段一段发送,如果数据的传输有实时性的要求的话可以配置它,发送完一小段数据就立刻能得到返回值,但是不要滥用哦
    
    
        #keepalive_timeout  0;
        keepalive_timeout  65;#给客户端分配连接超时时间,服务器会在这个时间过后关闭连接。一般设置时间较短,可以让nginx工作持续性更好
        client_header_timeout 10;#设置请求头的超时时间
        client_body_timeout 10;#设置请求体的超时时间
        send_timeout 10;#指定客户端响应超时时间,如果客户端两次操作间隔超过这个时间,服务器就会关闭这个链接
    
        limit_conn_zone $binary_remote_addr zone=addr:5m;#设置用于保存各种key的共享内存的参数,
        limit_conn addr 100; #给定的key设置最大连接数
    
        gzip  on;#是告诉nginx采用gzip压缩的形式发送数据。这将会减少我们发送的数据量
        gzip_disable "msie6";#为指定的客户端禁用gzip功能。我们设置成IE6或者更低版本以使我们的方案能够广泛兼容
        gzip_types text/plain text/css application/json application/javascript text/xml application/xml application/xml+rss text/javascript;
    
    
        #主要负责负载均衡的配置,通过默认的轮询调度方式来分发请求到后端服务器
        #-- max_fails:表示失败最大次数,超过失败最大次数暂停服务
        #-- fail_timeout:表示如果请求受理失败,暂停指定的时间之后重新发起请求
        upstream nginxServer {
            ip_hash;#指定请求调度算法,默认是weight权重轮询调度,可以指定
            server localhost:8000 max_fails=3 fail_timeout=3s;#可以用localhost,调用同一台服务器上server,也可以用ip或域名,代理其他服务器
            server 60.110.110.60:8001 down;#表示该主机暂停服务
            server 60.110.110.60:8002 max_fails=3 fail_timeout=3s;
            server 60.110.110.60:8003 max_fails=3 fail_timeout=3s;
            server 60.110.110.60:8004 max_fails=3 fail_timeout=3s;
            server 60.110.110.60:8005 max_fails=3 fail_timeout=3s;
        }
    
    
        server {
            listen       80;
            server_name www.xxx.cn;#指定ip地址或者域名,多个配置之间用空格分隔
    
            charset utf-8;
    
            #access_log  logs/host.access.log  main;
    
            #location / {
            #    root   html;
            #    index  index.html index.htm;
            #    proxy_pass http://nginxServer/;
            #    proxy_set_header Host $host;
            #    proxy_set_header X-Real-IP $remote_addr;
            #    proxy_set_header X-Forwarded-For $proxy_add_x_forwarded_for;
            #}
    
            #error_page  404              /404.html;#用于指定该虚拟主机服务器中访问错误日志的存放路径
    
            rewrite ^(.*)$ https://$host$1 permanent;#强制http访问https端口。如果不用https协议注掉
            
            # redirect server error pages to the static page /50x.html
            #
            error_page   500 502 503 504  /50x.html;
            location = /50x.html {
                root   html;
            }
    
            # proxy the PHP scripts to Apache listening on 127.0.0.1:80
            #
            #location ~ .php$ {
            #    proxy_pass   http://127.0.0.1;
            #}
    
            # pass the PHP scripts to FastCGI server listening on 127.0.0.1:9000
            #
            #location ~ .php$ {
            #    root           html;
            #    fastcgi_pass   127.0.0.1:9000;
            #    fastcgi_index  index.php;
            #    fastcgi_param  SCRIPT_FILENAME  /scripts$fastcgi_script_name;
            #    include        fastcgi_params;
            #}
    
            # deny access to .htaccess files, if Apache's document root
            # concurs with nginx's one
            #
            #location ~ /.ht {
            #    deny  all;
            #}
        }
      
        # another virtual host using mix of IP-, name-, and port-based configuration
        #
        #server {
        #    listen       8000;
        #    listen       somename:8080;
        #    server_name  somename  alias  another.alias;
    
        #    location / {
        #        root   html;
        #        index  index.html index.htm;
        #    }
        #}
    
    
        # HTTPS server
        
        server {
            listen       443 ssl;
            server_name  www.xxx.cn;
    
            ssl_certificate      cert/www.xxx.cn.pem;
            ssl_certificate_key  cert/www.xxx.cn.key;
    
            ssl_session_cache    shared:SSL:1m;
            ssl_session_timeout  5m;
    
            ssl_ciphers ECDHE-RSA-AES128-GCM-SHA256:ECDHE:ECDH:AES:HIGH:!NULL:!aNULL:!MD5:!ADH:!RC4;
            ssl_protocols TLSv1 TLSv1.1 TLSv1.2;
            ssl_prefer_server_ciphers  on;
    
            location / {
                root   html;
                index  index.html index.htm;
                proxy_pass http://nginxServer/;
                proxy_set_header Host $host;
                proxy_set_header X-Real-IP $remote_addr;
                proxy_set_header X-Forwarded-For $proxy_add_x_forwarded_for;
            }
        }
    
    }

    5.启动

    /usr/local/nginx/sbin/nginx

    6.重新加载

    /usr/local/nginx/sbin/nginx -s reload

    7.重启

    /usr/local/nginx/sbin/nginx -s reopen

    8.停止

    /usr/local/nginx/sbin/nginx -s stop

     9.设置开机启动

    vi /etc/init.d/nginx
    #! /bin/bash
    # chkconfig: - 85 15
    PATH=/usr/local/nginx
    DESC="nginx daemon"
    NAME=nginx
    DAEMON=$PATH/sbin/$NAME
    CONFIGFILE=$PATH/conf/$NAME.conf
    PIDFILE=$PATH/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() {
    $DAEMON -s stop || echo -n "nginx not running"
    }
    do_reload() {
    $DAEMON -s reload || 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

    将上方脚本代码cp到vi的nginx文件中,修改其中的PATH路径改为自己的安装路径。

    然后授权

    chmod a+x /etc/init.d/nginx
    /etc/init.d/nginx start
    /etc/init.d/nginx stop
    
    chkconfig --add /etc/init.d/nginx
    
    service nginx start
    service nginx stop
    
    chkconfig nginx on
    chkconfig nginx off
  • 相关阅读:
    groovy Date 格式化
    MySql Delete不走索引问题
    java解析文件
    H5自动准备杂记
    ubuntu 安装php ,apache 问题总结
    git 添加已被忽略的文件夹
    jenkins + nodejs + git 自动化部署前端
    分享到微信填坑之路
    jenkins 自动化部署php
    natapp 穿透访问 vue项目 Invalid Host header
  • 原文地址:https://www.cnblogs.com/jinzhiming/p/8603595.html
Copyright © 2011-2022 走看看