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

[经验分享] 神奇的Nginx之常用设置

[复制链接]

尚未签到

发表于 2018-11-16 10:19:40 | 显示全部楼层 |阅读模式
引言
  nginx软件十分小巧,较其竞争对手Apache而言,nginx可以实现的功能更为丰富,配置更为简单。Nginx采用多线程方式,对服务器内存大小要求不像apache那些高,此外其处理静态网页的速率、并发的访问量方面等都要比apache出色的多。目前越来越多的国内公司都开始使用nginx来代替apache搭建网站架构。本文介绍了部分常用nginx配置(核心代码)。

默认虚拟主机
  nginx可以实现配置文件的模块化分离,每个配置文件都是一个独立的虚拟主机。
  

[root@localhost default]# vim /usr/local/nginx/conf/vhost/test.com.conf  
server
  
{
  # 将该虚拟主机设置为默认虚拟主机
  listen 80 default_server;
  # 设置服务器的名称
  server_name default.com;
  # 设置服务器默认网页
  index index.html index.htm index.php;
  # 设置服务器的根目录
  root /data/www/default;
  
}
  

用户认证


  • 核心代码
  

    # 对目录  location /admin
  {
  auth_basic "User Auth";
  auth_basic_user_file /usr/local/nginx/conf/htpasswd;
  }
  # 对文件,可以直接写文件名,也可以是正则表示
  # ~ 匹配,~*模糊匹配(忽略大小写)
  location ~ .*\.php$
  {
  auth_basic "User Auth";
  auth_basic_user_file /usr/local/nginx/conf/htpasswd;
  }
  

域名重定向
  实现老站点向新站点域名的重定向
  

server  
{
  listen 80;
  # nginx可以配置多个主机名,apache只能使用ServerAlias来指定别名
  # nginx中哪个主机名在前,就是默认使用的主机名
  server_name test.com test2.com;
  index index.html index.htm index.php;
  root /data/www/test.com;
  # 判断host是否为test.com
  # permanent及返回状态码301,永久重定向
  if ($host != 'test.com') {
  rewrite ^/(.*)$ http://test.com/$1 permanent;
  }
  
}
  

访问日志
  

# 在nginx主配置文件nginx.conf内添加一下代码即可  
log_format test '$remote_addr $http_x_forwarded_for [$time_local]'
  ' $host "$request_uri" $status'
  ' "$http_referer" "$http_user_agent"';
  

  
# 设置好日志格式后,在虚拟主机内的server块内使用
  
access_log /tmp/test.com.log test;
  

  
# 如果某些情况下不需要记录日志,代码如下
  
access_log off;
  

静态文件不记录访问日志
  对于nginx静态文件访问日志不记录设置而言十分简单,其核心代码即expires time;
  

# 对不同的文件设置不同的过期时间  
# 过期时间单位可以是m/h/d等
  
location ~ .*\.(gif|jpg|jpeg|png|bmp|swf)$
  {
  expires 7d;
  }
  
location ~ .*\.(css|js)$
  {
  expires 12h;
  }
  

防盗链
  

location ~* .*\.(gif|jpg|png|swf|flv|rar|zip|doc|pdf|gz|bz2|jpeg|bmp|xls)$  {
  # 白名单可以是多个域名,域名间使用空格间隔开
  valid_referers none blocked server_names *.test.com;
  # 条件判断,非白名单域名返回403状态码即禁止访问forbidden;
  if ($invalid_referer) {
  return 403;
  }
  }
  

访问控制
  

# 对于目录  
location /admin/
  
{
  # nginx中没有apache里的order命令,按代码先后顺序执行
  # nginx中只要有一条规则匹配,后续规则就不会进行匹配
  # 允许本机
  allow 127.0.0.1;
  allow 192.168.65.133;
  # 禁止其他所有ip
  deny all;
  
}
  
# 针对文件
  
location ~ .*(upload|admin)/.*\.php$
  
{
  deny all;
  
}
  
# 针对user_agent
  
location /
  
{
  if ($http_user_agent ~ 'Spider/3.0|YoudaoBot|Tomato')
  {
  return 403; //等价于deny all;
  }
  
}
  

php文件解析
  

location ~ \.php$  {
  include fastcgi_params;
  # fastcgi_pass参数可以使用ip、sock
  # fastcgi_pass 127.0.0.1:9000;
  fastcgi_pass unix:/tmp/php-fcgi.sock;
  fastcgi_index index.php;
  fastcgi_param SCRIPT_FILENAME /data/www/test.com$fastcgi_script_name;
  }
  

  nginx还可以实现更多更有用的功能,这些知识点不是短短一篇博客就可以将去清楚的,本文基本上时nginx服务器基本功能实现的简单代码配置,日常生活工作中还是需要根据具体的需求还进行配置。



运维网声明 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.yunweiku.com/thread-635699-1-1.html 上篇帖子: rhel 6.4 安装 nginx-1.9.9.tar-13479442 下篇帖子: Centos6.7安装nginx-1.11.10-centos6使用xtrabackup-51CTO博客
您需要登录后才可以回帖 登录 | 立即注册

本版积分规则

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

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

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

扫描微信二维码查看详情

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


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


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


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



合作伙伴: 青云cloud

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