Centos 7 上 Nginx安装

版权声明:本文为博主原创文章,未经博主允许不得转载。 https://blog.csdn.net/supingemail/article/details/79615086

好记忆不如烂笔头,能记下点东西,就记下点,有时间拿出来看看,也会发觉不一样的感受。

Nginx 安装

系统平台:CentOS release 7.4 (Final) 64位。

一、安装编译工具及库文件

yum -y install make zlib zlib-devel gcc-c++ libtool  openssl openssl-devel

二、首先要安装 PCRE

PCRE 作用是让 Nginx 支持 Rewrite 功能。

1、下载 PCRE 安装包,下载地址: http://downloads.sourceforge.net/project/pcre/pcre/8.35/pcre-8.35.tar.gz

[root@bogon src]# wget http://downloads.sourceforge.net/project/pcre/pcre/8.35/pcre-8.35.tar.gz

2、解压安装包:

[root@bogon src]# tar zxvf pcre-8.35.tar.gz

3、进入安装包目录

[root@bogon src]# cd pcre-8.35

4、编译安装 

[root@bogon pcre-8.35]# ./configure
[root@bogon pcre-8.35]# make && make install

5、查看pcre版本

[root@bogon pcre-8.35]# pcre-config --version


 安装 OpenSSL  安装 library.

[root@bogon pcre-8.35]# yum -y install openssl openssl-devel 
    

安装 Nginx

1、下载 Nginx,下载地址:http://nginx.org/download/nginx-1.6.2.tar.gz

[root@bogon src]# wget http://nginx.org/download/nginx-1.6.2.tar.gz

2、解压安装包

[root@bogon src]# tar zxvf nginx-1.6.2.tar.gz

3、进入安装包目录

[root@bogon src]# cd nginx-1.6.2

4、编译安装

[root@bogon nginx-1.6.2]# ./configure --prefix=/usr/local/nginx/nginx-1.6.2 --with-http_stub_status_module --with-http_ssl_module --with-pcre=/usr/local/nginx/pcre-8.35
[root@bogon nginx-1.6.2]# make
[root@bogon nginx-1.6.2]# make install

5、查看nginx版本

[root@bogon nginx-1.6.2]# /usr/local/nginx/nginx-1.6.2/sbin/nginx -v

到此,nginx安装完成。


Nginx 配置

创建 Nginx 运行使用的用户 www: (可以不用建设)

[root@bogon conf]# /usr/sbin/groupadd www 
[root@bogon conf]# /usr/sbin/useradd -g www www

配置nginx.conf ,将 :  /usr/local/nginx/nginx-1.6.2/conf/nginx.conf替换为以下内容

[root@bogon conf]#  vim /usr/local/nginx/nginx-1.6.2/conf/nginx.conf

#运行用户
user nobody;
#user  nobody;


#启动进程,通常设置成和cpu的数量相等
worker_processes  1;


##全局错误日志及PID文件,如果没有logs目录 和 nginx.pid 没有,要记得手动创建.
error_log /usr/local/nginx/nginx-1.6.2/logs/nginx_error.log debug; 
#error_log  logs/error.log;
#error_log  logs/error.log  notice;
#error_log  logs/error.log  info;
   
## pid 地址.
pid /usr/local/nginx/nginx-1.6.2/nginx.pid;


#pid   logs/nginx.pid;
## ## 最大连接数据
worker_rlimit_nofile 65535;


###工作模式及连接数上限
events {
    ## epoll是多路复用IO(I/O Multiplexing)中的一种方式,
    ## 仅用于linux2.6以上内核,可以大大提高nginx的性能
    use epoll;
    ##单个后台worker process进程的最大并发链接数  
    worker_connections  1024;


        ## 并发总数是 worker_processes 和 worker_connections 的乘积
        ## 即 max_clients = worker_processes * worker_connections
        ## 在设置了反向代理的情况下,max_clients = worker_processes * worker_connections / 4  为什么
        ## 为什么上面反向代理要除以4,应该说是一个经验值
        ## 我们来看看360M内存的VPS可以打开的文件句柄数是多少:
        ## $ cat /proc/sys/fs/file-max
        ## 输出 34336
        ## 使得并发总数小于操作系统可以打开的最大文件数目
        ## 其实质也就是根据主机的物理CPU和内存进行配置
        ## 因为并发受IO约束,max_clients的值须小于系统可以打开的最大文件数
        ## 而系统可以打开的最大文件数和内存大小成正比,一般1GB内存的机器上可以打开的文件数大约是10万左右
        ## 我们来看看360M内存的VPS可以打开的文件句柄数是多少:
        ## $ cat /proc/sys/fs/file-max
        ## 输出 34336
        ## 32000 < 34336,即并发连接总数小于系统可以打开的文件句柄总数,这样就在操作系统可以承受的范围之内
        ## 所以,worker_connections 的值需根据 worker_processes 进程数目和系统可以打开的最大文件总数进行适当地进行设置
        ## 使得并发总数小于操作系统可以打开的最大文件数目
        ## 其实质也就是根据主机的物理CPU和内存进行配置
        ## 当然,理论上的并发总数可能会和实际有所偏差,因为主机还有其他的工作进程需要消耗系统资源。
        ## ulimit -SHn 65535


}


