Openresty 简介

Openresty是一个基于NGINX和Lua的高性能Web平台,内部有大量的Lua库和第三方模块,能够很方便的搭建处理高并发,扩展性高的Web平台和动态网关,充分利用 Nginx 的非阻塞 I/O 模型,不仅仅对 HTTP 客户端请求,甚至于对远程后端诸如 MySQL、PostgreSQL、Memcached 以及 Redis 等都进行一致的高性能响应。

Openresty 安装

1. 依赖包安装:

# yum install readline-devel pcre-devel openssl-devel

2.  在系统中添加openresty的仓库:

# sudo yum install yum-utils

# sudo yum-config-manager --add-repo https://openresty.org/package/centos/openresty.repo

3.  开始安装openresty

# sudo yum install openresty

# sudo yum install openresty-resty  (注:这个是openresty的命令工具包)

4. 以上安装完成后Openresty就安装完成了,默认安装目录在/usr/local/openresty下

Openresty下nginx配置

  1. /usr/local/openresty/nginx/conf下nginx.conf文件配置:

创建NGINX用户:

#groupadd nginx

#useradd -g nginx -s /sbin/nologin -M nginx

以下是配置文件内容:

###########################################

user  nginx nginx;  #启动用户

worker_processes  4; #nginx的进程数,建议和cpu核数一致

#error_log  logs/error.log;

#error_log  logs/error.log  notice;

#error_log  logs/error.log  info;

error_log  logs/error.log warn; #全局LOG定义

pid        logs/nginx.pid; # 进程文件ID

worker_rlimit_nofile 65535; #nginx进程打开的文件数

#工作模式与连接数配置

events {

use epoll; # epoll是高版本内核优化后的网络I/O模型

worker_connections  65535; #单个进程最大连接数

multi_accept on; #打开快速接收新连接

}

#http服务设置

