此前稍微提过,用nginx里面执行lua脚本,可以执行一些原有无法实现的必须到后端去控制。目前有个需求,是根据不同的传入id,判断其类型,反向代理到不同的项目后端,如果是采用后端来做的话,基本上很难去实现,然而我们在前端用lua去判断ID的类型就OK了,为了保证前端nginx的速度,所以将id的类型存入redis中,由lua去读取redis的数据进行id类型判断。
目前,用在nginx中用lua读取redis的数据有两套方案,一套是用lua自身的redis-client库,一套是采用nginx的redis模块。为了保证性能和可靠性,我们采用lua去用subprocess调用nginx的redis模块进行读取,由于nginx的redis模块只是单纯的做数据的插入和读取,并没有做redis协议的解析,所以,我们如果要使用的话,还必须加lua的redis-parse进行解析数据协议。
如何安装nginx+lua的环境此前已经有文章介绍过了,这里就不在阐述,接下来只需要在该基础上,编译进多两个模块(set-misc-nginx-module,redis2-nginx-module)即可。
定义redis连接池(1024个固定连接):