OpenResty 高阶实战之————Redis授权登录使用短连接(5000)和长连接(500W) 使用连接池AB压力测试结果
一、短连接开始测试
ab -n 5000 -c 100 -k 127.0.0.1/test_redis_short
#demo1
Concurrency Level:
Time taken for tests: 0.745 seconds
Complete requests:
Failed requests:
Keep-Alive requests:
Total transferred: bytes
HTML transferred: bytes
Requests per second: 6708.13 [#/sec] (mean)
Time per request: 14.907 [ms] (mean)
Time per request: 0.149 [ms] (mean, across all concurrent requests)
Transfer rate: 1434.65 [Kbytes/sec] received
#demo2
Concurrency Level:
Time taken for tests: 0.697 seconds
Complete requests:
Failed requests:
Keep-Alive requests:
Total transferred: bytes
HTML transferred: bytes
Requests per second: 7177.65 [#/sec] (mean)
Time per request: 13.932 [ms] (mean)
Time per request: 0.139 [ms] (mean, across all concurrent requests)
Transfer rate: 1535.06 [Kbytes/sec] received
ab -n 10000 -c 100 -k 127.0.0.1/test_redis_short
#demo1
Concurrency Level:
Time taken for tests: 1.211 seconds
Complete requests:
Failed requests:
Keep-Alive requests:
Total transferred: bytes
HTML transferred: bytes
Requests per second: 8256.17 [#/sec] (mean)
Time per request: 12.112 [ms] (mean)
Time per request: 0.121 [ms] (mean, across all concurrent requests)
Transfer rate: 1765.50 [Kbytes/sec] received
#demo2 比较卡
Concurrency Level:
Time taken for tests: 17.364 seconds
Complete requests:
Failed requests:
Keep-Alive requests:
Total transferred: bytes
HTML transferred: bytes
Requests per second: 575.90 [#/sec] (mean)
Time per request: 173.643 [ms] (mean)
Time per request: 1.736 [ms] (mean, across all concurrent requests)
Transfer rate: 123.15 [Kbytes/sec] received
ab -n 20000 -c 100 -k 127.0.0.1/test_redis_short
#demo1
Concurrency Level:
Time taken for tests: 19.374 seconds
Complete requests:
Failed requests:
(Connect: , Receive: , Length: , Exceptions: )
Keep-Alive requests:
Total transferred: bytes
HTML transferred: bytes
Requests per second: 1032.32 [#/sec] (mean)
Time per request: 96.869 [ms] (mean)
Time per request: 0.969 [ms] (mean, across all concurrent requests)
Transfer rate: 220.66 [Kbytes/sec] received
Nginx CPU内存情况

ab -n 30000 -c 100 -k 127.0.0.1/test_redis_short
#demo1
Concurrency Level:
Time taken for tests: 50.960 seconds
Complete requests:
Failed requests:
(Connect: , Receive: , Length: , Exceptions: )
Keep-Alive requests:
Total transferred: bytes
HTML transferred: bytes
Requests per second: 588.69 [#/sec] (mean)
Time per request: 169.867 [ms] (mean)
Time per request: 1.699 [ms] (mean, across all concurrent requests)
Transfer rate: 123.09 [Kbytes/sec] received
Nginx CPU内存情况

短连接一旦-n 大于 10000 ,nginx 刚开始直接100%,但是redis-server 负载相对较小,以下是 -n = 40000
Requests per second: 1105.62 [#/sec] (mean)

第二次 -n = 40000 测试结果
Requests per second: 933.82 [#/sec] (mean)

总结:
使用短连接一开始nginx 负载就满载100% ,太可怕了,但是redis-server 负载相对较小,(30000--->100%) 、(20000--->90%)、(10000--->70~90%),测试数据显示,安全最大连接在5000 以内
二、长连接开始测试
ab -n 5000 -c 100 -k 127.0.0.1/test_redis_long
#demo1
Concurrency Level:
Time taken for tests: 0.289 seconds
Complete requests:
Failed requests:
Keep-Alive requests:
Total transferred: bytes
HTML transferred: bytes
Requests per second: 17322.98 [#/sec] (mean)
Time per request: 5.773 [ms] (mean)
Time per request: 0.058 [ms] (mean, across all concurrent requests)
Transfer rate: 3501.81 [Kbytes/sec] received
#demo2
Concurrency Level:
Time taken for tests: 0.278 seconds
Complete requests:
Failed requests:
Keep-Alive requests:
Total transferred: bytes
HTML transferred: bytes
Requests per second: 17977.46 [#/sec] (mean)
Time per request: 5.563 [ms] (mean)
Time per request: 0.056 [ms] (mean, across all concurrent requests)
Transfer rate: 3634.12 [Kbytes/sec] received
ab -n 10000 -c 100 -k 127.0.0.1/test_redis_long
#demo1
Concurrency Level:
Time taken for tests: 0.670 seconds
Complete requests:
Failed requests:
Keep-Alive requests:
Total transferred: bytes
HTML transferred: bytes
Requests per second: 14927.29 [#/sec] (mean)
Time per request: 6.699 [ms] (mean)
Time per request: 0.067 [ms] (mean, across all concurrent requests)
Transfer rate: 3016.84 [Kbytes/sec] received
#demo2
Concurrency Level:
Time taken for tests: 0.812 seconds
Complete requests:
Failed requests:
Keep-Alive requests:
Total transferred: bytes
HTML transferred: bytes
Requests per second: 12310.57 [#/sec] (mean)
Time per request: 8.123 [ms] (mean)
Time per request: 0.081 [ms] (mean, across all concurrent requests)
Transfer rate: 2488.05 [Kbytes/sec] received
#demo3
Concurrency Level:
Time taken for tests: 0.662 seconds
Complete requests:
Failed requests:
Keep-Alive requests:
Total transferred: bytes
HTML transferred: bytes
Requests per second: 15114.05 [#/sec] (mean)
Time per request: 6.616 [ms] (mean)
Time per request: 0.066 [ms] (mean, across all concurrent requests)
Transfer rate: 3054.85 [Kbytes/sec] received
ab -n 20000 -c 100 -k 127.0.0.1/test_redis_long
#demo1
Concurrency Level:
Time taken for tests: 0.981 seconds
Complete requests:
Failed requests:
Keep-Alive requests:
Total transferred: bytes
HTML transferred: bytes
Requests per second: 20390.39 [#/sec] (mean)
Time per request: 4.904 [ms] (mean)
Time per request: 0.049 [ms] (mean, across all concurrent requests)
Transfer rate: 4121.23 [Kbytes/sec] received
ab -n 30000 -c 100 -k 127.0.0.1/test_redis_long
#demo1
Concurrency Level:
Time taken for tests: 1.392 seconds
Complete requests:
Failed requests:
Keep-Alive requests:
Total transferred: bytes
HTML transferred: bytes
Requests per second: 21556.79 [#/sec] (mean)
Time per request: 4.639 [ms] (mean)
Time per request: 0.046 [ms] (mean, across all concurrent requests)
Transfer rate: 4356.78 [Kbytes/sec] received
ab -n 40000 -c 100 -k 127.0.0.1/test_redis_long
#demo1
Concurrency Level:
Time taken for tests: 1.711 seconds
Complete requests:
Failed requests:
Keep-Alive requests:
Total transferred: bytes
HTML transferred: bytes
Requests per second: 23377.05 [#/sec] (mean)
Time per request: 4.278 [ms] (mean)
Time per request: 0.043 [ms] (mean, across all concurrent requests)
Transfer rate: 4724.64 [Kbytes/sec] received
ab -n 50000 -c 100 -k 127.0.0.1/test_redis_long
#demo1
Concurrency Level:
Time taken for tests: 1.995 seconds
Complete requests:
Failed requests:
Keep-Alive requests:
Total transferred: bytes
HTML transferred: bytes
Requests per second: 25059.81 [#/sec] (mean)
Time per request: 3.990 [ms] (mean)
Time per request: 0.040 [ms] (mean, across all concurrent requests)
Transfer rate: 5064.71 [Kbytes/sec] received
ab -n 100000 -c 100 -k 127.0.0.1/test_redis_long
#demo1
Concurrency Level:
Time taken for tests: 3.613 seconds
Complete requests:
Failed requests:
Keep-Alive requests:
Total transferred: bytes
HTML transferred: bytes
Requests per second: 27676.11 [#/sec] (mean)
Time per request: 3.613 [ms] (mean)
Time per request: 0.036 [ms] (mean, across all concurrent requests)
Transfer rate: 5593.40 [Kbytes/sec] received
ab -n 200000 -c 100 -k 127.0.0.1/test_redis_long
#demo1
Concurrency Level:
Time taken for tests: 7.562 seconds
Complete requests:
Failed requests:
Keep-Alive requests:
Total transferred: bytes
HTML transferred: bytes
Requests per second: 26447.14 [#/sec] (mean)
Time per request: 3.781 [ms] (mean)
Time per request: 0.038 [ms] (mean, across all concurrent requests)
Transfer rate: 5344.99 [Kbytes/sec] received
ab -n 500000 -c 100 -k 127.0.0.1/test_redis_long
#demo1
Concurrency Level:
Time taken for tests: 17.541 seconds
Complete requests:
Failed requests:
Keep-Alive requests:
Total transferred: bytes
HTML transferred: bytes
Requests per second: 28505.36 [#/sec] (mean)
Time per request: 3.508 [ms] (mean)
Time per request: 0.035 [ms] (mean, across all concurrent requests)
Transfer rate: 5760.94 [Kbytes/sec] received
ab -n 1000000 -c 100 -k 127.0.0.1/test_redis_long
#demo1
Concurrency Level:
Time taken for tests: 36.749 seconds
Complete requests:
Failed requests:
Keep-Alive requests:
Total transferred: bytes
HTML transferred: bytes
Requests per second: 27211.29 [#/sec] (mean)
Time per request: 3.675 [ms] (mean)
Time per request: 0.037 [ms] (mean, across all concurrent requests)
Transfer rate: 5499.40 [Kbytes/sec] received
ab -n 1500000 -c 100 -k 127.0.0.1/test_redis_long
#demo1
Concurrency Level:
Time taken for tests: 57.548 seconds
Complete requests:
Failed requests:
Keep-Alive requests:
Total transferred: bytes
HTML transferred: bytes
Requests per second: 26065.16 [#/sec] (mean)
Time per request: 3.837 [ms] (mean)
Time per request: 0.038 [ms] (mean, across all concurrent requests)
Transfer rate: 5267.76 [Kbytes/sec] received
ab -n 2000000 -c 100 -k 127.0.0.1/test_redis_long
#demo1
Concurrency Level:
Time taken for tests: 76.746 seconds
Complete requests:
Failed requests:
Keep-Alive requests:
Total transferred: bytes
HTML transferred: bytes
Requests per second: 26060.04 [#/sec] (mean)
Time per request: 3.837 [ms] (mean)
Time per request: 0.038 [ms] (mean, across all concurrent requests)
Transfer rate: 5266.73 [Kbytes/sec] received
Nginx CPU内存情况

ab -n 2500000 -c 100 -k 127.0.0.1/test_redis_long
#demo1
Concurrency Level:
Time taken for tests: 90.761 seconds
Complete requests:
Failed requests:
Keep-Alive requests:
Total transferred: bytes
HTML transferred: bytes
Requests per second: 27544.95 [#/sec] (mean)
Time per request: 3.630 [ms] (mean)
Time per request: 0.036 [ms] (mean, across all concurrent requests)
Transfer rate: 5566.83 [Kbytes/sec] received
Nginx CPU内存情况

长连接-n = 2500000 ,nginx 刚开始不会超过50%,但是redis-server 负载相对高点,最高在50%左右,测试结果:
Concurrency Level:
Time taken for tests: 93.482 seconds
Complete requests:
Failed requests:
Keep-Alive requests:
Total transferred: bytes
HTML transferred: bytes
Requests per second: 26743.15 [#/sec] (mean)
Time per request: 3.739 [ms] (mean)
Time per request: 0.037 [ms] (mean, across all concurrent requests)
Transfer rate: 5404.78 [Kbytes/sec] received

ab -n 5000000 -c 100 -k 127.0.0.1/test_redis_long
#demo1
Concurrency Level:
Time taken for tests: 221.492 seconds
Complete requests:
Failed requests:
Keep-Alive requests:
Total transferred: bytes
HTML transferred: bytes
Requests per second: 22574.15 [#/sec] (mean)
Time per request: 4.430 [ms] (mean)
Time per request: 0.044 [ms] (mean, across all concurrent requests)
Transfer rate: 4562.23 [Kbytes/sec] received
Nginx CPU内存情况

Completed 2000000 requests 请求截图

Completed 3500000 requests 请求截图 ,这时候的redis-server 负载保持在38%左右

测试到最后AB 压力直接爆掉

(-n---->nginx负载----->redis-server负载---->Requests per second)、
(100000--->37%--->37%---->28303.90) 表示很快完成
(200000--->50%--->56%--->33518.21)
(500000--->67%--->74%--->23959.52) redis-server 不稳定
(1000000--->50%--->50%--->23959.52) 2个都比较稳定,都能够保持在50%以下
总结:
使用长连接,10W 连接时毫无压力的,示,安全最大连接在20W 以内(测试环境可以100W没问题)
1、短连接Nginx负载太高 10000 链接负载直接飙到90+%
三、测试代码
test_long.lua
--[[-----------------------------------------------------------------------
* | Copyright (C) Shaobo Wan (Tinywan)
* | Github: https://github.com/Tinywan
* | Author: Tinywan
* | Date: 2017/5/8 16:25
* | Mail: Overcome.wan@Gmail.com
* |------------------------------------------------------------------------
* | version: 1.0
* | description: redis 长连接带连接池测试
* |------------------------------------------------------------------------
--]]
local redis = require "resty.redis"
local red = redis:new() local ok, err = red:connect("127.0.0.1", )
if not ok then
ngx.say("failed to connect: ", err)
return
end -- auth
local count
count, err = red:get_reused_times()
if == count then
local res, err = red:auth("tinywan123456")
if not res then
ngx.say("failed to authenticate: ", err)
return
end
elseif err then
ngx.say("failed to get_reused_times: ", err)
end ok, err = red:set("dog_test_long", "an animal 222"..ngx.time())
if not ok then
ngx.say("failed to set dog: ", err)
return
end ngx.say("set result: ", ok) local res, err = red:get("dog_test_long")
if not res then
ngx.say("failed to get dog: ", err)
return
end if res == ngx.null then
ngx.say("dog not found.")
return
end ngx.say("dog_test_long: ", res) local ok, err = red:set_keepalive(, )
if not ok then
ngx.say("failed to set keepalive: ", err)
return
end
test_short.lua
--[[-----------------------------------------------------------------------
* | Copyright (C) Shaobo Wan (Tinywan)
* | Github: https://github.com/Tinywan
* | Author: Tinywan
* | Date: 2017/5/8 16:25
* | Mail: Overcome.wan@Gmail.com
* |------------------------------------------------------------------------
* | version: 1.0
* | description: redis 短连接测试
* |------------------------------------------------------------------------
--]]
local redis = require "resty.redis"
local red = redis:new() --red:set_timeout(1000) -- 1 sec -- or connect to a unix domain socket file listened
-- by a redis server:
-- local ok, err = red:connect("unix:/path/to/redis.sock") local ok, err = red:connect("127.0.0.1", )
if not ok then
ngx.say("failed to connect: ", err)
return
end local res, err = red:auth("tinywan123456")
if not res then
ngx.say("failed to authenticate: ", err)
return
end ok, err = red:set("dog_test_short", "an animal dog_test_short"..ngx.time())
if not ok then
ngx.say("failed to set dog: ", err)
return
end ngx.say("set result: ", ok) local res, err = red:get("dog_test_short")
if not res then
ngx.say("failed to get dog: ", err)
return
end if res == ngx.null then
ngx.say("dog not found.")
return
end ngx.say("dog_test_short: ", res)
redis_iresty_short.lua
--[[-----------------------------------------------------------------------
* | Copyright (C) Shaobo Wan (Tinywan)
* | Github: https://github.com/Tinywan
* | Author: Tinywan
* | Date: 2017/5/8 16:25
* | Mail: Overcome.wan@Gmail.com
* |------------------------------------------------------------------------
* | version: 1.0
* | description: redis_iresty 短连接测试
* |------------------------------------------------------------------------
--]]
local redis = require "resty.redis_iresty"
local red = redis:new() local res, err = red:auth("tinywan123456")
if not res then
ngx.say("failed to authenticate: ", err)
return
end local ok, err = red:set("OPenresty_short", "NGINX-based OPenresty_short")
if not ok then
ngx.say("failed to set: ", err)
return
end ngx.say("set result: ", ok)
ab -n 5000 -c 100 -k 127.0.0.1/redis_iresty_short
Concurrency Level:
Time taken for tests: 0.682 seconds
Complete requests:
Failed requests:
Keep-Alive requests:
Total transferred: bytes
HTML transferred: bytes
Requests per second: 7332.55 [#/sec] (mean)
Time per request: 13.638 [ms] (mean)
Time per request: 0.136 [ms] (mean, across all concurrent requests)
Transfer rate: 1203.00 [Kbytes/sec] received
ab -n 10000 -c 100 -k 127.0.0.1/redis_iresty_short
Concurrency Level:
Time taken for tests: 1.120 seconds
Complete requests:
Failed requests:
Keep-Alive requests:
Total transferred: bytes
HTML transferred: bytes
Requests per second: 8925.68 [#/sec] (mean)
Time per request: 11.204 [ms] (mean)
Time per request: 0.112 [ms] (mean, across all concurrent requests)
Transfer rate: 1463.93 [Kbytes/sec] received
ab -n 100000 -c 100 -k 127.0.0.1/redis_iresty_short
Concurrency Level:
Time taken for tests: 10.308 seconds
Complete requests:
Failed requests:
Keep-Alive requests:
Total transferred: bytes
HTML transferred: bytes
Requests per second: 9701.45 [#/sec] (mean)
Time per request: 10.308 [ms] (mean)
Time per request: 0.103 [ms] (mean, across all concurrent requests)
Transfer rate: 1591.19 [Kbytes/sec] received
CPU

ab -n 500000 -c 100 -k 127.0.0.1/redis_iresty_short
Concurrency Level:
Time taken for tests: 55.198 seconds
Complete requests:
Failed requests:
Keep-Alive requests:
Total transferred: bytes
HTML transferred: bytes
Requests per second: 9058.32 [#/sec] (mean)
Time per request: 11.040 [ms] (mean)
Time per request: 0.110 [ms] (mean, across all concurrent requests)
Transfer rate: 1485.69 [Kbytes/sec] received

ab -n 1000000 -c 100 -k 127.0.0.1/redis_iresty_short
Concurrency Level:
Time taken for tests: 112.221 seconds
Complete requests:
Failed requests:
Keep-Alive requests:
Total transferred: bytes
HTML transferred: bytes
Requests per second: 8911.00 [#/sec] (mean)
Time per request: 11.222 [ms] (mean)
Time per request: 0.112 [ms] (mean, across all concurrent requests)
Transfer rate: 1461.53 [Kbytes/sec] received
CPU 负载

ab -n 5000000 -c 100 -k 127.0.0.1/redis_iresty_short
比较慢,但是能跑
Concurrency Level:
Time taken for tests: 534.139 seconds
Complete requests:
Failed requests:
Keep-Alive requests:
Total transferred: bytes
HTML transferred: bytes
Requests per second: 9360.85 [#/sec] (mean)
Time per request: 10.683 [ms] (mean)
Time per request: 0.107 [ms] (mean, across all concurrent requests)
Transfer rate: 1535.31 [Kbytes/sec] received

redis_iresty_long.lua
--[[-----------------------------------------------------------------------
* | Copyright (C) Shaobo Wan (Tinywan)
* | Github: https://github.com/Tinywan
* | Author: Tinywan
* | Date: 2017/5/8 16:25
* | Mail: Overcome.wan@Gmail.com
* |------------------------------------------------------------------------
* | version: 1.0
* | description: redis_iresty 长连接带连接池测试
* |------------------------------------------------------------------------
--]]
local redis = require "resty.redis_iresty"
local red = redis:new() -- auth
local count
count, err = red:get_reused_times()
if == count then
local res, err = red:auth("tinywan123456")
if not res then
ngx.say("failed to authenticate: ", err)
return
end
elseif err then
ngx.say("failed to get_reused_times: ", err)
end local ok, err = red:set("OPenresty", "NGINX-based Media Streaming Server")
if not ok then
ngx.say("failed to set: ", err)
return
end ngx.say("set result: ", ok) local ok, err = red:set_keepalive(, )
if not ok then
ngx.say("failed to set keepalive: ", err)
return
end
ab -n 5000 -c 100 -k 127.0.0.1/redis_iresty_long 很好
Concurrency Level:
Time taken for tests: 1.110 seconds
Complete requests:
Failed requests:
Non-2xx responses:
Keep-Alive requests:
Total transferred: bytes
HTML transferred: bytes
Requests per second: 4502.59 [#/sec] (mean)
Time per request: 22.209 [ms] (mean)
Time per request: 0.222 [ms] (mean, across all concurrent requests)
Transfer rate: 1613.72 [Kbytes/sec] received
ab -n 10000 -c 100 -k 127.0.0.1/redis_iresty_long 很好
Concurrency Level:
Time taken for tests: 2.065 seconds
Complete requests:
Failed requests:
Non-2xx responses:
Keep-Alive requests:
Total transferred: bytes
HTML transferred: bytes
Requests per second: 4843.59 [#/sec] (mean)
Time per request: 20.646 [ms] (mean)
Time per request: 0.206 [ms] (mean, across all concurrent requests)
Transfer rate: 1735.94 [Kbytes/sec] received
ab -n 100000 -c 100 -k 127.0.0.1/redis_iresty_long 不是很好(不推荐)
Concurrency Level:
Time taken for tests: 19.675 seconds
Complete requests:
Failed requests:
Non-2xx responses:
Keep-Alive requests:
Total transferred: bytes
HTML transferred: bytes
Requests per second: 5082.71 [#/sec] (mean)
Time per request: 19.675 [ms] (mean)
Time per request: 0.197 [ms] (mean, across all concurrent requests)
Transfer rate: 1821.64 [Kbytes/sec] received
CPU 负载

ab -n 500000 -c 100 -k 127.0.0.1/redis_iresty_long 不是很好(不推荐)
Concurrency Level:
Time taken for tests: 95.891 seconds
Complete requests:
Failed requests:
Non-2xx responses:
Keep-Alive requests:
Total transferred: bytes
HTML transferred: bytes
Requests per second: 5214.28 [#/sec] (mean)
Time per request: 19.178 [ms] (mean)
Time per request: 0.192 [ms] (mean, across all concurrent requests)
Transfer rate: 1868.79 [Kbytes/sec] received

ab -n 1000000 -c 100 -k 127.0.0.1/redis_iresty_long (不推荐)下面不再测试
Concurrency Level:
Time taken for tests: 190.008 seconds
Complete requests:
Failed requests:
Non-2xx responses:
Keep-Alive requests:
Total transferred: bytes
HTML transferred: bytes
Requests per second: 5262.94 [#/sec] (mean)
Time per request: 19.001 [ms] (mean)
Time per request: 0.190 [ms] (mean, across all concurrent requests)
Transfer rate: 1886.23 [Kbytes/sec] received
CPU

OpenResty 高阶实战之————Redis授权登录使用短连接(5000)和长连接(500W) 使用连接池AB压力测试结果的更多相关文章
- Nginx网络架构实战学习笔记(五):大访问量优化整体思路、ab压力测试及nginx性能统计模块、nginx单机1w并发优化
文章目录 大访问量优化整体思路 ab压力测试及nginx性能统计模块 ab压力测试及nginx性能统计模块 ab压力测试 nginx性能统计模块 nginx单机1w并发优化 整装待发: socket ...
- Spring Boot实战之Redis缓存登录验证码
1.工具类 1 import lombok.experimental.UtilityClass; 2 3 import java.awt.*; 4 import java.awt.image.Buff ...
- ThinkPHP5高阶实战教程
tp5项目:https://www.kancloud.cn/mikkle/thinkphp5_study/396283
- Thinkphp5 用ab压力测试工具测试高并发请求
上篇文章[Thinkphp5实现悲观锁]已介绍过thinkphp5使用悲观锁实现高并发的场景,这篇文章将实际测试下. 在shell里进入到apache的bin目录,输入以下url: ab -n 100 ...
- react高阶组件的一些运用
今天学习了react高阶组件,刚接触react学习起来还是比较困难,和大家分享一下今天学习的知识吧,另外缺少的地方欢迎补充哈哈 高阶组件(Higher Order Components,简称:HOC) ...
- sso单点登录系统的压力测试
环境:vmware centos7.4 2cpu 2核心 工具:ab压力测试工具 测试对象:sso单点登录系统 电脑:win10 4核 项目环境:flask+uwsgi+nginx(uwsgi 2进程 ...
- 《React后台管理系统实战 :一》:目录结构、引入antd、引入路由、写login页面、使用antd的form登录组件、form前台验证、高阶函数/组件
实战 上接,笔记:https://blog.csdn.net/u010132177/article/details/104150177 https://gitee.com/pasaulis/react ...
- Netty Redis 亿级流量 高并发 实战 (长文 修正版)
目录 疯狂创客圈 Java 分布式聊天室[ 亿级流量]实战系列之 -30[ 博客园 总入口 ] 写在前面 1.1. 快速的能力提升,巨大的应用价值 1.1.1. 飞速提升能力,并且满足实际开发要求 1 ...
- 《Netty Zookeeper Redis 高并发实战》 图书简介
<Netty Zookeeper Redis 高并发实战> 图书简介 本书为 高并发社群 -- 疯狂创客圈 倾力编著, 高度剖析底层原理,深度解读面试难题 疯狂创客圈 Java 高并发[ ...
随机推荐
- 命令行启用IIS Express
我们在调试WEB程序的时候可以把本地web程序挂载到本地IIS,然后访问程序,通过附加进程的方式(w3wp)来调试程序(个人非常喜欢的一种调试方式),还有一种比较传统的方式就是通过VS自带的F5来执行 ...
- 我的小游戏上线海外AppStore完整流程心得
1,购买一台Mac或者用VMWare 安装Mac OS流程,笔者使用VMWare. 先安装Mac OS 10.13,教程,成功后不要着急安装vmtools, 首先更新系统至最新版,因为真机测试往往需要 ...
- ats透明代理
透明代理是拦截客户端和服务器之间的连接而不可见的代理能力(比如ats). 必须要有一个网关设备,所有网络流量都通过该设备从客户端传递到Internet(或外部云).网关负责有效的将ATS拼接到该流量的 ...
- vue入门全局配置
全局配置 Vue.config 是一个对象,包含 Vue 的全局配置.可以在启动应用之前修改下列属性: silent 类型:boolean 默认值:false 用法: Vue.config.silen ...
- 20135234mqy-——信息安全系统设计基础第十三周学习总结
第十一章 网络编程 11.1 客户端-服务器编程模型 基本操作:事务 当一个客户端需要服务时,向服务器发送一个请求,发起一个事务. 服务器收到请求后,解释它,并以适当的方式操作它的资源. 服务器给客户 ...
- 软工团队(hello world)组员介绍
姜中希:喜欢编程,善于交际. 周盼超:喜欢编程. 王昭博:思路比较清晰,可以明确开发步骤. 刘洪阳:思想笔记广泛,可以把很多有关联的东西结合起来. 刘双勃:喜欢编程,踏实,比较容易坚持.
- (转)广度优先搜索BFS和深度优先搜索DFS
1. 广度优先搜索介绍 广度优先搜索算法(Breadth First Search),又称为"宽度优先搜索"或"横向优先搜索",简称BFS. 它的思想是:从图中 ...
- java常见编码
摘自:http://www.cnblogs.com/yaya-yaya/p/5768616.html 红色 主要点 灰色 内容 绿色 知识点 橘色 补充内容 几种常见的编码格式 ...
- 使用redis防止抢购商品超卖
前言: redis不仅仅是单纯的缓存,它还有一些特殊的功能,在一些特殊场景上很好用. 本篇博文用来测试下使用redis来防止抢购商品超卖问题. 内容: 使用redis的list进行测试 思路是设置一个 ...
- K8S 使用NFS 创建PV和PVC的例子 学习From https://blog.csdn.net/xts_huangxin/article/details/51494472
1. 获取资料 网址: https://blog.csdn.net/xts_huangxin/article/details/51494472 感谢原作者 这里面 按照自己的机器情况进行了学习模仿 ...