19
OpenResty ሴᴺኞ [email protected] ṛᚆਫ᪢

OpenResty [ Ô - O'Reillyvelocity.oreilly.com.cn/2015/ppts/openresty_best... · 2017-12-18 · C1K -> C10K -> C10M C1K ASP FastCGI Php Python JAVA C10K Nginx-Lua(OpenResty) 5Golang

  • Upload
    others

  • View
    5

  • Download
    0

Embed Size (px)

Citation preview

Page 1: OpenResty [ Ô - O'Reillyvelocity.oreilly.com.cn/2015/ppts/openresty_best... · 2017-12-18 · C1K -> C10K -> C10M C1K ASP FastCGI Php Python JAVA C10K Nginx-Lua(OpenResty) 5Golang

OpenResty

[email protected]

Page 2: OpenResty [ Ô - O'Reillyvelocity.oreilly.com.cn/2015/ppts/openresty_best... · 2017-12-18 · C1K -> C10K -> C10M C1K ASP FastCGI Php Python JAVA C10K Nginx-Lua(OpenResty) 5Golang

“ "

• Visual Studio C++

• APP(IOS)

• Win

• Linux

2014

Page 3: OpenResty [ Ô - O'Reillyvelocity.oreilly.com.cn/2015/ppts/openresty_best... · 2017-12-18 · C1K -> C10K -> C10M C1K ASP FastCGI Php Python JAVA C10K Nginx-Lua(OpenResty) 5Golang
Page 4: OpenResty [ Ô - O'Reillyvelocity.oreilly.com.cn/2015/ppts/openresty_best... · 2017-12-18 · C1K -> C10K -> C10M C1K ASP FastCGI Php Python JAVA C10K Nginx-Lua(OpenResty) 5Golang

OpenResty

Page 5: OpenResty [ Ô - O'Reillyvelocity.oreilly.com.cn/2015/ppts/openresty_best... · 2017-12-18 · C1K -> C10K -> C10M C1K ASP FastCGI Php Python JAVA C10K Nginx-Lua(OpenResty) 5Golang

and

Page 6: OpenResty [ Ô - O'Reillyvelocity.oreilly.com.cn/2015/ppts/openresty_best... · 2017-12-18 · C1K -> C10K -> C10M C1K ASP FastCGI Php Python JAVA C10K Nginx-Lua(OpenResty) 5Golang

• 100K QPS

• 2014 : 38 100

• 1

• 100 /38/60=4385K/100K=43.8

Page 7: OpenResty [ Ô - O'Reillyvelocity.oreilly.com.cn/2015/ppts/openresty_best... · 2017-12-18 · C1K -> C10K -> C10M C1K ASP FastCGI Php Python JAVA C10K Nginx-Lua(OpenResty) 5Golang

-•

• 100K QPS

• SQL

• KV

• Redis HandleSocket Memcached SSDB

Page 8: OpenResty [ Ô - O'Reillyvelocity.oreilly.com.cn/2015/ppts/openresty_best... · 2017-12-18 · C1K -> C10K -> C10M C1K ASP FastCGI Php Python JAVA C10K Nginx-Lua(OpenResty) 5Golang
Page 9: OpenResty [ Ô - O'Reillyvelocity.oreilly.com.cn/2015/ppts/openresty_best... · 2017-12-18 · C1K -> C10K -> C10M C1K ASP FastCGI Php Python JAVA C10K Nginx-Lua(OpenResty) 5Golang

C1K -> C10K -> C10MC1K ASP FastCGI Php Python JAVA

C10K Nginx-Lua(OpenResty) Golang Node.js Python(AIO) JAVA Netty Rust

C10K C100K C1MOpenResty

C10M DPDKAPI

Page 10: OpenResty [ Ô - O'Reillyvelocity.oreilly.com.cn/2015/ppts/openresty_best... · 2017-12-18 · C1K -> C10K -> C10M C1K ASP FastCGI Php Python JAVA C10K Nginx-Lua(OpenResty) 5Golang

OpenResty

Nginx+LuaJIT

Web Server

Page 11: OpenResty [ Ô - O'Reillyvelocity.oreilly.com.cn/2015/ppts/openresty_best... · 2017-12-18 · C1K -> C10K -> C10M C1K ASP FastCGI Php Python JAVA C10K Nginx-Lua(OpenResty) 5Golang

NginxNginx Igor Sysoev

• F5

• F5

• linux epoll windows: select freebsd: kqueue

• Windows iocp

ngx c module

Page 12: OpenResty [ Ô - O'Reillyvelocity.oreilly.com.cn/2015/ppts/openresty_best... · 2017-12-18 · C1K -> C10K -> C10M C1K ASP FastCGI Php Python JAVA C10K Nginx-Lua(OpenResty) 5Golang

LuaJIT• Lua

• C

• cache

• Lua 5.1

• FFI C CPU API win/ linux

• Mike Pall

Page 13: OpenResty [ Ô - O'Reillyvelocity.oreilly.com.cn/2015/ppts/openresty_best... · 2017-12-18 · C1K -> C10K -> C10M C1K ASP FastCGI Php Python JAVA C10K Nginx-Lua(OpenResty) 5Golang

OpenResty

• Github Nginx(Tengine)

• API Server WinCentos Ubuntu

• 100% NONBLOCK

• API Nginx +PHP

• c module: ngx_redis2 5000

• lua: resty-redis 460

Page 14: OpenResty [ Ô - O'Reillyvelocity.oreilly.com.cn/2015/ppts/openresty_best... · 2017-12-18 · C1K -> C10K -> C10M C1K ASP FastCGI Php Python JAVA C10K Nginx-Lua(OpenResty) 5Golang

OpenResty• C Level IPC

• bug

• API

Page 15: OpenResty [ Ô - O'Reillyvelocity.oreilly.com.cn/2015/ppts/openresty_best... · 2017-12-18 · C1K -> C10K -> C10M C1K ASP FastCGI Php Python JAVA C10K Nginx-Lua(OpenResty) 5Golang

• Mac OS X winLinux+Docker

• Win2003 / Vista / Win7 / Win8 / Win2008 / Win2012 / centos 6.* 7.* /Ubuntu 14.* /Redhat/SUSE

• beta 5 CPU 8GBDocker CPU 8% QPS

3-5 Docker CPU 100%

Page 16: OpenResty [ Ô - O'Reillyvelocity.oreilly.com.cn/2015/ppts/openresty_best... · 2017-12-18 · C1K -> C10K -> C10M C1K ASP FastCGI Php Python JAVA C10K Nginx-Lua(OpenResty) 5Golang

HTTP 2.0 HTTP 2.0

• WAF reload

• nginx-lua-tcp-server

• jsonrpc memcached just for fun

Page 17: OpenResty [ Ô - O'Reillyvelocity.oreilly.com.cn/2015/ppts/openresty_best... · 2017-12-18 · C1K -> C10K -> C10M C1K ASP FastCGI Php Python JAVA C10K Nginx-Lua(OpenResty) 5Golang

• OpenRestyOpenResty

• wiki

Page 18: OpenResty [ Ô - O'Reillyvelocity.oreilly.com.cn/2015/ppts/openresty_best... · 2017-12-18 · C1K -> C10K -> C10M C1K ASP FastCGI Php Python JAVA C10K Nginx-Lua(OpenResty) 5Golang

iresty.com

AdobeCloudFlare

Page 19: OpenResty [ Ô - O'Reillyvelocity.oreilly.com.cn/2015/ppts/openresty_best... · 2017-12-18 · C1K -> C10K -> C10M C1K ASP FastCGI Php Python JAVA C10K Nginx-Lua(OpenResty) 5Golang

[email protected]

“what’s your question?”