02_Nginx基本配置与参数说明 + 辅助命令



Nginx基本配置与参数说明,下面是nginx.conf配置文件

#运行用户

#user  nobody;

worker_processes  2;

 

#全局错误日志及PID文件

#error_log  logs/error.log;

#error_log  logs/error.log  notice;

#error_log  logs/error.log  info;

 

#pid        logs/nginx.pid;

 

#工作模式及连接数上限

events {

    #epoll是多路复用IOI/O Multiplexing)中的一种方式

    #仅用于linux2.6以上内核,可以大大提高nginx的性能

    #use epoll

 

    #单个后台worker process进程的最大并发链接数

    worker_connections  1024;

 

    #并发总数是worker_processesworker_connections的成绩

    #max_clients = worker_process * worker_connections

    #在设置了反向代理的情况下,max_clients = woker_processes * worker_connections / 4

    #为什么上面的方向代理要除以4,应该说是一个经验值

    #根据以上条件,正常情况下的Nginx Server可以应付的最大连接为:4 * 8000 = 32000

    #woker_connections值的设置跟物理内存大小有关

    #因为并发受IO约束,max_clients的值须小于系统可以打开的最大文件数

    #而系统可以打开的最大文件数和内存大小成正比,一般1GB内存的机器上可以打开的文件数大约是10左右

    #我们来看看360M内存的VPS可以打开的文件句柄数是多少:

    #$ cat /proc/sys/fs/file-max

    #输出 34336 (我的是287464

    #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;

 

    #开启gzip压缩

    gzip  on;

    gzip_disable "MSIE [1-6].";

 

    #设定请求缓冲

    client_header_buffer_size  128k;

    large_client_header_buffers 4 128k;

 

    #设置虚拟机主机配置

    server {

        listen       80;

        #定义使用www.nginx.cn访问

        #server_name www.nginx.cn;

        server_name  localhost;

 

        #定义服务器的默认网站根目录的访问日志

        #root html;

 

        #charset koi8-r;

 

        #设定本虚拟主机的访问日志

        #access_log  logs/host.access.log  main;

 

        #在我的电脑上有:[root@localhost some]# pwd example.html

        #/data/www/some

        #

        #如果按照下面的配置,在浏览器上输入:http://192.168.6.26/some/example.html

        #这时候浏览器中可以看到页面内容

        location / {

            root   /data/www;

        }

 

        #在我的电脑

        #[root@localhost images]#

        #[root@localhost images]# pwd

        #/data/images

        #[root@localhost images]# ls

        #test.png

        #[root@localhost images]#

        #

        #在浏览器中输入:http://192.168.6.26/images/test.png,在页面中可以看到图片

         location /images/ {

            root /data;

        }

 

        #error_page  404              /404.html;

 

        # redirect server error pages to the static page /50x.html

        # 定义错误提示页面

        error_page   500 502 503 504  /50x.html;

        location = /50x.html {

            root   html;

        }

       

        #静态文件,nginx自己处理

        location ~ ^/(images|javascript|js|css|flash|media|static)/ {

             #过期30天,静态文件不怎么更新,过期可以设大一点

             #如果频繁更新,则可以设置得小一点

             expires 30d;

        }

 

        # 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

        #

        #禁止访问,htxxx文件

        #location ~ /\.ht {

        #    deny  all;

        #}

    }

 

    server {

         location / {

               proxy_pass http://192.168.6.26:8080;

         }    

 

         #表示只要是这些歌文件就转到/data/images

         location ~ \.(gif|jpg|png)$ {

              root /data/images;

         }

    }

 

 

    # 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  localhost;

 

    #    ssl_certificate      cert.pem;

    #    ssl_certificate_key  cert.key;

 

    #    ssl_session_cache    shared:SSL:1m;

    #    ssl_session_timeout  5m;

 

    #    ssl_ciphers  HIGH:!aNULL:!MD5;

    #    ssl_prefer_server_ciphers  on;

 

    #    location / {

    #        root   html;

    #        index  index.html index.htm;

    #    }

    #}

}

