当前位置: 首页 > news >正文

做水果网站平台百度提交入口网址是什么

做水果网站平台,百度提交入口网址是什么,郑州小程序外包公司,辽源网站建设设计很多人都遇到过这样的情况,当网站达到一定的访问量,数据库就会成为瓶颈,进而引起阻塞。 有人认为这可能就是硬件的极限了,于是想办法增加硬件设备。而我本人认为问题的元凶可能是性能不高的sql脚本,引起了阻塞。 如果你…

很多人都遇到过这样的情况,当网站达到一定的访问量,数据库就会成为瓶颈,进而引起阻塞。

有人认为这可能就是硬件的极限了,于是想办法增加硬件设备。而我本人认为问题的元凶可能是性能不高的sql脚本,引起了阻塞。

如果你和我有相同的看法,那我们就一起想办法找出问题的源头。

案例1.

某一天我被告知,我们的书城网站不能访问了,我马上查看,发现书城的有两台iis服务器均显示service unavailable,我初步断定是sqlserver数据库发生了阻塞,因为同一套程序使两台iis服务器同时当机的可能性不大。

要知道是否发生了阻塞,当然要看master库的sysprocess表,看看是否有什么进程堵住了别的进程,语句如下:

Select * from master..sysprocesses where blocked > 0

很快我发现,有一个blocked = 51 堵住了很多进程(查看blocked列可见),果然和我的判断吻合;为了进一步找出发生阻塞的语句,我用到的如下的语句

dbcc inputbuffer(51);

结果如下:

EventType      Parameters            EventInfo            

------------------------------------------------

RPC Event      0                          p_Book_content;1

从上面就可以看出是p_Book_content (是个存储过程)引起的阻塞,但是这个过程里面同时对多个表进行了操作,到底是那个语句出了问题呢?

下面我们再来进一步定位阻塞的位置:

Sp_lock

结果如下(大部分数据略)

Spid        dbid        objid              indid       type   resource   mode      status

-------------------------------------------------------------------------------------------------

51           14           206623779     0         TAB                    X            WAIT

52           14           0                   0            DB                       S            GRANT

53           14           0                   0            DB                       S            GRANT

。。。

。。。

。。。

现在我们来看看spid = 51 这行, mode = X 表示排它锁, status = WAIT表示正在等待(即被阻塞了),dbid = 14 是数据库的id,objid = 206623779 是被锁的对象id,我们可以通过下列函数得到数据库和表:

Select db_name(@dbid) -----》book_db

select object_name(@objid) -------》 t_book

即book_db库的t_book表被锁住了,这时候再回投仔细检查 p_Book_content 存储过程,发现只有一个语句对t_book进行了操作:

update t_book set hitcount = hitcount + 1 where bookid = @bookid

这个语句的作用是更新书本的点击次数,为什么上面这个语句会引起阻塞呢?我认为最可能的情况应该是同时访问的人过多,同时对表进行过多的update操作引起的,所以最终改用别的方式,不再实时对t_book表进行update操作,而是每次访问都先insert一条记录到一个中间表中,然后再用一个作业,每隔10分钟定时更新书本的点击次数,如此改进之后,此问题终于圆满解决了。

相关资料在book online可以找到, 关键字: sp_lock , sysprocesses , dbcc inputbuffer , db_name(), object_name()

 注:原来发在csdn的,现在荒芜了,挪到这边来栽培一下。

 

http://www.lbrq.cn/news/2707993.html

相关文章:

  • 英文网站建设需求外贸接单十大网站
  • 上海网站建设网站制广告联盟接单平台
  • wordpress模板QQ评论西安seo诊断
  • 建设用地规划证查询网站站长工具seo综合查询论坛
  • 网站怎么做啊大型网站制作
  • 花生壳免费域名注册网站搜外滴滴友链
  • 济南免费做网站b2b国际贸易平台
  • 电子政务门户网站建设的意义微信推广广告在哪里做
  • 网站的空间百度权重网站排名
  • 分类目录网站大全ip反查域名网站
  • 动漫设计与制作属于什么专业大类南宁百度seo排名优化软件
  • 网站制作天津郑州网站推广公司哪家好
  • 备案的域名可以做盗版电影网站吗信息如何优化上百度首页公司
  • 彩票网站平台外国网站的浏览器
  • 网站策划书注意事项电商软文范例
  • 建站推广哪里有建站新闻资讯域名批量查询工具
  • 观澜做网站公司广州seo黑帽培训
  • 阳泉做网站公司百度网址大全官网旧版
  • 找人做网站怕侵权自媒体视频发布平台
  • 怎样做网站关键字网站seo标题是什么意思
  • 做网站最专业的公司有哪些百度热词搜索指数
  • 网站建设账务处理b2b网站源码
  • 网站返回503的含义是色目人
  • 网站开发种类如何建立一个网站
  • 国内网站设计如何进行营销推广
  • 徐州网站推广优化排名优化公司
  • 中国建站网培训网站建设
  • 如何介绍自己做的网站微信腾讯会议
  • 网站建设 图片他达拉非功效与作用主要会有哪些
  • 学设计的网站推荐项目网站
  • 【代码随想录day 20】 力扣 108.将有序数组转换为二叉搜索树
  • OpenCV ------图像基础处理(一)
  • pycharm远程连接服务器跑实验详细操作
  • 当img占不满div时,图片居中显示,两侧加当前图片模糊效果
  • Mac安装ant
  • Linux的进程信号