http {

include       mime.types;#文件扩展名与类型映射表

default_type  application/octet-stream;#默认文件类型

charset utf-8;#默认编码

server_names_hash_bucket_size 128; #服务器名字的hash表大小

client_header_buffer_size 32k; #上传文件大小限制

large_client_header_buffers 4 32k; #设定请求缓存数

client_max_body_size 32m; #设定请求缓存大小

#include proxy.conf;

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

#resolver 8.8.8.8;

sendfile        on; #开启高效文件传输

tcp_nopush     on; #防止网络阻塞

tcp_nodelay on;

#keepalive_timeout  0;

keepalive_timeout  30; #长连接超时时间,默认单位秒

####解决跨域问题(我们服务中已有跨域功能所以我这里已全注释)###########

#add_header Access-Control-Allow-Origin *;

#add_header Access-Control-Allow-Headers X-Requested-With,Content-Type,If-Modified-Since;

#add_header Access-Control-Allow-Methods GET,POST,OPTIONS;

#以下是FastCGI 的相关参数,主要作用减少资源占用优化网站性能提高访问速度

fastcgi_connect_timeout 300;

fastcgi_send_timeout 300;

fastcgi_read_timeout 300;

fastcgi_buffer_size 64k;

fastcgi_buffers 4 64k;

fastcgi_busy_buffers_size 128k;

fastcgi_temp_file_write_size 64k;

  • open_file_cache max=10240 inactive=20s;
  • open_file_cache_min_uses 1;
  • open_file_cache_valid 30s;

#gizp优化配置,加速传速

gzip on;

gzip_min_length 1k;

gzip_buffers 4 16k;

gzip_http_version 1.0;

gzip_comp_level 2;

gzip_types text/plain application/x-javascript text/css application/xml;

gzip_vary on;

gzip_disable msie6;

lua_package_path "/usr/local/openresty/nginx/lua/?.lua;;"; #需要用到lua的项目脚本设用路径

# 虚拟主机配置我这定义到了/usr/local/openresty/nginx/conf/vhosts目录下

include vhosts/*.conf;

}

#####################################################################

  1. 虚拟主机文件的配置

以bizapi.xx.com的/usr/local/openresty/nginx/conf/vhosts /bizapi.conf反向代理配置为例:

以下是配置文件内容:

###########################################

server

{

listen       80;

server_name  bizapi.xx.com;

location /api/BasicService/authBaseService/ {        #要做反向代理转发的路径

proxy_redirect          off;

proxy_set_header        Host $host;

proxy_set_header        X-Real-IP $remote_addr;  #获取真实ip

proxy_set_header       X-Forwarded-For   $proxy_add_x_forwarded_for; #获取代理者的真实ip

add_header X-Frame-Options SAMEORIGIN;

client_max_body_size    10m; #允许客户端请求字节数

client_body_buffer_size 128k; #缓冲区代理请求最字节数

proxy_connect_timeout   90; #后端服务器超进间间

proxy_send_timeout      90; #后端服务器数据传回时间

proxy_read_timeout      90; #后端服务器的响应时间

proxy_buffer_size       128k; #代理服务器保存的用户头信息缓冲区大小

proxy_buffers           2 256k; #缓冲区设置,网页平均在256K以下设

proxy_busy_buffers_size 256k; #高并发下缓存大小

proxy_temp_file_write_size 256k; #设定文件大小限制

proxy_pass http://192.168.102.47:9002; #要转发到的地址与端口配置

}

location /api/sas/recoManageService/ {

proxy_redirect          off;

proxy_set_header        Host $host;

proxy_set_header        X-Real-IP $remote_addr;  #获取真实ip

proxy_set_header       X-Forwarded-For   $proxy_add_x_forwarded_for; #获取代理者的真实ip

add_header X-Frame-Options SAMEORIGIN;

client_max_body_size    10m;

client_body_buffer_size 128k;

proxy_connect_timeout   90;

proxy_send_timeout      90;

proxy_read_timeout      90;

proxy_buffer_size       128k;

proxy_buffers           2 256k;

proxy_busy_buffers_size 256k;

proxy_temp_file_write_size 256k;

proxy_pass http://192.168.102.47:9031;

}

location /api/sas/paymManageService/ {

proxy_redirect          off;

proxy_set_header        Host $host;

proxy_set_header        X-Real-IP $remote_addr;  #获取真实ip

proxy_set_header       X-Forwarded-For   $proxy_add_x_forwarded_for; #获取代理者的真实ip

add_header X-Frame-Options SAMEORIGIN;

client_max_body_size    10m;

client_body_buffer_size 128k;

proxy_connect_timeout   90;

proxy_send_timeout      90;

proxy_read_timeout      90;

proxy_buffer_size       128k;

proxy_buffers           2 256k;

proxy_busy_buffers_size 256k;

proxy_temp_file_write_size 256k;

proxy_pass http://192.168.102.47:9032;

}

location /api/sas/invoManageService/ {

proxy_redirect          off;

proxy_set_header        Host $host;

proxy_set_header        X-Real-IP $remote_addr;  #获取真实ip

proxy_set_header       X-Forwarded-For   $proxy_add_x_forwarded_for; #获取代理者的真实ip

add_header X-Frame-Options SAMEORIGIN;

client_max_body_size    10m;

client_body_buffer_size 128k;

proxy_connect_timeout   90;

proxy_send_timeout      90;

proxy_read_timeout      90;

proxy_buffer_size       128k;

proxy_buffers           2 256k;

proxy_busy_buffers_size 256k;

proxy_temp_file_write_size 256k;

proxy_pass http://192.168.102.47:9033;

}

location /api/receiptPay/sapSyncManageService/ {

proxy_redirect          off;

proxy_set_header        Host $host;

proxy_set_header        X-Real-IP $remote_addr;  #获取真实ip

proxy_set_header       X-Forwarded-For   $proxy_add_x_forwarded_for; #获取代理者的真实ip

add_header X-Frame-Options SAMEORIGIN;

client_max_body_size    10m;

client_body_buffer_size 128k;

proxy_connect_timeout   90;

proxy_send_timeout      90;

proxy_read_timeout      90;

proxy_buffer_size       128k;

proxy_buffers           2 256k;

proxy_busy_buffers_size 256k;

proxy_temp_file_write_size 256k;

proxy_pass http://192.168.102.47:9036;

}

location /api/receiptPay/receiptManageService/ {

proxy_redirect          off;

proxy_http_version 1.1;

proxy_set_header Connection "";

proxy_set_header        Host $host;

proxy_set_header        X-Real-IP $remote_addr;  #获取真实ip

proxy_set_header       X-Forwarded-For   $proxy_add_x_forwarded_for; #获取代理者的真实ip

add_header X-Frame-Options SAMEORIGIN;

client_max_body_size    10m;

client_body_buffer_size 128k;

proxy_connect_timeout   90;

proxy_send_timeout      90;

proxy_read_timeout      90;

proxy_buffer_size       128k;

proxy_buffers           2 256k;

proxy_busy_buffers_size 256k;

proxy_temp_file_write_size 256k;

proxy_pass http://192.168.102.47:9034;

}

location /api/receiptPay/payManageService/ {

proxy_redirect          off;

proxy_set_header        Host $host;

proxy_set_header        X-Real-IP $remote_addr;  #获取真实ip

proxy_set_header       X-Forwarded-For   $proxy_add_x_forwarded_for; #获取代理者的真实ip

add_header X-Frame-Options SAMEORIGIN;

client_max_body_size    10m;

client_body_buffer_size 128k;

proxy_connect_timeout   90;

proxy_send_timeout      90;

proxy_read_timeout      90;

proxy_buffer_size       128k;

proxy_buffers           2 256k;

proxy_busy_buffers_size 256k;

proxy_temp_file_write_size 256k;

proxy_pass http://192.168.102.47:9035;

}

location /api/assignment/ {

proxy_redirect          off;

proxy_set_header        Host $host;

proxy_set_header        X-Real-IP $remote_addr;  #获取真实ip

proxy_set_header       X-Forwarded-For   $proxy_add_x_forwarded_for; #获取代理者的真实ip

add_header X-Frame-Options SAMEORIGIN;

client_max_body_size    10m;

client_body_buffer_size 128k;

proxy_connect_timeout   90;

proxy_send_timeout      90;

proxy_read_timeout      90;

proxy_buffer_size       128k;

proxy_buffers           2 256k;

proxy_busy_buffers_size 256k;

proxy_temp_file_write_size 256k;

proxy_pass http://139.224.147.71:9050;

}

#access_log  logs/bizapi.log  access;

}

###############################################################

  1. 启动命令:

对配置文件进行更改后我们再启动时先检查配置文件的语法是否正确:

# openresty  –t

返回以下情况说明配置没问题:

启动nginx:

# openresty -s reload

如果在启动时出现以下报错:

nginx: [error] invalid PID number "" in "/usr/local/openresty/nginx/logs/nginx.pid"

那我们就需要重新定义一下nginx.conf的指定

# /usr/local/openresty/nginx/sbin/nginx  -c  /usr/local/openresty/nginx/conf/nginx.conf

  1. 关于nginx的log切割:

对于nginx的处理,我这里是写了一个shell脚本加上crontab做定时任务来实现的,相关脚本如下:

#############################################

#定义变量

LOGS_PATH=/usr/local/openresty/nginx/logs

YESTERDAY=$(date -d "yesterday" +%Y%m%d)

#按天切割日志

mv ${LOGS_PATH}/access.log ${LOGS_PATH}/access_${YESTERDAY}.log

mv ${LOGS_PATH}/error.log ${LOGS_PATH}/error_${YESTERDAY}.log

#向nginx主进程发送USR1信号,重新打开日志文件,否则会继续往mv后的文件写数据的。原因在于:linux系统中,内核是根据文件描述符来找文件的。如果不这样操作导致日志切割失败。

kill -USR1 `ps axu | grep "nginx: master process" | grep -v grep | awk '{print $2}'`

#删除7天前的日志

cd ${LOGS_PATH}

find . -mtime +7 -name "*20[1-9][3-9]*" | xargs rm -f

#或者根据你定义的log名进行处理

#find . -mtime +7 -name "xx.com_*" | xargs rm -f

exit 0

##############################################

  1. 添加定时执行命令:

#nginx cut log

59 23 * * * sh   /usr/local/openresty/nginx/cutlog.sh

Openresty安装及使用配置(OPENRESTY+NGINX)的更多相关文章

  1. Nginx 安装与部署配置以及Nginx和uWSGI开机自启

    下载 官方网站:https://nginx.org/en/download.html Windows下安装 安装 下载后解压(切记不能含有中文路径!!),文件结构如图(我解压的路径就有中文,记得拷贝放 ...

  2. 烂泥:php5.6源码安装及php-fpm配置与nginx集成

    本文由秀依林枫提供友情赞助,首发于烂泥行天下. LNMP环境的搭建中,现在只有php没有源码安装过.这篇文章就把这个介绍下. 注意本篇文章使用的centos 6.5 64bit. 登陆centos下载 ...

  3. 【精选】Nginx负载均衡学习笔记(一)实现HTTP负载均衡和TCP负载均衡(官方和OpenResty两种负载配置)

    说明:很简单一个在HTTP模块中,而另外一个和HTTP 是并列的Stream模块(Nginx 1.9.0 支持) 一.两个模块的最简单配置如下 1.HTTP负载均衡: http { include m ...

  4. OpenResty入门之使用Lua扩展Nginx

    记住一点:nginx配置文件很多坑来源自你的空格少了或多了. 1.Centos下载安装 如果你的系统是 Centos 或 RedHat 可以使用以下命令: yum install readline-d ...

  5. openresty安装文档

    一.OpenResty简介    OpenResty是一个基于 Nginx与 Lua的高性能 Web平台,其内部集成了大量精良的 Lua 库.第三方模块以及大多数的依赖项.用于方便地搭建能够处理超高并 ...

  6. OpenResty入门之使用Lua开发Nginx插件

    记住一点:nginx配置文件很多坑来源自你的空格少了或多了. OpenResty OpenResty 是一个基于 Nginx 与 Lua 的高性能 Web 平台,其内部集成了大量精良的 Lua 库.第 ...

  7. OpenResty 安装配置

    0. 说明 1. Windows 下安装 下载软件包 openresty-1.13.6.1-win32.zip ,解压即可食用. [开启] 直接运行 nginx.exe 在 Windows 的命令窗口 ...

  8. openresty安装配置 Ubuntu下

    1.进入openresty-1.11.2.4的压缩包木木,我这里是在“/usr/local/”下: 2.进入后执行[tar -xzvf openresty-1.11.2.4.tar.gz]进行解压 3 ...

  9. OpenResty安装使用教程(CentOS 6)

    一.安装OpenResty Linux官方建议直接通过官方提供的预编译包安装:http://openresty.org/cn/linux-packages.html # 确保yum周边工具已经安装 y ...

随机推荐

  1. 前后端分离djangorestframework——ContentType组件表

    ContentType ContentType其实django自带的,但是平时的话很少会用到,所以还是放在Djangorestframework这个部分 作用: 在实际的开发中,由于数据库量级大,所以 ...

  2. SQL Server -- 回忆笔记(五):T-SQL编程,系统变量,事务,游标,触发器

    SQL Server -- 回忆笔记(五):T-SQL编程,系统变量,事务,游标,触发器 1. T-SQL编程 (1)声明变量 declare @age int (2)为变量赋值 (3)while循环 ...

  3. c/c++ 多线程 绕过mutex的保护

    多线程 绕过mutex的保护 mutex,能够解决线程安全的问题,但它不是万能的.下面的例子虽然使用了mutex,但是恶意注入了一个外部函数,导致把被mutex保护的双向链表,让一个外部的指针指向了, ...

  4. 搭建Jetbrains家族IDE授权服务器

    虽然VS号称宇宙第一IDE但是也有不方便的地方,如果你也是C#码农我不得不向你推荐一个强大的插件ReSharper,他会是你的开发更加便捷,大大加快了开发的速度以及开发的乐趣.但是ReSharper并 ...

  5. django 创建admin用户名跟密码

    一.django中创建用户名和密码 (venv) D:\project\py37project\Djangopro\Procrm>Python37 manage.py createsuperus ...

  6. Python开发【socket篇】解决粘包

    客户端 import os import json import struct import socket sk = socket.socket() sk.connect(('127.0.0.1',8 ...

  7. centos7下kubernetes(11。kubernetes-运行一次性任务)

    容器按照持续运行的时间可以分为两类:服务类容器和工作类容器 服务类容器:持续提供服务 工作类容器:一次性任务,处理完后容器就退出 Deployment,replicaset和daemonset都用于管 ...

  8. (九)Delete an Index

    Now let’s delete the index that we just created and then list all the indexes again: 现在让我们删除刚刚创建的索引, ...

  9. fliplr函数

    fliplr  左右翻转矩阵 语法: B = fliplr(A) 将矩阵A的列绕垂直轴进行左右翻转 matabc 如果A是一个行向量,fliplr(A)将A中元素的顺序进行翻转. 如果A是一个列向量, ...

  10. 移除Windows图标快捷方式小箭头

    以管理员身份运行cmd,输入 reg delete "HKEY_CLASSES_ROOT\lnkfile" /v IsShortcut /f & taskkill /f / ...