2 辅助知识点:

#总核数 = 物理CPU个数 * 每颗物理CPU的核数

#总逻辑CPU = 物理CPU个数 * 每颗物理CPU的核数 * 超线程数

 

#查看物理CPU个数(以下是我虚拟机中的信息):

[root@localhost ~]# cat /proc/cpuinfo |grep "physical id" | sort | uniq | wc -l

1

 

#查看每个物理CPU中的core的个数

[root@localhost ~]# cat /proc/cpuinfo |grep "cpu cores" | uniq

cpu cores :2

 

查看逻辑物理CPU的个数

[root@localhost ~]# cat /proc/cpuinfo| grep"processor"| wc -l

2

 

查看CPU信息(型号)

[root@localhost ~]# cat /proc/cpuinfo |grep name | cut -f2 -d: | uniq -c

     2  Intel(R) Core(TM) i5-3230M CPU@ 2.60GHz

 

查看内存信息

[root@localhost ~]# cat /proc/meminfo

 

 
  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 打赏
    打赏
  • 0
    评论
好的,我知道你的问题了。针对你的问题,我可以给你一些简单的部署步骤: 1.安装nginx和PHP 在CentOS 6.8中安装nginx和PHP的方式如下: ``` sudo yum install nginx sudo yum install php-fpm ``` 2.配置nginx配置nginx之前,你需要备份一下默认的nginx配置文件。备份命令如下: ``` sudo cp /etc/nginx/nginx.conf /etc/nginx/nginx.conf.bak ``` 然后,你可以通过编辑/etc/nginx/nginx.conf文件来配置nginx。 下面是一个简单的nginx配置示例,可以将它添加到/etc/nginx/nginx.conf文件中: ``` user nginx; worker_processes auto; error_log /var/log/nginx/error.log; pid /run/nginx.pid; events { worker_connections 1024; } http { include /etc/nginx/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 /var/log/nginx/access.log main; sendfile on; keepalive_timeout 65; include /etc/nginx/conf.d/*.conf; server { listen 80; server_name localhost; root /usr/share/nginx/html; index index.php index.html index.htm; location / { try_files $uri $uri/ /index.php; } location ~ \.php$ { try_files $uri =404; fastcgi_pass unix:/var/run/php-fpm/php-fpm.sock; fastcgi_index index.php; fastcgi_param SCRIPT_FILENAME $document_root$fastcgi_script_name; include fastcgi_params; } } } ``` 在这个示例配置中,我们将nginx的根目录设置为/usr/share/nginx/html,并且将index.php添加到默认文档列表中。同时,我们还配置了一个location块,用于处理PHP文件。 3.配置PHP 在配置PHP之前,你需要备份一下默认的php-fpm配置文件。备份命令如下: ``` sudo cp /etc/php-fpm.d/www.conf /etc/php-fpm.d/www.conf.bak ``` 然后,你可以通过编辑/etc/php-fpm.d/www.conf文件来配置PHP。 下面是一个简单的PHP配置示例,可以将它添加到/etc/php-fpm.d/www.conf文件中: ``` [www] user = nginx group = nginx listen = /var/run/php-fpm/php-fpm.sock listen.owner = nginx listen.group = nginx pm = dynamic pm.max_children = 50 pm.start_servers = 5 pm.min_spare_servers = 5 pm.max_spare_servers = 35 ``` 在这个示例配置中,我们将PHP-FPM的用户和组设置为nginx,并将PHP-FPM的监听套接字设置为/var/run/php-fpm/php-fpm.sock。 4.重启服务 完成配置后,你需要重启nginx和php-fpm服务,以使配置生效。重启命令如下: ``` sudo systemctl restart nginx sudo systemctl restart php-fpm ``` 到这里,就完成了nginx+PHP的简单部署。同时,为了进一步提升性能,你可以使用Nginx+PHP+FastCGI加速模式。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

涂作权的博客

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值