设为首页 收藏本站
查看: 628|回复: 0

[经验分享] nginx 配置文件例子

[复制链接]

尚未签到

发表于 2016-12-24 10:54:10 | 显示全部楼层 |阅读模式
  第一种配置
  nginx 上传最大限制为1M,如果有上传文件功能注意修改上传最大值。

#user  nobody;
worker_processes  1;
#error_log  logs/error.log;
#error_log  logs/error.log  notice;
#error_log  logs/error.log  info;
#pid        logs/nginx.pid;

events {
worker_connections  1024;
}
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  logs/access.log  main;
sendfile        on;
#tcp_nopush     on;
#keepalive_timeout  0;
keepalive_timeout  65;
#gzip  on;
#配置 多domain

upstream baidu{
ip_hash;
server 127.0.0.1:8088; #
}
#---会计网 start---
server{
listen  80;
charset utf-8;
#access_log  logs/access.www.baidu.com.log;
location / {
proxy_pass              http://baidu;
proxy_buffer_size 64k;
proxy_buffers 4 64k;
proxy_redirect    off;
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.htm;
# redirect server error pages to the static page /50x.html
#
error_page   500 502 503 504  /50x.html;
location = /50x.html {
root   html;
}
#程序会根据你访问的域名找到相应的 代理“proxy_pass”->upstream  然后找到服务器的地址和转向端口
server_name www.baidu.com;
#error_log logs/error.www.baidu.com.log;
}
#---会计网 end---

#server {
#listen       80;
#server_name  localhost;
#charset koi8-r;
#access_log  logs/host.access.log  main;
#location / {
#root   html;
#index  index.html index.htm index.jsp;
#}
#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;
#}
# 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;
#    server_name  localhost;
#    ssl                  on;
#    ssl_certificate      cert.pem;
#    ssl_certificate_key  cert.key;
#    ssl_session_timeout  5m;
#    ssl_protocols  SSLv2 SSLv3 TLSv1;
#    ssl_ciphers  HIGH:!aNULL:!MD5;
#    ssl_prefer_server_ciphers   on;
#    location / {
#        root   html;
#        index  index.html index.htm;
#    }
#}
}
  第二种配置(网上摘取)

worker_processes 8;   
error_log /usr/local/webserver/nginx/logs/nginx_error.log crit;   
pid /usr/local/webserver/nginx/nginx.pid;   
#Specifies the value for maximum file descriptors that can be opened by this process.   
worker_rlimit_nofile 65535;   
events   
{   
use epoll;   
worker_connections 65535;   
}   
http   
{   
include mime.types;   
default_type application/octet-stream;   
charset utf-8;   
server_names_hash_bucket_size 128;   
client_header_buffer_size 32k;   
large_client_header_buffers 4 32k;   
client_max_body_size 300m;  # 上传文件最大限制,如果不配置的话小文件可以上传 大点文件就上传不了
sendfile on;   
tcp_nopush on;   
keepalive_timeout 60;   
tcp_nodelay on;   
client_body_buffer_size 512k;   
proxy_connect_timeout 5;   
proxy_read_timeout 60;   
proxy_send_timeout 5;   
proxy_buffer_size 16k;   
proxy_buffers 4 64k;   
proxy_busy_buffers_size 128k;   
proxy_temp_file_write_size 128k;   
gzip on;   
gzip_min_length 1k;   
gzip_buffers 4 16k;   
gzip_http_version 1.1;   
gzip_comp_level 2;   
gzip_types text/plain application/x-javascript text/css application/xml;   
gzip_vary on;   
#注:proxy_temp_path和proxy_cache_path指定的路径必须在同一分区   
proxy_temp_path /data0/proxy_temp_dir;   
#设置Web缓存区名称为cache_one,内存缓存空间大小为200MB,1天清理一次缓存,硬盘缓存空间大小为30GB。   
proxy_cache_path /data0/proxy_cache_dir levels=1:2 keys_zone=cache_one:200m inactive=1d max_size=30g;   
upstream backend_server {   
server 192.168.8.43:80 weight=1 max_fails=2 fail_timeout=30s;   
server 192.168.8.44:80 weight=1 max_fails=2 fail_timeout=30s;   
server 192.168.8.45:80 weight=1 max_fails=2 fail_timeout=30s;   
}   
server   
{   
listen 80;   
server_name www.yourdomain.com 192.168.8.42;   
index index.html index.htm;   
root /data0/htdocs/www;   
location /   
{   
#如果后端的服务器返回502、504、执行超时等错误,自动将请求转发到upstream负载均衡池中的另一台服务器,实现故障转移。   
proxy_next_upstream http_502 http_504 error timeout invalid_header;   
proxy_cache cache_one;   
#对不同的HTTP状态码设置不同的缓存时间   
proxy_cache_valid 200 304 12h;   
#以域名、URI、参数组合成Web缓存的Key值,Nginx根据Key值哈希,存储缓存内容到二级缓存目录内   
proxy_cache_key $host$uri$is_args$args;   
proxy_set_header Host $host;   
proxy_set_header X-Forwarded-For $remote_addr;   
proxy_pass http://backend_server;   
expires 1d;   
}   
#用于清除缓存,假设一个URL为http://192.168.8.42/test.txt,通过访问http://192.168.8.42/purge/test.txt就可以清除该URL的缓存。   
location ~ /purge(/.*)   
{   
#设置只允许指定的IP或IP段才可以清除URL缓存。   
allow 127.0.0.1;   
allow 192.168.0.0/16;   
deny all;   
proxy_cache_purge cache_one $host$1$is_args$args;   
}   
#扩展名以.php、.jsp、.cgi结尾的动态应用程序不缓存。   
location ~ .*\.(php|jsp|cgi)?$   
{   
proxy_set_header Host $host;   
proxy_set_header X-Forwarded-For $remote_addr;   
proxy_pass http://backend_server;   
}   
access_log off;   
}   
}