http {


    #设定mime类型,类型由mime.type文件定义
    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  logs/access.log  main;


    #sendfile 指令指定 nginx 是否调用 sendfile 函数(zero copy 方式)来输出文件,
    #对于普通应用,必须设为 on,
    #如果用来进行下载等应用磁盘IO重负载应用,可设置为 off,
    #以平衡磁盘与网络I/O处理速度,降低系统的uptime.
    sendfile     on;
    #tcp_nopush     on;


    #连接超时时间
    #keepalive_timeout  0;
    keepalive_timeout  65;
    tcp_nodelay     on;


    #开启gzip压缩
    gzip  on;
    gzip_disable "MSIE [1-6].";


    #设定请求缓冲
    client_header_buffer_size    128k;
    large_client_header_buffers  4 128k;


    #设定虚拟主机配置
    server {
	
        #侦听80端口
        listen    80;
		
        #定义使用 www.nginx.cn访问
        server_name  localhost 118.24.157.96 www.brucego.cn;


        #定义服务器的默认网站根目录位置
        root html;


	#启动页,没有会在页面显示 404 
	#index index.php index.html index.html;
	#访问编码.
	charset utf-8;
		 
        #设定本虚拟主机的访问日志
        access_log  logs/nginx.access.log  main;


        #默认请求
        location / {
            
            #定义首页索引文件的名称
            index index.php index.html index.htm;   


        }


        # 定义错误提示页面
        error_page   500 502 503 504 /50x.html;
		
        location = /50x.html {
			
        }


        #静态文件,nginx自己处理
        location ~ ^/(images|javascript|js|css|flash|media|static)/ {
            
            #过期30天,静态文件不怎么更新,过期可以设大一点,
            #如果频繁更新,则可以设置得小一点。
            expires 30d;
        }


        #PHP 脚本请求全部转发到 FastCGI处理. 使用FastCGI默认配置.
        location ~ .php$ {
            fastcgi_pass 127.0.0.1:9000;
            fastcgi_index index.php;
            fastcgi_param  SCRIPT_FILENAME  $document_root$fastcgi_script_name;
            include fastcgi_params;
        }


        #禁止访问 .htxxx 文件
            location ~ /.ht {
            deny all;
        }
    }
}

检查配置文件ngnix.conf的正确性命令:

[root@bogon conf]# /usr/local/nginx/nginx-1.6.2/sbin/nginx -t

启动 Nginx

Nginx 启动命令如下:

[root@bogon conf]# /usr/local/nginx/nginx-1.6.2/sbin/nginx

访问站点

从浏览器访问我们配置的站点ip:


CentOS 7 开机启动Nginx

sudo systemctl enable nginx.service

Linux查看公网IP

您可以运行以下命令来显示你的服务器的公共IP地址:

ip addr show eth0 | grep inet | awk '{ print $2; }' | sed 's/\/.*$//'

Nginx 其他命令

以下包含了 Nginx 常用的几个命令:

/usr/local/nginx/nginx-1.6.2/sbin/nginx -s reload            # 重新载入配置文件
/usr/local/nginx/nginx-1.6.2/sbin/nginx -s reopen            # 重启 Nginx
/usr/local/nginx/nginx-1/6/2/sbin/nginx -s stop              # 停止 Nginx
学习学习 :https://www.cnblogs.com/zhouxinfei/p/7862285.html

猜你喜欢

转载自blog.csdn.net/supingemail/article/details/79615086