高性能网络编程,高并发
公司项目并发量都特小,自己如何实际接触高并发项目?
如果你是一个工作刚不久的巨婴,那么首先,不要急于学习大型网站的架构设计,此时此刻做任何项目都可以学到很多东西,并发量不高的项目你可以多学习学习代码设计,要是工作不那么忙你还可以在公司学习。任何产品不可能一开始的时候就是高并发架构。但是我们要时刻准备好迎接大流量。如果你确实希望能够直接接触高并发项目,那也不是不可以。
我给你一个实际操作的思路。首先你需要了解jmeter工具,高并发的项目通常会用它来进行并发测试。并发我们通常会分为两种,一种是读并发,一种是写并发。模拟读并发第一阶段:正常情况下,我们编写一个接口都是直接访问数据库获取数据,那这样肯定是占用数据库连接的,所以并发数不会很高。第二阶段:我们为数据添加缓存,访问时我们先访问缓存,比如redis,如果缓存中没有数据我们再从数据库中读取,这里就会涉及到缓存雪崩和穿透的问题。
这些问题咱们可以忽略不计,因为解决办法很简单,而且有很多种。添加缓存就减少了数据库压力,更重要的是我们增加了请求的IOPS(吞吐量),也就意味着我们的服务器一秒钟可以处理更多的请求,也就提高了并发量。第三阶段:当我们的缓存处理的IOPS比我们的服务器最高支持的并发数还高,比如Tomcat优化的好的话可以有1.5k左右(有人说可以达到6k),不过我觉得这个跟你机器的内存和tomcat的配置有关,咱们暂且假定是1.5k。
如果你要超过1.5k的并发,那么此时你就需要增加服务器或者换一种并发量更高的服务器。我们以增加服务器为例,你可以添加1台服务器来支持更高的并发,然后通过nginx进行负载均衡,将流量分配到两台tomcat中。我们知道nginx的最高并发可以达到3W,也就是意味着你可以添加20台tomcat。第四阶段:当nginx成为了我们的并发瓶颈,我们就要做nginx集群了。
这也意味着我们需要将一个地区划分成多个小地区,每个地区配置一个公网nginx。而这种做法有两种,一种是通过网络路由层增加控制来实现分发,一种是通过硬件来实现,硬件的我没操作过,自己实践也不实际,因为很贵!当然,我们并不能直接通过增加最高并发量就能处理并发,比如数据库层面中途我们就需要改成主从机制,采用分库分表或者使用mongodb这种高吞吐量的数据库来做。
比如我们的机器配置也需要增加等。模拟写并发写并发跟读并发的区别主要在于写的时间往往比较长,读的时间我们通过缓存来提高,但写库这个动作我们并不能通过缓存来处理,此时就需要我们增加消息队列MQ,最终走向MQ的集群。增加MQ以后我们的请求只是把写库这项任务添加到队列中,然后一条一条地执行,但是用户发起的请求我们立即返回成功标志。
这样可以不占用服务线程。也就提高了并发量,同时也需要修改我们的业务,比如正常下单是订单入库后返回成功,并发量上来后我们就需要调整为订单加入队列后成功,并没有入库,那么此时不能告诉用户下单成功,而是提醒用户正在下单,然后前端每1秒钟去查询订单看是否存在,如果存在再提示下单成功。最后总的来说,我们知道了一套高并发的常见处理方式和原理,我们就可以自己去模拟一下。
讲真的在公司基本学不到啥东西,一般都是靠自己做项目来完成一些自己想要的效果或者自己想实践的技术和经验。我自己就开发了一个代码开发平台,你也可以了解一下,叫懒猴子CG。前端用的nuxt,后端用的springboot,基本都不怎么架构,但是从前端到后端基本都是我一个人开发的,所以还是会学到很多东西。即使流量大了,我也有办法撑起来,这就是自己做项目去实践的一个好处,可以经历一下从无到有的整个过程。
如何看待有些满嘴高并发,编码能力却稀松平常的程序员?
一般公司并发能有一百就很不错了,上千已经是业内有名了,上万已经是领头羊了。但是工业软件另说,采集器一秒一个数据,上万采集器一秒就一万的数据。满嘴高并发的程序员大部分都没有高并发经验,因为高并发更多的面对波峰请求,容错处理,容灾处理,带损服务,大数据处理,防御机制做得多,纯粹的高并发离开业务都是不靠谱的,比如直播类的并发和12306抢票处理就不一样,电商的双十一和大型图片存储中心的并发处理又不一样,游戏的高并发又不一样。
编码能力不行又满嘴高并发这必须是个玩虚高手,搞关系他很行,甩锅也是一般好手。我有幸参与过秒请求超过5万的项目,说实话,很痛苦,光是扩容和修改数据库都让我熬了好多个通宵。后来实在是太痛苦了,把cpp换成可以热更新的语言,全部重写了一遍。即使我已经是bug率很低了,一天造一个,久了也受不了。热更要停机,秒请求5w,更新停一次机我就要熬到凌晨四点多,这个时候请求量还上五千。
推荐文档
- 11.往年大连中考满分是多少
- 12.为什么说学播音毁一生,原因有哪些
- 13.淘宝店铺的优质好评语大全
- 14.考研可改变第一学历吗、专科考研可以改变第一学历吗
- 15.民学网查出的学历国家承认吗(民学网查出的学历国家承认吗是真的吗)
- 16.往年轻薄商务笔记本电脑推荐-商务轻薄本性价比排行
- 17.承德护理职业学院(承德护理职业学院2023年招生计划)
- 18.wreak是什么意思wreak的翻译(wake,area是什么意思中文翻译)
- 19.电子科技大学A+类学科名单有哪些(含A、B、C类学科名单)
- 20.systematic是什么意思systematic的翻译(systematically是什么意思中文翻译)
- 21.leant是什么意思leant的翻译(lean,on什么意思中文意思)
- 22.华南农业大学是几本大学,华南农业大学是一本还是二本
- 23.包头中考考试科目时间预测安排,包头中考考哪几门考哪些课程
- 24.高考430分能上什么大学,430分高考能报啥学校
- 25.朱自清的散文代表作有什么(朱自清的散文代表作有什么散文集有什么散文诗集有什么)
- 26.浙江有几所大学是985和211,全国985和211大学名单汇总
- 27.i5,1155G7和R5,5600U哪款好-对比评测
- 28.荷兰什么叫-荷兰弟为什么叫荷兰弟,出演蜘蛛侠原因曝光
- 29.警察警衔工资改革新政策及新方案【全文】解读
- 30.电大专科(电大专科毕业论文)
- 31.广东省高级技工学校官网
- 32.广州大学专科
- 33.大连陆军学院,原大连陆军学院校址现在什么是什么学校
- 34.亲们,谁给一份南京大学的研究生招生简章?(河海大学
- 35.他日若遂凌云志全诗及出处
- 36.铜绿的化学式是什么有哪些性质
- 37.「佛山市顺德养正西山学校初中部」往年录取分数线
- 38.公办本科(公办本科和民办本科有什么区别)
- 39.外交学院是名牌大学吗
- 40.往年湖南高考成绩排名一分一段表
- 41.全国有8所烟草院校是哪些(这4所大学门槛低)
- 42.私人垄断资本主义基本概念是私人垄断资本主义
- 43.难以启齿,这8部影片可以一看(性教育适合看的影片)
- 44.美国独立战争的性质爆发战争的原因是什么
- 45.往年东莞市高中排名前十最新
- 46.大朗网络教育(大朗教育)
- 47.往年甘肃省高中排名最好的高中
- 48.逻辑思维训练有哪些方法优秀训练方法推荐
- 49.浙江大学教务管理系统
- 50.人类的动物老师有哪些这属于什么学科
- 51.往年山西高考状元榜_山西历届高考理科状元和文科状元
- 52.往年北京舞蹈学院艺术类招生简章招生人数及专业
- 53.航空最好的5个专业就业前景如何
- 54.太原科技大学怎么样及评价好不好太原科技大学口碑如何
- 55.满招损谦受益这句话的意思是什么出自哪
- 56.舍本逐末发生在什么时期含义是什么
- 57.女孩子首选十大专业什么专业适合女生
- 58.国防生是什么意思指的是什么
- 59.河南省三本学院有哪些2018最新三本院校名单
- 60.往年龙岩高中学校排名榜单龙岩十大优秀高中
- 51.纳税人未清卡不允许申领发票是什么意思,税务控票是什么意思
- 52.北流隆盛有什么风景区,登北流隆盛鹅公石山峰
- 53.沈阳国电投全称叫什么,中国电力国际有限公司
- 54.fx安装器下载,先锋fx资源网站
- 55.中波台是什么编制,杭州中波转播台是什么单位
- 56.敏东一矿待遇怎么样,详细分享福建省公务员待遇
- 57.三星手机大全,三星的手机所有的型号和样式,带图片...
- 58.一名即将毕业的大学生晒桌面,联想y430p是哪一年的机子
- 59.奔驰大g长宽高是多少钱(奔驰大g长宽高是多少米)
- 60.九堡大桥南是指哪里,杭州市江干区九堡大桥南信息
- 61.林长高速什么时候通车,高速穿越大峡谷
- 62.太原市迎泽区交通运输局怎么样,迎泽区交通运输局多项措施
- 63.银川妇幼保健院在哪里,投诉银川人放假期间一定要知道这些号码
- 64.库伦到奈曼怎么走,通辽市库伦旗概况
- 65.金乡惠民路小学在哪里,雨中再游金乡金山公园
- 66.电力odn有什么用途,光电线缆双中标
- 67.宜黄有什么路在规划,高架桥与宜黄路转盘壮观
- 68.设备采购方案怎么写,端午礼品采购方案
- 69.修村部到路什么人以管,村委会2万元维修款变10万元注水合同
- 70.高价中标是什么意思,在国际上处于什么地位