运维网声明 1、欢迎大家加入本站运维交流群:群②:261659950 群⑤:202807635 群⑦870801961 群⑧679858003
2、本站所有主题由该帖子作者发表,该帖子作者与运维网享有帖子相关版权
3、所有作品的著作权均归原作者享有,请您和我们一样尊重他人的著作权等合法权益。如果您对作品感到满意,请购买正版
4、禁止制作、复制、发布和传播具有反动、淫秽、色情、暴力、凶杀等内容的信息,一经发现立即删除。若您因此触犯法律,一切后果自负,我们对此不承担任何责任
5、所有资源均系网友上传或者通过网络收集,我们仅提供一个展示、介绍、观摩学习的平台,我们不对其内容的准确性、可靠性、正当性、安全性、合法性等负责,亦不承担任何法律责任
6、所有作品仅供您个人学习、研究或欣赏,不得用于商业或者其他用途,否则,一切后果均由您自己承担,我们对此不承担任何法律责任
7、如涉及侵犯版权等问题,请您及时通知我们,我们将立即采取措施予以解决
8、联系人Email:admin@iyunv.com 网址:www.yunweiku.com

所有资源均系网友上传或者通过网络收集,我们仅提供一个展示、介绍、观摩学习的平台,我们不对其承担任何法律责任,如涉及侵犯版权等问题,请您及时通知我们,我们将立即处理,联系人Email:kefu@iyunv.com,QQ:1061981298 本贴地址:https://www.iyunv.com/thread-318771-1-1.html 上篇帖子: 搭建nginx的负载均衡 下篇帖子: puppet系列之nginx+foreman
您需要登录后才可以回帖 登录 | 立即注册

本版积分规则

扫码加入运维网微信交流群X

扫码加入运维网微信交流群

扫描二维码加入运维网微信交流群,最新一手资源尽在官方微信交流群!快快加入我们吧...

扫描微信二维码查看详情

客服E-mail:kefu@iyunv.com 客服QQ:1061981298


QQ群⑦:运维网交流群⑦ QQ群⑧:运维网交流群⑧ k8s群:运维网kubernetes交流群


提醒:禁止发布任何违反国家法律、法规的言论与图片等内容;本站内容均来自个人观点与网络等信息,非本站认同之观点.


本站大部分资源是网友从网上搜集分享而来,其版权均归原作者及其网站所有,我们尊重他人的合法权益,如有内容侵犯您的合法权益,请及时与我们联系进行核实删除!



合作伙伴: 青云cloud

快速回复 返回顶部 返回列表