【1】概念

  把不同数据文件移动到不同的物理磁盘,无疑是一个提高IO的有效办法

  在资源可以的情况下,尽量把 temp 、数据库的主数据文件(mdf)、数据库的从数据数据(ndf)、数据库的事务日志文件(ldf)存放在不同磁盘

  如果碍于资源有限,尽可能的把数据文件存放在不同磁盘(即mdf与ndf不同盘,或者说是同文件组中的不同文件不同盘),没有ndf的情况下mdf与ldf不同盘

【2】如何只管查看物理磁盘与逻辑盘符的关系?

右击我的电脑-》管理-》磁盘管理,如下图,很明显C/E是同一个物理盘,而D盘是另外一个物理盘。

  

简单案例演示:当目前只有MDF与LDF,且在同一个逻辑盘符时

--0、目的:把数据库文件分部在不同物理磁盘
--1、前提:知道除系统盘外其他逻辑盘符均为不同物理硬盘
--2、问题:(1)权限 (2)没有通用化 -- 允许配置高级选项
EXEC sp_configure 'show advanced options',1;
EXEC sp_configure 'xp_cmdshell',1;
RECONFIGURE WITH OVERRIDE; use master
go
--查看逻辑盘符数量
DECLARE @temp_disk_unused TABLE (
diskNum varchar(2),
unUsed_space bigint
)
insert into @temp_disk_unused
exec xp_fixeddrives --如果逻辑盘符数量》3(表明至少有2个物理盘,我这里只用D,E),且数据库的(单数据文件)数据文件与日志文件均在同一个磁盘下
if exists( select 1 from @temp_disk_unused having count(*)>=3)
and
exists(
select 1 where
(select left(filename,1) from db_tank_1..sysfiles where fileid=1)=
(select left(filename,1) from db_tank_1..sysfiles where fileid=2)
)
begin declare @db_name varchar(100),@logic_name varchar(100)
declare @new_path varchar(500),@filename varchar(100),@old_path varchar(500),@new_dir varchar(100)
declare @old_disk_num varchar(2),@new_disk_num varchar(2)
declare @sql varchar(4000),@sql1 varchar(4000)
--判断当前是在D盘还是E盘,如果是D则把日志文件迁移到E,E迁移到D
select @old_disk_num=left(filename,1) from db_tank_1..sysfiles where fileid=1
if @old_disk_num='D'
set @new_disk_num='E'
else
set @new_disk_num='D' --找出旧文件全路径与新位置路径,方便迁移文件过去
select @old_path=filename,@logic_name=name from db_tank_1..sysfiles where fileid=2
set @filename=right(@old_path,charindex('\',reverse(@old_path))-1)
set @new_dir=stuff(left(@old_path,len(@old_path)-len(@filename)),1,1,@new_disk_num)
set @new_path=stuff(@old_path,1,1,@new_disk_num)
print @filename+','+@new_dir+','+@new_path+','+@logic_name
--------------------------------------------------------
--建立一个虚拟表 用来判断文件夹是否存在
DECLARE @TEMP TABLE(A INT,B INT,C INT)
insert into @TEMP
EXEC [MASTER]..XP_FILEEXIST @new_dir
IF NOT EXISTS(SELECT 1 FROM @TEMP WHERE B=1)
BEGIN
--不存在则创建
SET @SQL='EXEC XP_CMDSHELL ''MKDIR '+@new_dir+''''
exec(@sql)
print @sql
END
--------------------------------------------------------
--修改日志文件(1)修改逻辑文件名对应的物理路径 (2)脱机该数据库 (3)迁移 (4)重新联机该数据库
set @sql1='alter database db_tank_1 modify file (name = '+@logic_name+',filename='''+@new_path+''');'
set @sql1=@sql1+'ALTER DATABASE db_tank_1 SET OFFLINE WITH ROLLBACK IMMEDIATE;'
print @sql1
exec(@sql1)
SET @SQL='EXEC XP_CMDSHELL ''move '+@old_path+' '+@new_path+''''
print @sql
exec(@sql)
set @sql1='alter database db_tank_1 set online;'
print @sql1
exec(@sql1) end
--核验
select * from db_tank_1..sysfiles
if exists(
select 1 where
(select left(filename,1) from db_tank_1..sysfiles where fileid=1)=
(select left(filename,1) from db_tank_1..sysfiles where fileid=2)
)
print 'have problem,please check the info by sysfiles..'
else
print 'operator success!' --------------------------------------------------------
-- 允许配置高级选项 EXEC sp_configure 'xp_cmdshell',0;
EXEC sp_configure 'show advanced options',1; RECONFIGURE WITH OVERRIDE;

【基本优化实践】【1.1】IO优化——把文件迁移到不同物理磁盘的更多相关文章

  1. 数据库优化实践【MS SQL优化开篇】

    数据库定义: 数据库是依照某种数据模型组织起来并存在二级存储器中的数据集合,此集合具有尽可能不重复,以最优方式为特定组织提供多种应用服务,其数据结构独立于应用程序,对数据的CRUD操作进行统一管理和控 ...

  2. [置顶] 数据库优化实践【MS SQL优化开篇】

    数据库定义: 数据库是依照某种数据模型组织起来并存在二级存储器中的数据集合,此集合具有尽可能不重复,以最优方式为特定组织提供多种应用服务,其数据结构独立于应用程序,对数据的CRUD操作进行统一管理和控 ...

  3. Tomcat8史上最全优化实践

    Tomcat8史上最全优化实践 1.Tomcat8优化 1.1.Tomcat配置优化 1.1.1.部署安装tomcat8 1.1.2 禁用AJP连接 1.1.3.执行器(线程池) 1.1.4 3种运行 ...

  4. Hadoop YARN:调度性能优化实践(转)

    https://tech.meituan.com/2019/08/01/hadoop-yarn-scheduling-performance-optimization-practice.html 文章 ...

  5. MYSQL join 优化 --JOIN优化实践之快速匹配

    MySQL的JOIN(四):JOIN优化实践之快速匹配 优化原则:小表驱动大表,被驱动表建立索引有效,驱动表建立索引基本无效果.A left join B :A是驱动表,B是被驱动表:A right ...

  6. CDN HTTPS安全加速基本概念、解决方案及优化实践

    大家都知道,HTTP 本身是明文传输的,没有经过任何安全处理,网站HTTPS解决方案通过在HTTP协议之上引入证书服务,完美解决网站的安全问题.本文将为大家介绍阿里云CDN HTTPS安全加速传输的基 ...

  7. Glow Android 优化实践

    了解 Glow 的朋友应该知道,我们主营四款 App,分别是Eve.Glow.Nuture和Baby.作为创业公司,我们的四款 App 都处于高速开发中,平均每个 Android App 由两人负责开 ...

  8. Unity3D游戏GC优化总结---protobuf-net无GC版本优化实践

    protobuf-net优化效果图 protobuf-net是Unity3D游戏开发中被广泛使用的Google Protocol Buffer库的c#版本,之所以c#版本被广泛使用,是因为c++版本的 ...

  9. 长连接锁服务优化实践 C10K问题 nodejs的内部构造 limits.conf文件修改 sysctl.conf文件修改

    小结: 1. 当文件句柄数目超过 10 之后,epoll 性能将优于 select 和 poll:当文件句柄数目达到 10K 的时候,epoll 已经超过 select 和 poll 两个数量级. 2 ...

随机推荐

  1. bzoj3307 雨天的尾巴题解及改题过程(线段树合并+lca+树上差分)

    题目描述 N个点,形成一个树状结构.有M次发放,每次选择两个点x,y对于x到y的路径上(含x,y)每个点发一袋Z类型的物品.完成所有发放后,每个点存放最多的是哪种物品. 输入格式 第一行数字N,M接下 ...

  2. 第06课:作用域、JS预解析机制

    从字面上理解----域就是空间.范围.区域,作用就是读.写,所以作用域我们可以简单理解为:在什么样空间或者范围内对数据进行什么样的读或写操作. 看一下代码 alert(a); // 为什么是undef ...

  3. 关于项目在网页中运行部分jsp出现乱码(由request.getRequestDispatcher("XXX.jsp").forward(request, response)造成)的解决方法

    在写jsp的时候发现部分的jsp在浏览器预览时出现乱码,为一堆问号,如图: 当时问了同学,只有部分jsp会出现乱码,因为重新建一个jsp在运行就没有错误,可以显示出来,所以发现是jsp头部的错误,当新 ...

  4. MySQL_(Java)使用JDBC向数据库中修改(update)数据

    MySQL_(Java)使用JDBC向数据库发起查询请求 传送门 MySQL_(Java)使用JDBC向数据库中插入(insert)数据 传送门 MySQL_(Java)使用JDBC向数据库中删除(d ...

  5. centos6升级系统内核

    1.升级系统内核查看内核版本: uname -r 2.6.32-573.8.1.el6.x86_64 导入elrepo的key: rpm --import https://www.elrepo.org ...

  6. python-matplotlib-ERROR

    在导入包显示画图时,出错:ImportError: No module named '_tkinter 解决办法:通常原因是tkinter和tk-devel缺失 ERROR: matplotlib的图 ...

  7. Python dictionary 字典

    Python字典是另一种可变容器模型,且可存储任意类型对象,如字符串.数字.元组等其他容器模型. 一.创建字典字典由键和对应值成对组成.字典也被称作关联数组或哈希表.基本语法如下: dict = {' ...

  8. C++ 学习时的错误记录

    1. 关于C++相关的文件扩展名 c++程序中的头文件扩展名包括: .h .hpp .hxx C++程序中源文件的扩展名包括: .cc .cpp .cxx 2.C++程序编译过程 3. 处理错误 4. ...

  9. Java Jsch SFTP 递归下载文件夹

    Java Program For Downloading Folder Content recursively from SFTP Server How to download folder from ...

  10. linux出现Redirecting to /bin/systemctl start mysqld.service,解决方法

    上去就是一个命令     /bin/systemctl start httpd.service