sql数据库恢复挂起(sql数据库下载及安装)
本篇文章给大家谈谈sql数据库恢复挂起,以及sql数据库下载及安装对应的知识点,文章可能有点长,但是希望大家可以阅读完,增长自己的知识,最重要的是希望对各位有所帮助,可以解决了您的问题,不要忘了收藏本站喔。
sql server数据库显示恢复挂起怎么解决
当 SQL Server数据库显示恢复挂起时,通常是由于数据库在恢复过程中遇到错误或资源冲突导致的。以下是详细的解决步骤:
1.确定原因检查错误日志在 SQL Server Management Studio(SSMS)中,通过以下路径查看错误日志:管理→ SQL Server日志→查找与恢复挂起相关的错误(如 RECOVERY SUSPENDED或 I/O错误)。关键点:记录错误代码和上下文(如文件路径、损坏的页 ID)。
查看 Windows事件查看器在 Windows中打开事件查看器→ Windows日志→应用程序,筛选 SQL Server相关错误,确认是否有系统级问题(如磁盘故障、权限不足)。
2.解决问题步骤 1:清除损坏的日志文件在 SSMS中右键点击数据库→属性→选项→检查日志文件状态。操作:如果发现日志文件大小为 0或标记为“可疑”,尝试分离数据库(任务→分离),手动删除损坏的日志文件(.ldf),然后重新附加数据库(需确保有完整备份)。
注意:此操作可能导致数据丢失,需提前备份。
步骤 2:从备份恢复数据库右键点击数据库→任务→还原→数据库。选择备份源(完整备份+差异/日志备份,如有)。在选项页签勾选覆盖现有数据库,确保恢复模式为完整或大容量日志(根据备份类型)。关键点:若日志链断裂,需使用 WITH REPLACE或 STOPAT参数。步骤 3:重新启动 SQL Server服务在服务管理器(services.msc)中重启 SQL Server(MSSQLSERVER)服务。作用:释放潜在的资源锁或内存冲突。步骤 4:修复损坏的页在 SSMS中执行以下命令(替换<数据库名称>):DBCC CHECKDB('<数据库名称>', REPAIR_REBUILD);若提示更严重的损坏,尝试 REPAIR_ALLOW_DATA_LOSS(需谨慎,可能丢失数据)。
后续操作:修复后再次运行 DBCC CHECKDB验证。
步骤 5:联系 Microsoft支持如果上述步骤无效,收集以下信息并联系支持:错误日志片段、DBCC CHECKDB输出、Windows事件日志。
数据库备份文件(如有)。
SQL Server版本和补丁级别(通过 SELECT@@VERSION获取)。
3.预防措施定期维护:设置自动备份策略,定期执行 DBCC CHECKDB。监控资源:确保磁盘空间充足,避免 I/O瓶颈。高可用性:考虑使用 AlwaysOn可用性组或日志传送减少恢复风险。通过以上步骤,大多数恢复挂起问题可被解决。若问题复杂(如存储损坏),建议优先从备份恢复以减少停机时间。
紧急求救,怎样才能恢复数据库
数据库被挂起了。你可以试一试用下面的方法恢复:
A.现象:Error 926
Severity Level 14
Error Message Text
Database'xx' cannot be opened- it has been marked SUSPECT by recover Explanation
(1)当你使用Transact_SQL命令操作这个数据库的数据时,出现这个信息,这是一个严重的错误,如果你要使用这个数据库的数据,必须改正这个错误.
(2)启动Backup Server,后备master数据库
1>dump database master to"/usr/sybase/master_dump.19991201"
2>go
(3)用isql登录到SQL Server,须用sa帐号(本文以pubs2数据库为例)
1>sp_configure"allow updates", 1
2>go
1>begin tran
2>go
1>update master..sysdatabases
2>set status=-32768
3>Where name="pubs2"
4>go
如果得到(1 row affected),则
1>commit
2>go
否则
1>rollback
2>go
(4.1)如果条件允许,bcp out用户数据或dump用户数据库
(5.1)这时重新启动SQL Server,再有sa帐号注册到SQL Server.
1>begin tran
2>go
1>update master..sysdatabases
2>set status=0
3>Where name="pubs2"
4>go
如果得到(1 row affected),则
1>commit
2>go
否则
1>rollback
2>go
1>sp_configure"allow updates",0
2>go
(4)如果你的数据库原来有dboption(例如"select into","trunc log on chkpt"等),你需要重新设置这些option..
(5)运行dbcc命令检查数据库的一致性
isql-Usa-P-i dbcc.sql-o dbcc.out
dbcc.sql文件示例:
dbcc checkdb("pubs2")
go
dbcc checkalloc("pubs2")
go
dbcc checkcatalog("pubs2")
go
grep Msg dbcc.out
6)后备用户数据库
1>dump database pubs2 on"/usr/sybase/pubs2_dump.19991201"
2>go
B.如何解决数据库被标记为"suspect"的问题之二(数据库设备损坏时的解决方案)?
A.现象: 926错误产生的原因有几种。本文讨论当数据库设备初始化失败(设备文件丢失或文件读写权限不正确)时,导致数据库恢复失败,出现926错误的情况。
(1)请先恢复数据库设备及读写权限。
(2)启动Backup Server,后备master数据库
1>dump database master to"/usr/sybase/master_dump.19991201"
2>go
3)用isql登录到SQL Server,须用sa帐号(本文以pubs2数据库为例)
1>sp_configure"allow updates", 1
2>go
1>begin tran
2>go
1>update master..sysdatabases
2>set status= status- 256
3>Where name="pubs2"
4>go
如果得到(1 row affected),则
1>commit
2>go
否则
1>rollback
2>go
(4)重新启动SQL Server,运行dbcc命令检查数据库的一致性编辑生成dbcc.sql文件:
dbcc checkdb("pubs2")
go
dbcc checkalloc("pubs2")
go
dbcc checkcatalog("pubs2")
go
isql-Usa-P-i dbcc.sql-o dbcc.out
grep Msg dbcc.out
(5)后备用户数据库
1>dump database pubs2 on"/usr/sybase/pubs2_dump.19991201"
2>go
linux 备份的数据库怎么恢复
一、使用mysql相关命令进行简单的本地备份
1 mysqlldump命令
mysqldump是采用SQL级别的备份机制,它将数据表导成 SQL脚本文件,在不同的 MySQL版本之间升级时相对比较合适,这也是最常用的备份方法。
使用 mysqldump进行备份非常简单,如果要备份数据库” db_backup”,使用命令:
#mysqldump–u-p phpbb_db_backup>/usr/backups/mysql/db_backup2008-1-6.sql
还可以使用gzip命令对备份文件进行压缩:
#mysqldump db_backup| gzip>/usr/backups/mysql/ db_backup2008-1-6.sql.gz(备份后生成的sql不含建库语句!)
只备份一些频繁更新的数据库表:
## mysqldump sample_db articles comments links>/usr/backups/mysql/sample_db.art_comm_lin.2008-1-6.sql
上面的命令会备份articles, comments,和links三个表。
恢复数据使用命令:
#mysql–u-p db_backup</usr/backups/mysql/ db_backup2008-1-6.sql
注意使用这个命令时必须保证数据库正在运行。
2使用 SOURCE语法
其实这不是标准的 SQL语法,而是 mysql客户端提供的功能,例如:
# SOURCE/tmp/db_name.sql;
这里需要指定文件的绝对路径,并且必须是 mysqld运行用户(例如 nobody)有权限读取的文件。
3 mysqlhotcopy备份
mysqlhotcopy只能用于备份 MyISAM,并且只能运行在 linux和Unix和 NetWare系统上。mysqlhotcopy支持一次性拷贝多个数据库,同时还支持正则表达。以下是几个例子:
#mysqlhotcopy-h=localhost-u=goodcjh-p=goodcjh db_name/tmp
(把数据库目录 db_name拷贝到/tmp下)
注意,想要使用 mysqlhotcopy,必须要有 SELECT、RELOAD(要执行 FLUSH TABLES)权限,并且还必须要能够有读取 datadir/db_name目录的权限。
还原数据库方法:
mysqlhotcopy备份出来的是整个数据库目录,使用时可以直接拷贝到 mysqld指定的目录(在这里是/usr/local/mysql/data/)目录下即可,同时要注意权限的问题,另外首先应当删除数据库旧副本如下例:
#/bin/rm-rf/mysql-backup/**//*old
关闭mysql服务器、复制文件、查询启动mysql服务器的三个步骤:
#/etc/init.d/mysqld stop
Stopping MySQL: [ OK ]
# cp-af/mysql-backup/**//*/var/lib/mysql/
#/etc/init.d/mysqld start
Starting MySQL: [ OK ]
#chown-R nobody:nobody/usr/local/mysql/data/(将 db_name目录的属主改成 mysqld运行用户)
二、使用网络备份
将MYSQL数据放在一台计算机上是不安全的,所以应当把数据备份到局域网中其他Linux计算机中。假设Mysql服务器IP地址是:192.168.1.3。局域网使用Linux的远程计算机IP地址是192.168.1.4;类似于windows的网络共享,UNIX(Linux)系统也有自己的网络共享,那就是NFS(网络文件系统),在linux客户端挂接(mount)NFS磁盘共享之前,必须先配置好NFS服务端。linux系统NFS服务端配置方法如下:
(1)修改/etc/exports,增加共享目录
/export/home/sunky 192.168.1.4(rw)
/export/home/sunky1*(rw)
/export/home/sunky2 linux-client(rw)
注:/export/home/目录下的sunky、sunky1、sunky2是准备共享的目录,10.140.133.23、*、linux-client是被允许挂接此共享linux客户机的IP地址或主机名。如果要使用主机名linux-client必须在服务端主机/etc/hosts文件里增加linux-client主机ip定义。格式如下:
192.168.1.4 linux-client
若修改/etc/export文件增加新的共享,应先停止NFS服务,再启动NFS服务方能使新增加的共享起作用。使用命令exportfs-rv也可以达到同样的效果。linux客户端挂接(mount)其他linux系统或UNIX系统的NFS共享。这里我们假设192.168.1.4是NFS服务端的主机IP地址,当然这里也可以使用主机名,但必须在本机/etc/hosts文件里增加服务端ip定义。/export/home/sunky为服务端共享的目录。如此就可以在linux客户端通过/mnt/nfs来访问其它linux系统或UNIX系统以NFS方式共享出来的文件了。
把MYSQL数据备份到使用Linux的远程计算机需要在两端都安装NFS协议(Network File System),远程NFS计算机安装NFS协议后还要修改配置文件:/etc/exports,加入一行:
/usr/backups/mysql/ 192.168.1.4(rw, no_root_squash)
表示将/usr/backups/mysql/目录共享。这个目录具有远程root用户读写权限。保存NFS配置文件,然后使用命令:
#exportfs-a–r
然后重新启动NFS服务:
#service nfsd start
远程计算机设定后,在MYSQL服务器/mnt目录下建立一个backup_share目录:
#mkdir/mnt/backup_share
将远程的Linux计算机的/usr/backups/mysql/目录挂载到MYSQL服务器的/mnt/backup_share目录下:
# mount-t nfs 192.168.1.4:/usr/backups/mysql/mnt/backup_share
将目录挂载进来后,只要进入/mnt/backup_share目录,就等于到了IP地址:192.168.1.4那部NFS计算机的/usr/backups/mysql目录中。下面使用mysqldump把“phpbb_db_backup”备份到远程计算机:
# mysqldump db_backup>/mnt/backup_share/ db_backup2008-1-6.sql
自动完成网络备份的方法:
Linux服务器上的程序每天都在更新 MySQL数据库,于是就想起写一个 shell脚本,结合 crontab,定时备份数据库。建立一个shell脚本:sample_db_backup.sh
# At the very end the$(date+%F)自动添加备份日期
mysqldump-u<username>-p<password>-h<hostname> sample_db>/mnt/backup_share/sample_db.$(date+%F)
#un-mount the filesystem
umount/mnt/backup_share
# mount\u2013o soft 192.168.1.4:/archive/mnt/backup_share
说明:mount NFS服务器的一个重要参数:hard(硬) mount或soft(软)mount。
硬挂载: NFS客户机会不断的尝试与NFS服务器的连接(在后台,一般不会给出任何提示信息),直到挂载上为止。
软挂载:会在前台尝试与NFS服务器的连接,是默认的连接方式。当收到错误信息后终止mount尝试,并给出相关信息。
对于到底是使用硬挂载还是软挂载的问题,这主要取决于你访问什么信息有关。例如你是想察看NFS服务器的视频文件时,你绝对不会希望由于一些意外的情况(如网络速度一下子变的很慢)而使系统输出大量的错误信息,如果此时你用的是硬挂载方式的话,系统就会等待,直到能够重新与NFS服务器建立连接传输信息。另外如果是非关键数据的话也可以使用软挂载方式,如FTP一些数据等,这样在远程机器暂时连接不上或关闭时就不会挂起你的会话过程。
下面建立脚本文件权限:chmod+x./sample_db_backup.sh
然后使用将此脚本加到/etc/crontab定时任务中:
01 5** 0 mysql/home/mysql/ sample_db_backup.sh
好了,每周日凌晨 5:01系统就会自动运行 sample_db_backup.sh文件通过网络备份 MySQL数据库了。
三、实时恢复M y S Q L数据方法
在对MySQL数据和表格结构进行备份时,mysqldump是一个非常有用的工具。然而,通常情况下,一般一天只备份一次,或者在一个特定的间隔备份一次。如果在刚备份完成的一段时间以内数据丢失,那么这些数据很有可能无法恢复。有什么方法可以对数据进行实时性地保护呢?事实上,现在有几种方法都可以实现MySQL数据库的实时保护。这里介绍其中一种,即使用二进制日志进行数据恢复。
1设置二进制日志方法
要想从二进制日志恢复数据,你需要知道当前二进制日志文件的路径和文件名。一般可以从选项文件(即my.cnf or my.ini,取决于你的系统)中找到路径。如果未包含在选项文件中,当服务器启动时,可以在命令行中以选项的形式给出。启用二进制日志的选项为-- log-bin。要想确定当前的二进制日志文件的文件名,输入下面的MySQL语句:
# SHOW BINLOG EVENTS\G
2最简单的数据恢复
每天备份和运行二进制日志的确是一个在MySQL服务器中恢复数据的不错方法。比如,可以每天在深夜使用mysqldump对数据进行备份,如果某天在数据备份完成后的一段时间里,由于某种原因数据丢失,可以使用以下方法来对其进行恢复。首先,停止MySQL服务器,然后使用以下命令重新启动MySQL服务器。该命令将保证是惟一可以访问该数据库服务器的人:
#/etc/init.d/mysqld stop
Stopping MySQL: [ OK ]
# mysqld--socket=/tmp/mysql_restore.sock--skip-networking
这里,一socket选项将为U n i x系统命名一个不同的Socket文件。一旦服务器处于独占控制之下,就可以放心地对数据库进行操作,而不用担心在进行数据恢复的过程中有用户尝试访问数据库而导致更多的麻烦。进行恢复的第一个步骤是恢复晚上备份好的dump文件:
#mysql-u root-pmypwd--socket=/tmp/mysql_restore.sock</var/backup/20080120.sql
该命令可以将数据库的内容恢复至晚上刚刚完成备份的内容。要恢复dump文件创建后的数据库事务处理,可以使用mysqlbinlog工具。如果每天晚上进行备份操作时都对日志进行flush操作,则可以使用以下命令行工具将整个二进制日志文件进行恢复:
mysqlbinlog/var/log/mysql/bin.123456\
| mysql-u root-pmypwd--socket=/tmp/mysql_restore.sock
3针对某一时问点的恢复
对于MySQL 4.1.4,可以在mysqlbinlog语句中通过--start-date和--stop-date选项指定DATETIME格式的起止时间。假设用户在2008-1-22上午10点执行的SQL语句删除了一个大的数据表,则可以使用以下命令进行恢复:要想恢复表和数据,你可以恢复前晚上的备份,并输入:
#mysqlbinlog--stop-date="2008-1-22 9:59:59"
/var/log/mysql/bin.123456|
mysql-u root-pmypwd\
--socket=/tmp/mysql_restore.sock
#mysql-u root-pmypwd
该语句将恢复所有给定一stop-date日期之前的数据。如果在执行某SQL语句数小时之后才发现执行了错误操作,那么可能还需要恢复之后输入的一些数据。这时,也可以通过mysqlbinlog来完成该功能:
#mysqlbinlog--start-date="2008-1-22 10:01:00"\
/var/log/mysql/bin.123456\
| mysql-u root-pmypwd\
--socket=/tmp/mysql_restore.sock
#mysql-u root-pmypwd
在该行中,从上午10:01登录的SQL语句将运行。组合执行前夜的转储文件和mysqlbinlog的两行可以将所有数据恢复到上午10:00前一秒钟。你应检查日志以确保时间确切。
4使用Position进行恢复
也可以不指定日期和时间,而使用mysqlbinlog的选项--start-position和--stop-position来指定日志位置。它们的作用与起止日选项相同,不同的是给出了从日志起的位置号。使用日志位置是更准确的恢复方法,特别是当由于破坏性SQL语句同时发生许多事务的时候。要想确定位置号,可以运行mysqlbinlog寻找执行了不期望的事务的时间范围,但应将结果重新指向文本文件以便进行检查。操作命令为:
mysqlbinlog--start-date="2005-04-20 9:55:00"--stop-date="2005-04-20 10:05:00"
/var/log/mysql/bin.123456>/tmp/mysql_restore.sql
该命令将在/tmp目录创建小的文本文件,将显示执行了错误的SQL语句时的SQL语句。你可以用vi或者gedit文本编辑器打开该文件,寻找你不要想重复的语句。如果二进制日志中的位置号用于停止和继续恢复操作,应进行注释。用log_pos加一个数字来标记位置。使用位置号恢复了以前的备份文件后,你应从命令行输入下面内容:
mysqlbinlog--stop-position="368312"/var/log/mysql/bin.123456
| mysql-u root-pmypwd
mysqlbinlog--start-position="368315"/var/log/mysql/bin.123456
| mysql-u root-pmypwd
上面的第1行将恢复到停止位置为止的所有事务。下一行将恢复从给定的起始位置直到二进制日志结束的所有事务。因为mysqlbinlog的输出包括每个SQL语句记录之前的SET TIMESTAMP语句,恢复的数据和相关MySQL日志将反应事务执行的原时间。
关于sql数据库恢复挂起到此分享完毕,希望能帮助到您。