已解决:SQL Server 2012 事务日志已满,原因为“CheckPoint“,报9002错误,无法操作数据。

客户现场的数据库,现象是写入、修改、删除都执行不了,日志文件大小修改不了,增加日志文件同样提示“事务日志已满,原因为CheckPoint“,网上关于SQL Server 2012此错误基本没有,查询数据库状态为CheckPoint状态,其它正常的数据库都是Nothing,尝试过以下方法:

1、脱机、分离,重新附加时删除Log文件,无效,同样错误

2、脱机、分离,创建同名数据库,文件名和日志文件也相同,停止数据库服务,将有数据的数据库主文件覆盖新建的,启动数据库服务,数据库变成成恢复,使用语句修复,报文件不同。

3、通过修改CheckPoint参数为10分钟,保存参数,重启,同样错误

4、按错误提示截断日志,发现SQL Server 2012不再支持日志截断

搞了两个小时,只好去bing搜索国际版,关键词CheckPoint  SQL Server 2012   9002,还真找到了一篇文章,通过Rebuild日志文件解决,语句如下:

ALTER DATABASE DatabaseName  set  EMERGENCY 
ALTER DATABASE DatabaseName  REBUILD LOG ON (NAME='DatabaseName_log',FILENAME='D:\Program Files\Microsoft SQL Server\MSSQL11.MSSQLSERVER\MSSQL\DATA\DatabaseName_Log.LDF')
ALTER DATABASE DatabaseName  set ONLINE
ALTER DATABASE DatabaseName  SET MULTI_USER 

原地址:SQL SERVER - Transaction Log Full Due to 'CHECKPOINT' | SQL Conjuror

  • 1
    点赞
  • 3
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
### 回答1: Flink SQL可以通过设置checkpoint来保证数据的一致性和容错性。具体的设置方法包括: 1. 在Flink SQL的执行环境中,通过设置ExecutionConfig的checkpointingEnabled属性为true来启用checkpoint。 2. 设置checkpoint的间隔时间和超时时间,可以通过ExecutionConfig的checkpointInterval和checkpointTimeout属性来设置。 3. 设置checkpoint的存储位置,可以通过ExecutionConfig的stateBackend属性来设置。 4. 设置checkpoint的并发度,可以通过ExecutionConfig的maxParallelism属性来设置。 5. 在Flink SQL中,可以通过设置TABLE_PROPERTIES属性来设置checkpoint的相关参数,例如: CREATE TABLE myTable ( id INT, name STRING, age INT, PRIMARY KEY (id) NOT ENFORCED ) WITH ( 'connector' = 'kafka', 'topic' = 'myTopic', 'properties.bootstrap.servers' = 'localhost:9092', 'format' = 'json', 'scan.startup.mode' = 'earliest-offset', 'checkpoint.interval.ms' = '10000', 'checkpoint.timeout.ms' = '60000', 'state.backend' = 'rocksdb', 'state.backend.rocksdb.checkpoint.interval' = '10000', 'state.backend.rocksdb.checkpoint.timeout' = '60000', 'max.parallelism' = '4' ); 以上就是Flink SQL设置checkpoint的方法和步骤。 ### 回答2: Apache Flink是一款分布式流处理框架,可用于处理实时的数据流。Flink提供了SQL API,可以使用标准SQL语言处理数据。在使用Flink SQL时,也需要设置CheckpointCheckpoint是一种Flink用于实现容错和恢复的机制,用于将数据流保存到持久存储中。在Flink中,数据被分为一系列的流水线,称为任务链。当收到事件时,它经过一系列的处理步骤,最终被发送到输出。Checkpoint利用Flink的任务链,将数据流保存在状态后端或文件系统中,以避免数据丢失。 在Flink SQL中,通过设置`checkpointInterval`参数来设置Checkpoint间隔。此参数表示执行完每个指定的毫秒数后,Flink将在所有操作完成后执行Checkpoint。接下来,我们将讨论如何在Flink SQL中设置Checkpoint。 首先,我们需要在Flink SQL中创建一个StreamExecutionEnvironment并将其设置为流模式。接下来,为此环境配置Checkpoint属性。以下是示例代码: ``` StreamExecutionEnvironment env = StreamExecutionEnvironment.getExecutionEnvironment(); env.enableCheckpointing(60000); env.getCheckpointConfig().setCheckpointingMode(CheckpointingMode.EXACTLY_ONCE); env.getCheckpointConfig().setMinPauseBetweenCheckpoints(30000); env.getCheckpointConfig().setCheckpointTimeout(10000); env.getCheckpointConfig().setMaxConcurrentCheckpoints(1); ``` 在上面的代码中,`enableCheckpointing(60000)`表示将每隔60秒进行一次Checkpoint。`.setCheckpointingMode(CheckpointingMode.EXACTLY_ONCE)`表示在Checkpoint期间,每个事件仅处理一次。`setMinPauseBetweenCheckpoints(30000)`是两个Checkpoint之间的最小时间间隔。`setCheckpointTimeout(10000)`是检查点超时的时间限制。最后,`setMaxConcurrentCheckpoints(1)`表示不允许同时进行多个Checkpoint。 以上是Flink SQL中设置Checkpoint的步骤和代码示例。通过设置适当的Checkpoint参数,可以确保Flink应用程序的容错性和可靠性,以便在失败时恢复数据。 ### 回答3: Flink SQL是指在Flink平台上使用SQL语言进行数据处理。在实际使用中,我们需要对Flink SQL进行设置checkpoint,以实现数据的可靠性和容错性。 设置checkpoint有两种方式:一种是基于代码实现,另一种是基于Flink Web UI进行配置。 首先,我们需要在代码中启用checkpoint,并设置checkpoint相关的参数,如checkpoint的间隔时间、最大同时进行的checkpoint数量等。然后,在代码中定义一个可靠的存储系统,如HDFS、S3等,用来存储checkpoint数据。 具体地,我们可以通过以下代码启用checkpoint: 1. 在ExecutionEnvironment中设置checkpoint间隔时间和最大同时进行的checkpoint数量: env.enableCheckpointing(5000); // checkpoint每间隔5000ms执行一次 env.getCheckpointConfig().setMaxConcurrentCheckpoints(1); // 最大同时进行的checkpoint数量为1 2. 设置可靠存储系统,以存储checkpoint数据: env.setStateBackend(new FsStateBackend("hdfs:///flink/checkpoint")); 然后,我们还需要在Flink Web UI中进行相关的设置,以确保checkpoint正常运行。 在Flink Web UI中,我们需要打开“Job Manager”页面,并点击“Configure”按钮。在弹出的对话框中,我们可以设置checkpoint的间隔时间、最大同时进行的checkpoint数量等。在“Checkpoint Storage”选项卡中,我们需要选择一个可靠的存储系统,如HDFS、S3等,用来存储checkpoint数据。 最后,我们可以通过在代码中调用env.execute("jobName")方法来启动Flink SQL任务,并在Flink Web UI中查看任务的状态和checkpoint的情况。 总的来说,设置checkpoint是Flink SQL中保证数据可靠性和容错性的重要手段,在实际使用中需要注意参数设置和可靠存储系统的选择。

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值