zcl_ccc 发表于 2018-11-8 07:38:11

LNMP环境相关配置Nginx-kindy个人博客

  LNMP环境搭建已经在上一篇文章记录了。本篇主要记录相关的配置,如Nginx、php
  Nginx配置:
  1. 默认虚拟主机
  Nginx的默认虚拟主机的概念和httpd的类似,第一个被nginx加载的虚拟主机就睡默认虚拟主机。不同的是,nginx可以标记默认虚拟主机,如果没有标记则第一个就是默认的;
  修改主配置文件nginx.conf,在结束符号 } 上面加入一行配置,如下:
  include vhost/*.conf;
  }

  意思是/usr/local/nginx/conf/vhost/下面的所有以.conf结尾的文件都会加载,这样我们只需把虚拟主机文件放在vhost目录下就行了



  创建测试文件:
  echo "Nginx默认虚拟主机" > /data/nginx/default.com/index.html

  2. 用户认证
  新建一个虚拟主机:
  cd /usr/local/nginx/conf/vhost
  vim test.com.conf

  使用httpd的htpasswd命令:


  windows下测试的效果:

  对目录进行用户认证:

  3. 域名重定向
server  
{
  
    listen 80;
  
    server_name test1.com test2.com;
  
    index index.htm index.html index.php;
  
    root /data/nginx/test1.com;
  
    # 域名重定向
  
    if ($host != 'test1.com'){
  
      rewrite ^/(.*)$ http://test1.com/$1 permanent;
  
    }
  
}

  4. Nginx的访问日志
  Nginx日志格式定义在配置文件里:

  vim test.com.conf,在server里面添加一行内容即可!


  nginx日志切割需要编写脚本实现:
vim /usr/local/sbin/nginx_log_rorate.log.sh  
#!/bin/bash
  
d=`date -d "-1 day" +%Y%m%d`
  
logdir="/data/logs"
  
nginx_pid="/usr/local/nginx/logs/nginx.pid"
  
cd $logdir
  
for log in `ls *.log`
  
do
  
    mv $log $log-$d
  
done
  
/bin/kill -HUP `cat $nginx_pid`
  写完脚本,还需要增加任务计划:
  0 0 * * * /bin/bash /usr/local/sbin/nginx_log_rorate.log.sh
  5. 配置静态文件不记录日志并添加过期时间
  vim test.com.conf


  查看日志文件:(没有记录!)

  6. Nginx防盗链
  vim test.com.conf

  测试:

  7. 访问控制(主允许192.168.159.131和127.0.0.1 访问等!)

  8. Nginx解析php(经常出现502错误!查看fastcgi_passwd是否和php-fpm服务监听一致)

  9. Nginx代理
  vim /usr/local/nginx/conf/vhost/proxy.conf

  或者这样:

  10. Nginx配置SSL
  SSL工作流程:
  浏览器发送一个https的请求给服务器;
  服务器要有一套数字证书,可以自己制作(后面的操作就是阿铭自己制作的证书),也可以向组织申请,区别就是自己颁发的证书需要客户端验证通过,才可以继续访问,而使用受信任的公司申请的证书则不会弹出>提示页面,这套证书其实就是一对公钥和私钥;
  服务器会把公钥传输给客户端;
  客户端(浏览器)收到公钥后,会验证其是否合法有效,无效会有警告提醒,有效则会生成一串随机数,并用收到的公钥加密;
  客户端把加密后的随机字符串传输给服务器;
  服务器收到加密随机字符串后,先用私钥解密(公钥加密,私钥解密),获取到这一串随机数后,再用这串随机字符串加密传输的数据(该加密为对称加密,所谓对称加密,就是将数据和私钥也就是这个随机字符串>通过某种算法混合在一起,这样除非知道私钥,否则无法获取数据内容);
  服务器把加密后的数据传输给客户端;
  客户端收到数据后,再用自己的私钥也就是那个随机字符串解密;
  HTTPS通信过程:

  生成SSL密钥对:


  php-fpm配置:
  1. php-fpm的pool
  vim /usr/local/php-fpm/etc/php-fpm.conf





  2. php-fpm的慢执行日志
  vim /usr/local/php-fpm/etc/php-fpm.d/www.conf

  3. php-fpm定义open_basedir
  php_admin_value=/data/nginx/wap.com:/tmp/
  4. php-fpm进程管理
  pm = dynamic//动态进程管理,也可以是static
  pm.max_children = 50 //最大子进程数,ps aux可以查看
  pm.start_servers = 20 //启动服务时会启动的进程数
  pm.min_spare_servers = 5 //定义在空闲时段,子进程数的最少数量,如果达到这个数值时,php-fpm服务会自动派生新的子进程。
  pm.max_spare_servers = 35 //定义在空闲时段,子进程数的最大值,如果高于这个数值就开始清理空闲的子进程。
  pm.max_requests = 500//定义一个子进程最多处理的请求数,也就是说在一个php-fpm的子进程最多可以处理这么多请求,当达到这个数值时,它会自动退出。


页: [1]
查看完整版本: LNMP环境相关配置Nginx-kindy个人博客