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

淳安县住房和城乡建设局网站首页西安做推广网站设计

淳安县住房和城乡建设局网站首页,西安做推广网站设计,北京互联网公司建网站,品牌建设与品牌价值首先祝大家新年快乐#xff0c;身体健康#xff0c;万事如意。一般来说一个系统最先出现瓶颈的点很可能是数据库。比如我们的生产系统并发量很高在跑一段时间后#xff0c;数据库中某些表的数据量会越来越大。海量的数据会严重影响数据库的读写性能。这个时候我们会开始优化… 首先祝大家新年快乐身体健康万事如意。一般来说一个系统最先出现瓶颈的点很可能是数据库。比如我们的生产系统并发量很高在跑一段时间后数据库中某些表的数据量会越来越大。海量的数据会严重影响数据库的读写性能。这个时候我们会开始优化系统一般会经过这么几个过程找出SQL慢查询针对该SQL进行优化比如改进SQL的写法查看执行计划对全表扫描的字段建立索引引入缓存把一部分读压力加载到内存中读写分离引入队列把并发的请求使其串行化来减轻系统瞬时压力分表/分库对于第五点优化方案我们来细说一下。分表分库通常有两种拆分维度1.垂直切分垂直切分往往跟业务有强相关关系比如把某个表的某些不常用的字段迁移出去比如订单的明细数据可以独立成一张表需要使用的时候才读取 2.水平切分比如按年份来拆分把数据库按年或者按某些规则按时间段分成多个表。拆分表之后每个表的数据量将会变小带来的好处是不言而喻的。不管是全表扫描还是索引查询都会有比较高的提升。如果把不同的表文件落在多个磁盘上那数据库的IO性能还能进一步提高。如果纯手工拆分比如按年份拆分成多个表那么上层业务代码也得进行调整。每次读写都得判断该使用哪张表。如果是跨多个年份的分页查询更加难搞。人肉分表基本上不可能实现的对于上层编码简直是个噩梦。所以针对分表分库我们通常会使用某些中间件比如MycatSharding-JDBC等中间件。使用这些组件确实能实现分表分库并且对业务层代码屏蔽了数据库架构的改动但是配置略显麻烦。如果你使用的是SQL Server数据库并且目前还不需要分库只需要分表那么其实使用内置的分区表功能是最简单的方案。只需要打开SQL Server Management Studio简单设置几下就可以了对于你上层应用完全是无感的你的代码、数据库连接串都不需要改动。以下我们通过2个简单的测试来简单的演示下如何进行表分区操作以及测试下分区前后性能变化。测试写性能我们的测试方案新建一张logs表按年份写入数据。2019年写入1000000数据2020年也写入100000数据。为了加快写入的速度每个年份并行10个线程同时写每个线程写100000数据一共1000000数据。然后把logs表改成分区表再用同样的方式写入2000000数据。记录耗时 比较两次的耗时。硬件为一台14年产的笔记本OS为win10。挂载2块硬盘1块为5400转的机械硬盘1块为15年加的SSD。磁盘性能可以说极为垃圾。未分区时表文件会落在机械硬盘上。未分区情况下测试使用脚本建表CREATE TABLE [dbo].[logs]([id] [uniqueidentifier] NOT NULL,[log_txt] [varchar](200) NULL,[log_time] [datetime] NULL,CONSTRAINT [PK_logs] PRIMARY KEY CLUSTERED ([id] ASC )WITH (PAD_INDEX OFF, STATISTICS_NORECOMPUTE OFF, IGNORE_DUP_KEY OFF, ALLOW_ROW_LOCKS ON, ALLOW_PAGE_LOCKS ON) ON [PRIMARY] ) 新建一个控制台程序编写代码class Program{static void Main(string[] args){Console.WriteLine(Hello World!);Task.Run(() {InsertData(2019);});Task.Run(() {InsertData(2020);});Console.ReadLine();}static void InsertData(int year){var tasks new ListTask();Stopwatch sw new Stopwatch();sw.Start();for (int i 0; i 10; i){tasks.Add(Task.Run(() {using (var conn new SqlConnection()){conn.ConnectionString Persist Security Info False; User ID sa; Password dev123; Initial Catalog fq_test; Server .\\mssql2016;conn.Open();int index 0;for (int j 0; j 100000; j){var logtime new DateTime(year, new Random().Next(1, 12), new Random().Next(1, 28));conn.Execute(insert into logs2 values (newid(),下订单,logtime), new{logtime});Console.WriteLine(logtime:{0} index {1}, logtime, index);}}}));}Task.WaitAll(tasks.ToArray());sw.Stop();Console.WriteLine(Year {0} complete , total time: {1}., year, sw.ElapsedMilliseconds);}} 写完2000000数据耗时1369454毫秒。分区情况下进行测试开始分区把一个表设置为分区表大概有5个步骤添加文件组在文件组添加文件新建分区函数新建分区方案开始分区以下演示下如何使用SQL SERVER Management Studio管理器进行表分区选中数据库属性文件组添加group1group2两个文件组。选中数据库属性文件。添加file1文件组选group1路径选择一个文件目录。这里选择E盘data目录。添加file2文件组选择group2路径选择一个文件目录。这里选择X盘的data目录。这样当分区的时候数据就会落在这2个目录下。这里的路径可以选择在同一个硬盘但是为了更高的读写性能如果有条件建议直接指定在不同的硬盘下。选中logs表存储创建分区启动分区向导工具。新建一个分区函数点击下一步。新建一个分区方案点击下一步。选择一个分区列数据会根据该列进行水平拆分。这里选择logtime因为时间是比较适合水平切分的一个维度。值得数据拆分的范围。范围选择“右边界”。右边界跟左边界的差异在于对边界值的处理。右边界是左边界是也就是包含边界值。我们这里设置group1存储2019的数据group2存储2020的数据。所以group1的边界值设置为2020-01-01group2的边界值设置为2021-01-01 。设置完是这个样子需要3个文件组。当出现不在group1group2范围内的数据就会存储在第三个文件组内。建好分区函数、分区方案后可以选择生成脚本或者立即执行。这里选择“立即执行”。当执行完成后表里的数据会按照分区方案设置的边界分散到多个文件上。在分区情况下进行测试先清空logs表所有的数据然后使用同样的代码进行测试。测试结果显示写完2000000数据耗时568903毫秒。可以看到数据库写性能大副提高大概提高了1倍不止的性能。这也比较符合两块磁盘同时IO的预期。测试读性能我们的测试方案新建一张log2表使用上面的代码按年份写入2000000数据。然后使用select语句同时读取2019,2020年的数据。把log表转换成分区表重新测试select的时间。比较两次读取数据的时间。sql语句select * from log2 where (logtime  2019-05-01 and logtime  2019-06-01) or (logtime  2020-05-01 and logtime  2020-06-01)首先在未分区的表上测试查询性能花费时间为3s。把表按前面的方法进行分区拆分查询花费时间为1s。读性能大概为未分区时的3倍。总结经过简单的测试SQL Server的分区表功能能大副提高数据库的读写性能。通过SQL Server Management Stduio的简单设置就可以对数据库表进行分区操作并且对应用层的代码完全是无感的比用分表分库中间件来说简单多了。
http://www.zqtcl.cn/news/810394/

