java基础-9.高并发

基础-面向对象/语法/异常/常用api/数据类型/io/集合/多线程/高并发
高并发:在极短单位时间内,极多个请求同时发起到服务器。

需要了解大数据高并发的瓶颈在哪里,一般都是数据库层面的,机械硬盘承载不起非常快速的读写操作,cpu承载不起大量的逻辑运算,所以最基本的解决思路就是:

1.换固态硬盘加快硬盘的读写效率。
2.建立缓存中间件降低对硬盘的读写次数,缓存不用多说了,最最最基本和重要的优化策略。
3.将硬盘的读写或者数据的计算分摊到多台机器上,也就是集群。hadoop就是基于这个层面的。
4.良好的查询算法,降低读的次数,分表,分库,索引等都是基于这层面的。

具体Java高并发,如何解决,什么方式解决(锁机制1.同步锁:改代码;2.数据库:悲观锁and乐观锁;3.分布式分表分库;负载均衡等;具体问题具体分析)

对于我们开发的网站,如果网站的访问量非常大的话,那么我们就需要考虑相关的并发访问问题了。而并发问题是绝大部分的程序员头疼的问题, 为了更好的理解并发和同步,我们需要先明白两个重要的概念:

同步和异步

1、同步和异步的区别和联系

同步就是一件事,一件事情一件事的做。
异步就是,做一件事情,不引响做其他事情。

2、如何处理并发和同步

处理并发和同同步问题主要是通过锁机制
一种是代码层次上的,如java中的同步锁,典型的就是同步关键字synchronized,
另外一种是数据库层次上的,比较典型的就是悲观锁和乐观锁。

3、常见并发同步案例分析

案例一:订票系统案例,某航班只有一张机票,假定有1w个人打开你的网站来订票,问你如何解决并发问题(可扩展到任何高并发网站要考虑的并发读写问题)

问题,1w个人来访问,票没出去前要保证大家都能看到有票,不可能一个人在看到票的时候别人就不能看了。到底谁能抢到,那得看这个人的“运气”(网络快慢等)其次考虑的问题,并发,1w个人同时点击购买,到底谁能成交?总共只有一张票。

首先我们容易想到和并发相关的几个方案 :

锁同步同步更多指的是应用程序的层面,多个线程进来,只能一个一个的访问,java中指的是syncrinized关键字。
锁也有2个层面,一个是java中谈到的对象锁,用于线程同步;另外一个层面是数据库的锁;如果是分布式的系统,显然只能利用数据库端的锁来实现。假定我们采用了同步机制或者数据库物理锁机制,如何保证1w个人还能同时看到有票,显然会牺牲性能,在高并发网站中是不可取的。

4、常见的提高高并发下访问的效率的手段

首先要了解高并发的的瓶颈在哪里?

可能是服务器网络带宽不够 可能web线程连接数不够 可能数据库连接查询上不去。 根据不同的情况,解决思路也不同。

像第一种情况可以增加网络带宽,DNS域名解析分发多台服务器。 负载均衡,前置代理服务器nginx、apache等等
数据库查询优化,读写分离,分表等等
--------------------- 作者:Derllk 来源:CSDN 原文:https://blog.csdn.net/derllk/article/details/79614053
版权声明:本文为博主原创文章,转载请附上博文链接!

  • 1
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值