相关文章:

  • 淮安市交通建设局网站新郑做网站
  • 新开传奇网站手机版深圳房管局官网
  • 重庆网站建设营销深圳微商城网站设计公司
  • 用织梦做的网站是模板的吗外贸展示型模板网站
  • 网站seo的关键词排名怎么做的定制和订制
  • 自适应网站做多大尺寸的四川建设厅电话网站
  • 易语言可以做网站了吗电商平台排名100强
  • 网站代码开发方式影视公司网页设计
  • 如何选择网站定制公司响水专业做网站
  • 海门建网站公司凡客模板wordpress
  • 网站关键字排名php开源cms
  • 手机商城手机网站建设多少钱明水县网站建设
  • 北京网站优化外包做板材外贸一般用哪个网站
  • 北京建设网站有哪些公司药店网站模板
  • 网站欢迎页面怎么做个人简历免费模板下载
  • 宁波外贸网站建设竣工验收报告查询网
  • 内衣网站建设详细方案如何制作企业网站的版式
  • 网站建设是否需要源代码php如何制作网站
  • 自响应式网站是什么意思现货交易平台合法的有几家
  • 网站如何做视频链接地址一个虚拟主机空间挂两个网站
  • seo外贸网站建设常州本地网站
  • 可以做机械设计接单的网站pc网站怎么做自适应
  • 网站建设义乌电子商务做网站实训体会
  • 哪些网站做国际贸易比较好徐州泉山建设局网站
  • 平果县免费网站哪家好新媒体营销
  • 网站制作的页面比例企业为什么建立企业网站
  • 网站开发技术的发展专业的seo网站优化公司
  • 十大ppt模板免费下载网站惠州网络营销
  • 网站建设自优化网站首页
  • 网络营销推广方式包括哪几种湘潭网站seo磐石网络