Spring事务管理报错Transaction rolled back because it has been marked as rollback-only
2023-02-14 05:16:15 来源:腾讯云

事务是我们平时项目中对数据操作最为直接、常用的方式,现在无论是大小公司都离不开对事务的操作,伴随业务的提升,客户量的积累也大大增加了对事务管理的难度。


【资料图】

在本章节中将会讲到如下内容:

1、线上环境对roll back only 的处理2、线上环境对嵌套事务的解决方案3、11个demo分析事务失效的场景4、分布式事务5、事务也能异步

1、线上环境对roll back only 的处理与产生

org.springframework.dao.CannotAcquireLockException: ### Error updating database.  Cause: com.mysql.cj.jdbc.exceptions.MySQLTransactionRollbackException: Lock wait timeout exceeded; try restarting transaction### The error may involve xxxMapper.insert-Inline### The error occurred while setting parameters### SQL: INSERT INTO xxx### Cause: com.mysql.cj.jdbc.exceptions.MySQLTransactionRollbackException: Lock wait timeout exceeded; try restarting transaction; Lock wait timeout exceeded; try restarting transaction; nested exception is com.mysql.cj.jdbc.exceptions.MySQLTransactionRollbackException: Lock wait timeout exceeded; try restarting transaction

产生原因:

事务嵌套,内层事务将异常捕获未抛出。

2、线上环境对嵌套事务的解决方案

优化点可以从以下几点进行考虑:

最为直接的方法便是去掉嵌套事务,在controller层统一决定异常处理

对于类似开发过程中,需考虑将相关方法长事务中查询方法剔除,将方法内事务缩短为最小事务

出现突发情况,应提供最为简单有效的方案,让业务正常操作,不受影响

开发应对当时的技术方案告知相关测试

在代码层面,后续代码需要前面操作事务释放锁

无需等待插入结果 直接插入后续数据

将查询放在事务外面尽量将大事务变为小事务

捕获异常 自动重试

但是短时间内我还没有时间进行整改,在不影响主流程的情况下未进行整改,但我后续才知道大错特错。

排查

@timestamp September 1st 2021, 10:20:24.637# @version  1t LOG_DATEFORMAT_PATTERN    yyyy-MM-dd HH:mm:ss.SSSt LOG_LEVEL_PATTERN %5pt _id   VMaGt _index    applog-2021.09.01# _score    1t _type doct appindex  applogt appname   appt host  10.0.74.157t level ERROR# level_value   40,000t logger_name   ExceptionLogCollectort message   未知异常[500] => Transaction rolled back because it has been marked as rollback-only# port  10,792t stack_trace   org.springframework.transaction.UnexpectedRollbackException: Transaction rolled back because it has been marked as rollback-onlyat org.springframework.transaction.support.AbstractPlatformTransactionManager.processRollback(AbstractPlatformTransactionManager.java:873) ~[spring-tx-5.1.4.RELEASE.jar!/:5.1.4.RELEASE]at org.springframework.transaction.support.AbstractPlatformTransactionManager.commit(AbstractPlatformTransactionManager.java:710) ~[spring-tx-5.1.4.RELEASE.jar!/:5.1.4.RELEASE]at org.springframework.transaction.interceptor.TransactionAspectSupport.commitTransactionAfterReturning(TransactionAspectSupport.java:533) ~[spring-tx-5.1.4.RELEASE.jar!/:5.1.4.RELEASE]at org.springframework.transaction.interceptor.TransactionAspectSupport.invokeWithinTransaction(TransactionAspectSupport.java:304) ~[spring-tx-5.1.4.RELEASE.jar!/:5.1.4.RELEASE]at org.springframework.transaction.interceptor.TransactionInterceptor.invoke(TransactionInterceptor.java:98) ~[spring-tx-5.1.4.RELEASE.jar!/:5.1.4.RELEASE]at org.springframework.aop.framework.ReflectiveMethodInvocation.proceed(ReflectiveMethodInvocation.java:186) ~[spring-aop-5.1.4.RELEASE.jar!/:5.1.4.RELEASE]at org.springframework.aop.framework.CglibAopProxy$DynamicAdvisedInterceptor.intercept(CglibAopProxy.java:688) ~[spring-aop-5.1.4.RELEASE.jar!/:5.1.4.RELEASE]spring-tx-5.1.4.RELEASE.jar-org.springframework.transaction.interceptor.TransactionInterceptor#事务拦截器avatar

spring事务分为声明式事务和编程式事务,若目标方法存在事务,spring会对bean生成一个代理对象,从日志来看是cglib的

入口98行springaop事务增强 TransactionAspectSupport在事务中的调用,执行代理类的目标方法触发invoke

@Nullableprotected Object invokeWithinTransaction(Method method, @Nullable Class targetClass,            final InvocationCallback invocation) throws Throwable方法为protected的,根据源代码注释解析

if (txAttr == null || !(tm instanceof CallbackPreferringPlatformTransactionManager))

如果事务属性为null 且事务类型是CallbackPreferringPlatformTransactionManager进入304行commitTransactionAfterReturning(txInfo);方法

意为事务成功后执行,有异常不执行,没有事务不执行,也就是为后面的事务方法异常时没执行进行了铺垫,533行

txInfo.getTransactionManager().commit(txInfo.getTransactionStatus());事务进行commit时进行判断

如果不是进行全局事务提交 但是是RollbackOnly的话

走processRollback处理实际回滚

@Override    public final void commit(TransactionStatus status) throws TransactionException {        if (status.isCompleted()) {            throw new IllegalTransactionStateException(                    "Transaction is already completed - do not call commit or rollback more than once per transaction");        }        DefaultTransactionStatus defStatus = (DefaultTransactionStatus) status;        if (defStatus.isLocalRollbackOnly()) {            if (defStatus.isDebug()) {                logger.debug("Transactional code has requested rollback");            }            processRollback(defStatus, false);            return;        }        if (!shouldCommitOnGlobalRollbackOnly() && defStatus.isGlobalRollbackOnly()) {            if (defStatus.isDebug()) {                logger.debug("Global transaction is marked as rollback-only but transactional code requested commit");            }            日志追踪的710行-----记住此处传true            processRollback(defStatus, true);            return;        }        processCommit(defStatus);    }private void processRollback(DefaultTransactionStatus status, boolean unexpected) {        try {            入参为true            boolean unexpectedRollback = unexpected;            try {                triggerBeforeCompletion(status);                if (status.hasSavepoint()) {                    if (status.isDebug()) {                        logger.debug("Rolling back transaction to savepoint");                    }                    status.rollbackToHeldSavepoint();                }                else if (status.isNewTransaction()) {                    if (status.isDebug()) {                        logger.debug("Initiating transaction rollback");                    }                    doRollback(status);                }                else {                    // Participating in larger transaction                    if (status.hasTransaction()) {                        if (status.isLocalRollbackOnly() || isGlobalRollbackOnParticipationFailure()) {                            if (status.isDebug()) {                                logger.debug("Participating transaction failed - marking existing transaction as rollback-only");                            }                            doSetRollbackOnly(status);                        }                        else {                            if (status.isDebug()) {                                logger.debug("Participating transaction failed - letting transaction originator decide on rollback");                            }                        }                    }                    else {                        logger.debug("Should roll back transaction but cannot - no transaction available");                    }                    // Unexpected rollback only matters here if we"re asked to fail early                    if (!isFailEarlyOnGlobalRollbackOnly()) {                        unexpectedRollback = false;                    }                }            }            catch (RuntimeException | Error ex) {                triggerAfterCompletion(status, TransactionSynchronization.STATUS_UNKNOWN);                throw ex;            }            triggerAfterCompletion(status, TransactionSynchronization.STATUS_ROLLED_BACK);            日志追踪的873行  抛出异常            // Raise UnexpectedRollbackException if we had a global rollback-only marker            if (unexpectedRollback) {                throw new UnexpectedRollbackException(                        "Transaction rolled back because it has been marked as rollback-only");            }        }        finally {            cleanupAfterCompletion(status);        }    }

事务这里场景和传播行为相关知识点太多了,这个后续接着分析

但就此场景将伪代码贴一下

try    {        methodA()    }catch    {    }    @Transactional(rollbackFor = Exception.class)    public methodA() {        methodB()    }    @Transactional(rollbackFor = Exception.class)    public methodB() {        try {            methodC()        } catch {        }    }    methodC() {        当C方法抛出异常时    }

不知道大家对于rpc行为调用的接口是如何处理的,我们以前是将rpc调用的接口有Biz接收进来,进行参数处理,领域模型转换后,调取service进行内部数据处理的,但此时的接口在主流程上会伴随着另一个第三方接口的写操作,需进行事务处理,那么内层service接口为什么还要进行事务管理?在设计上理应不对rpc接口操作的service进行开放调用的,但业务上区分不同场景,不同供应商,不同酒店等对接口进行了反射调用,或者app调用,导致内层service也进行了事务操作,那么问题来了,嵌套事务时,如果内层事务注解取消不抛出

UnexpectedRollbackException,实际此方法内并没有完全执行完,

我希望是怎样的?我希望在保持事务原子性的前提,内层事务回滚则整个全局事务回滚,且不报此异常

第一种方法isGlobalRollbackOnParticipationFailure方法,让主事务来决定是否回滚,

改动成本大

而在Springaop中,被拦截的方法需要显式的抛出异常,并不能经过任何处理,这样aop才能进行回滚,默认aop是只catchruntimeException的异常 第二种方法可以在catch块里加上 TransactionAspectSupport.currentTransactionStatus().setRollbackOnly() 手动回滚 即便上层事务发生了异常,也想要最终提交整个事务呢?如果有这样的需求的话,可以给事务管理器配置一个参数 setGlobalRollbackOnParticipationFailure(false); # 改动成本大

解决方案:在内层方法中不进行方法的try catch,有异常操作时在外层事务进行处理,且可决定是否回滚,特定的异常也再次处理

回顾:事务的失效场景(事务不生效和事务不回滚)

3、11个demo分析事务失效的场景

@Slf4j@Servicepublic class DemoService {@Autowiredprivate Test1Mapper test1Mapper;@Autowiredprivate TestMapper testMapper;@Autowiredprivate InvalidTransactionService invalidTransactionService;@Autowiredprivate ExecutorService executorService;@Autowiredprivate DemoService _self;@Autowiredprivate ValidTransactionService validTransactionService;@Autowiredprivate RequireNewTransactionService requireNewTransactionService;/******************************************************** * 事务不生效场景1 * 相当于调用this调用,没有产生代理对象调用,解决方法,自己把自己注入以后调用 ********************************************************/public void demo1() {invalidTransaction();//TODO other logic code here}@Transactionalpublic void invalidTransaction() {TestDO test = new TestDO();test.setName("11111");testMapper.insert(test);Test1DO test1 = new Test1DO();test1.setCust("2222");test1Mapper.insert(test1);throw new WMSException(ErrorCodeEnum.BD10001001.code(),"事务不生效场景1");}/******************************************************** * 事务不生效场景二 * 这个例子的目的是为了catch住内层事务的异常,让外层事务成功,但是实际上没有内外层事务都回滚了 * * 这里A和B都受事务控制,并且是处于同一个事务的。 * A调用B,A中抓了B的异常,当B发生异常的时候,B的操作应该回滚,但是A吃了异常,A方法中没有产生异常,所以A的操作又应该提交,二者是相互矛盾的。 * spring的事务关联拦截器在抓到B的异常后就会标记rollback-only为true,当A执行完准备提交后,发现rollback-only为true,也会回滚,并抛出异常告诉调用者。 * * 报错提示:Transaction rolled back because it has been marked as rollback-only * * 如果想使外层事务生效可以把内层事务传播特性修改为:@Transactional(propagation = Propagation.REQUIRES_NEW) *  ********************************************************/@Transactionalpublic void demo2() {TestDO test = new TestDO();test.setName("3333");testMapper.insert(test);try {invalidTransactionService.transaction();}catch (Exception e) {log.error("服务异常,异常被捕获", e);}}/******************************************************** * 事务不生效场景三 * * 因为开了线程异步执行,等于事务完全在两个线程内,不在一个线程,所以即使抛错,也是一个生效一个不生效, * 事务没有回滚 *  ********************************************************/@Transactionalpublic void demo3() {TestDO test = new TestDO();test.setName("5555");testMapper.insert(test);executorService.execute(() -> {Test1DO test1 = new Test1DO();test1.setCust("6666");test1Mapper.insert(test1);});throw new WMSException(ErrorCodeEnum.BD10001001.code(),"事务不生效场景3");}/******************************************************** * 事务不生效场景八 * Spring默认情况下会对运行期例外(RunTimeException)进行事务回滚。这个例外是unchecked,如果遇到checked意外就不回滚。 * Exception包含RuntimeException体系和其他非RuntimeException的体系 * Error和RuntimeException及其子类成为未检查异常(unchecked),其它异常成为已检查异常(checked)。 * spring声明式事务管理默认对非检查型异常和运行时异常进行事务回滚,而对检查型异常则不进行回滚操作 * * *那么什么是检查型异常什么又是非检查型异常呢? * 1.继承自runtimeexception或error的是非检查型异常,而继承自exception的则是检查型异常(当然,runtimeexception本身也是exception的子类)。 * 2.对非检查型类异常可以不用捕获,而检查型异常则必须用try语句块进行处理或者把异常交给上级方法处理总之就是必须写代码处理它。所以必须在service捕获异常,然后再次抛出,这样事务方才起效。 * * @throws IOException  *  ********************************************************/@Transactionalpublic void demo8() throws IOException {TestDO test = new TestDO();test.setName("11111");testMapper.insert(test);Test1DO test1 = new Test1DO();test1.setCust("2222");test1Mapper.insert(test1);throw new IOException("事务不生效场景8");}/******************************************************** * 事务不生效场景九 * @throws IOException  *  ********************************************************/public void demo9(){invalidTransaction2();}@Transactionalprivate void invalidTransaction2() {TestDO test = new TestDO();test.setName("11111");testMapper.insert(test);Test1DO test1 = new Test1DO();test1.setCust("2222");test1Mapper.insert(test1);throw new WMSException("事务不生效场景9");}/******************************************************** * 事务生效场景1 *  ********************************************************/public void demo4() {_self.invalidTransaction();//TODO other logic code here}/******************************************************** * 事务生效场景二 * * 因为内层没有事务控制,所以内层报错,不会混回滚,同样外层catch住,所以外层业务成功 ********************************************************/@Transactionalpublic void demo5() {TestDO test = new TestDO();test.setName("7777");testMapper.insert(test);try {validTransactionService.transaction();}catch (Exception e) {log.error("服务异常,异常被捕获", e);}}/******************************************************** * 事务生效场景三 * *内层事务配置的是REQUIRES_NEW,表示自己用自己的,不和外层有牵连,内层如果报错,事务会回滚 * 外层如果catch住了,就可以正常执行,外层生效,内层回滚 ********************************************************/@Transactionalpublic void demo6() {TestDO test = new TestDO();test.setName("9999");testMapper.insert(test);try {requireNewTransactionService.transactionWithException();}catch (Exception e) {log.error("服务异常,异常被捕获", e);}}/******************************************************** * 独立事务 * 内外层事务独立,内层操作未报错,事务正常执行,外层有错,事务回滚。 ********************************************************/@Transactionalpublic void demo7() {TestDO test = new TestDO();test.setName("9999");testMapper.insert(test);requireNewTransactionService.transaction();throw new WMSException(ErrorCodeEnum.BD10001001.code(),"独立事务");}}

4、分布式事务以及分布式事务嵌套

一次业务操作需要跨多个数据源或需要垮多个系统进行远程调用,就会产生分布式事务问题

全局事务一致性问题

全局事务id+三组件 tc+tm+rm

Seata(AT 模式)的默认全局隔离级别是 读未提交(Read Uncommitted)

Seata 是 Simple Extensible Autonomous Transaction Architecture 的简写,由 feascar 改名而来。

AT模式 默认

TCC模式

XA模式

SAGA模式 长事务解决方案

XID 由ip 端口号 加全局事务id生成

关于分布式事务,工程领域主要讨论的是强一致性和最终一致性的解决方案。典型方案包括:

两阶段提交(2PC, Two-phase Commit)方案

eBay 事件队列方案

TCC 补偿模式

缓存数据最终一致性

一致性理论

分布式事务的目的是保障分库数据一致性,而跨库事务会遇到各种不可控制的问题,如个别节点永久性宕机,像单机事务一样的ACID是无法奢望的。另外,业界著名的CAP理论也告诉我们,对分布式系统,需要将数据一致性和系统可用性、分区容忍性放在天平上一起考虑。

两阶段提交协议(简称2PC)是实现分布式事务较为经典的方案,但2PC 的可扩展性很差,在分布式架构下应用代价较大,eBay 架构师Dan Pritchett 提出了BASE 理论,用于解决大规模分布式系统下的数据一致性问题。BASE 理论告诉我们:可以通过放弃系统在每个时刻的强一致性来换取系统的可扩展性。

CAP理论在分布式系统中,一致性(Consistency)、可用性(Availability)和分区容忍性(Partition Tolerance)3 个要素最多只能同时满足两个,不可兼得。

其中,分区容忍性又是不可或缺的。

avatar

一致性:分布式环境下多个节点的数据是否强一致。可用性:分布式服务能一直保证可用状态。当用户发出一个请求后,服务能在有限时间内返回结果。分区容忍性:特指对网络分区的容忍性。举例:Cassandra、Dynamo

等,默认优先选择AP,弱化C;HBase、MongoDB 等,默认优先选择CP,弱化A。

BASE理论核心思想:

基本可用(BasicallyAvailable):指分布式系统在出现故障时,允许损失部分的可用性来保证核心可用。

软状态(SoftState):指允许分布式系统存在中间状态,该中间状态不会影响到系统的整体可用性。

最终一致性(EventualConsistency):指分布式系统中的所有副本数据经过一定时间后,最终能够达到一致的状态。

一致性模型数据的一致性模型可以分成以下 3 类:强一致性:数据更新成功后,任意时刻所有副本中的数据都是一致的,一般采用同步的方式实现。 弱一致性:数据更新成功后,系统不承诺立即可以读到最新写入的值,也不承诺具体多久之后可以读到。 最终一致性:弱一致性的一种形式,数据更新成功后,系统不承诺立即可以返回最新写入的值,但是保证最终会返回上一次更新操作的值。 分布式系统数据的强一致性、弱一致性和最终一致性可以通过Quorum NRW算法分析。分布式事务解决方案2PC方案——强一致性2PC的核心原理是通过提交分阶段和记日志的方式,记录下事务提交所处的阶段状态,在组件宕机重启后,可通过日志恢复事务提交的阶段状态,并在这个状态节点重试,如Coordinator重启后,通过日志可以确定提交处于Prepare还是PrepareAll状态,若是前者,说明有节点可能没有Prepare成功,或所有节点Prepare成功但还没有下发Commit,状态恢复后给所有节点下发RollBack;若是PrepareAll状态,需要给所有节点下发Commit,数据库节点需要保证Commit幂等。avatar2PC方案的问题:同步阻塞。数据不一致。单点问题。升级的3PC方案旨在解决这些问题,主要有两个改进:增加超时机制。两阶段之间插入准备阶段。但三阶段提交也存在一些缺陷,要彻底从协议层面避免数据不一致,可以采用Paxos或者Raft算法。eBay 事件队列方案——最终一致性eBay 的架构师Dan Pritchett,曾在一篇解释BASE 原理的论文《Base:An AcidAlternative》中提到一个eBay分布式系统一致性问题的解决方案。它的核心思想是将需要分布式处理的任务通过消息或者日志的方式来异步执行,消息或日志可以存到本地文件、数据库或消息队列,再通过业务规则进行失败重试,它要求各服务的接口是幂等的。描述的场景为,有用户表user和交易表transaction,用户表存储用户信息、总销售额和总购买额,交易表存储每一笔交易的流水号、买家信息、卖家信息和交易金额。如果产生了一笔交易,需要在交易表增加记录,同时还要修改用户表的金额。avatar论文中提出的解决方法是将更新交易表记录和用户表更新消息放在一个本地事务来完成,为了避免重复消费用户表更新消息带来的问题,增加一个操作记录表updates_applied来记录已经完成的交易相关的信息。

这个方案的核心在于第二阶段的重试和幂等执行。失败后重试,这是一种补偿机制,它是能保证系统最终一致的关键流程。

TCC (Try-Confirm-Cancel)补偿模式——最终一致性

某业务模型如图,由服务 A、服务B、服务C、服务D 共同组成的一个微服务架构系统。服务A 需要依次调用服务B、服务C 和服务D

共同完成一个操作。当服务A 调用服务D 失败时,若要保证整个系统数据的一致性,就要对服务B 和服务C 的invoke

操作进行回滚,执行反向的revert 操作。回滚成功后,整个微服务系统是数据一致的。

avatar

实现关键要素:服务调用链必须被记录下来。每个服务提供者都需要提供一组业务逻辑相反的操作,互为补偿,同时回滚操作要保证幂等。必须按失败原因执行不同的回滚策略。

缓存数据最终一致性

在我们的业务系统中,缓存(Redis 或者Memcached)通常被用在数据库前面,作为数据读取的缓冲,使得I/O

操作不至于直接落在数据库上。以商品详情页为例,假如卖家修改了商品信息,并写回到数据库,但是这时候用户从商品详情页看到的信息还是从缓存中拿到的过时数据,这就出现了缓存系统和数据库系统中的数据不一致的现象。

要解决该场景下缓存和数据库数据不一致的问题我们有以下两种解决方案:为缓存数据设置过期时间。当缓存中数据过期后,业务系统会从数据库中获取数据,并将新值放入缓存。这个过期时间就是系统可以达到最终一致的容忍时间。更新数据库数据后同时清除缓存数据。数据库数据更新后,同步删除缓存中数据,使得下次对商品详情的获取直接从数据库中获取,并同步到缓存。

常用组件: Seata,Sega,Atomikos

avatar

TC (Transaction Coordinator) - 事务协调者

维护全局和分支事务的状态,驱动全局事务提交或回滚。

TM (Transaction Manager) - 事务管理器

定义全局事务的范围:开始全局事务、提交或回滚全局事务。

RM (Resource Manager) - 资源管理器

管理分支事务处理的资源,与TC交谈以注册分支事务和报告分支事务的状态,并驱动分支事务提交或回滚。

avatar

安装

关键注解全局@GlobalTranstional

1.更改事务组名称service

2.store更改mode 修改db

3.执行sql

4.修改注册进nacos

5.启动seata-server.bat

如何保证分布唯一全局id的生成

5、分布式事务异步方案

看下分布式事务的异步问题,根据事务的xid搭配future在切面里对注解进行处理,实现异步+分布式事务的并存

注意事项

这个依赖只是用来解决部分问题,不是解决全部问题

这个仅用于TM端,不要用来RM端(其实要实现RM端的话,可以仿照SeataAsyncAspect,写一个aspect,很简单的)

不要进行事务嵌套,不支持事务嵌套!!!

确保异步的多个操作之间是没有先后顺序的

这个是一个私人包装处理,仅供参考,还未应用到生产环境

—-待续

Spring事务管理报错Transaction rolled back because it has been marked as rollback-only

2023-02-14

坚强不屈的反义词是什么词

2023-02-14

天天快资讯:嗜酸乳杆菌_说一说嗜酸乳杆菌的简介

2023-02-14

名侦探柯南中冲矢昴身份

2023-02-13

全球今日报丨GT20029美国I期临床试验获积极结果 开拓药业-B涨3.52%

2023-02-13

首秀来了!41分钟轰下21分13助!林书豪终于打回巅峰-环球快讯

2023-02-13

环球聚焦:《崩坏 星穹铁道》虎克的礼物任务攻略

2023-02-13

天天播报:南京开春首场盛大花事:以梅为“媒”引海内外赏花客深度游

2023-02-13

工厂车间卫生管理制度及流程_工厂车间卫生管理制度 天天观察

2023-02-13

国家药监局2023年1月共批准注册124个医疗器械产品_速读

2023-02-13

退圈19年,无儿无女无工作:王祖贤的快乐,你根本想象不到-全球即时看

2023-02-13

当前关注:医院怎么检查是不是宫外孕_怎么检查是不是宫外孕

2023-02-13

农牧场全能助手下载_农牧场全能助手

2023-02-12

热点在线丨江西湖口:人勤春来早 田间施肥忙

2023-02-12

小虎拿下换队后首个MVP!成拯救WBG的英雄!春之虎帝在延续 世界快看

2023-02-12

焦点速讯:父亲送女儿出嫁致辞

2023-02-12

热点!市工商联:创新服务理念 做实“助企发展”

2023-02-11

环球简讯:山东地正实业有限公司

2023-02-11

如何减掉肚子上的脂肪男生_如何减掉肚子上的脂肪

2023-02-11

广东河源发生4.3级地震,暂无人员伤亡报告 全球速看

2023-02-11

全球快资讯丨国有大行精准赋能制造业 中小银行力挺小微企业

2023-02-11

【全球速看料】运算器包括寄存器_运算器 控制器和寄存器属于什么

2023-02-11

小儿豉翘清热颗粒有两种吗_什么是小儿豉翘清热颗粒-世界观天下

2023-02-11

什么是金砖国家-全球动态

2023-02-11

差速电机和普通电机的区别_差速电机

2023-02-10

每日视点!ipad软件下载慢_ipad软件下载中心

2023-02-10

龙虎榜丨恒烁股份今日涨7.73% 机构合计净卖出5819.71万元

2023-02-10

5g覆盖城市数量排名_5g覆盖城市|全球微速讯

2023-02-10

微资讯!做网站软文有哪些好处 这些你都知道吗

2023-02-10

大学生房屋出租合同范本(合集19篇)-天天时快讯

2023-02-10

2023年“春风行动暨就业援助月”正式启动_滚动

2023-02-10

惠朗装订机好用吗 Wilion装订机质量怎么样 当前观点

2023-02-10

逢年过节女友从来没给送过什么礼物

2023-02-10

2023年江苏省家电产业发展现状分析 吸尘器年产量连续突破7000万台【组图】

2023-02-10

今亮点!中国1月PPI同比下降0.8%,前值下降0.7%

2023-02-10

空间农场打不开

2023-02-10

收到的礼品是假货怎么办 每日热门

2023-02-10

东北菜谱家常菜做法大全视频_东北菜谱家常菜做法

2023-02-10

天天观天下!什么叫针砭时弊_针砭时弊的意思

2023-02-10

减肥期间能吃山竹不_减肥期间可以吃山竹吗

2023-02-10

当前观察:家族群好听的群名,好听个性的群家族名称

2023-02-10

10岁小男孩送什么礼物,来一波很有创意的 全球速看

2023-02-09

环球速递!费氏各色牡丹鹦鹉_费氏各色牡丹鹦鹉 犯法

2023-02-09

当日快讯:阳光城:已到期未支付债务本金合计460.18亿元

2023-02-09

华西村负债多少个亿,天下第一村华西村负债389亿 神话倒塌了

2023-02-09

每日头条!进入二月第一个十年,生肖4吉星闪耀,运势大增,喜事重演,日子顺风顺水

2023-02-09

宣讲现场|内江市委宣讲团走进市信访局宣讲

2023-02-09

珠海女子销毁毒狗药物时中毒身亡,毒狗药物从何而来?

2023-02-09

王者荣耀赛季什么时候更新 王者荣耀赛季更新时间|热推荐

2023-02-09

大众高尔夫R评论

2023-02-09

每日速看!汉字小故事20字简短 简短的小故事盘点

2023-02-09

长子农商行岚水支行念好“三字诀”迎战“开门红”

2023-02-09

02月09日06时陕西延安昨日累计报告阳性感染者确诊78例 怎么判断自己是否属于轻型感染者 全球热议

2023-02-09

80泪_天天速递

2023-02-09

南都电源董事醉驾 朱保义现在怎样及照片引关注|微速讯

2023-02-09

ART021

2023-02-09

重点聚焦!经典国货化妆品推荐

2023-02-09

天天看点:瓦格纳法则认为政府支出随着政府的职能扩大而增长_瓦格纳法则

2023-02-09

安史之乱祸首安禄山生平简介

2023-02-08

向身边的劳动者学习!海珠青少年在社区公益中有收获

2023-02-08

*ST金洲收关注函:要求说明是否通过突击新增业务等方式增加2022年年收入规模,从而规避终止上市情形

2023-02-08

duyiwu2d

2023-02-08

环球快讯:温州大学是几本_温州大学宿舍环境怎么样最新

2023-02-08

美国恐怖片大全1080p_美国恐怖片大全|世界聚焦

2023-02-08

FL-955

2023-02-08

2022年的高考作文范文(精选10篇)_世界实时

2023-02-08

恒久科技2月8日盘中涨停

2023-02-08

电脑360卸载的软件怎么恢复_360卸载的软件怎么恢复

2023-02-08

热推荐:广岛核爆受害者子女向国家索赔 日本法院驳回诉讼

2023-02-08

新婚夫妻蜜月旅行的9大注意事项 今热点

2023-02-08

【全球新要闻】它非常聪明的英文怎么写_聪明的英文怎么写

2023-02-08

每日快看:三年级数学下册位置与方向测试题与答案_三年级数学下册位置与方向测试题

2023-02-08

纸杯蛋糕的三大做法

2023-02-08

什么叫手机号码归属地_手机号码归属地是什么意思|世界快资讯

2023-02-08

基层四项目人员是什么意思_四项目人员是什么意思

2023-02-08

榴莲怎么挑_如何挑选榴莲-当前热讯

2023-02-08

MINI或将在3月1日推出全新代理销售模式 可能采用直销模式

2023-02-07

炒玉米怎么做|新消息

2023-02-07

撸起袖子加油干 努力夺取开门红丨哈尔滨出台购房新政 ●符合政策人员购新房可享1万元~10万元补贴 ●二手房公积金贷款房龄年限由20年提至30年 天天快看点

2023-02-07

合家幸福阖家幸福_合家幸福 全球看点

2023-02-07

国际油价6日上涨 纽约市场收于每桶74.11美元_世界即时看

2023-02-07

蔺河是什么省的 时讯

2023-02-07

V·保利斯塔 每日资讯

2023-02-07

国产新车品鉴:上汽奥迪A7L于4月19日上海车展首发 或售45万以内 全球快资讯

2023-02-07

XML检索

2023-02-07

38条高速公路“兔”飞猛进——湖北交投3000亿元密织高速网|天天新视野

2023-02-07

奥联电子2月7日快速回调

2023-02-07

分类作文好词好句子摘抄(实用81句)|世界要闻

2023-02-07

万荣县光华乡志愿服务队 每日热点

2023-02-07

假发十大品牌排行榜_中国假发十大品牌_环球百事通

2023-02-07

当日快讯:ST商城:公司关联方本金2360万元借款逾期_全球快报

2023-02-06

非货规模逆市增长超200亿 建信基金2023年看好这些投资机会 最新快讯

2023-02-06

上文选注表

2023-02-06

环球时讯:办理居住登记需要哪些材料?居住证过期如何办理延期?解答看这里!

2023-02-06

富煌钢构:2022年累计新签销售合同额约49.8亿元 同比下降11% 环球观速讯

2023-02-06

三级跳世界纪录

2023-02-06

心有猛虎细嗅蔷薇-环球时快讯

2023-02-06

全球简讯:天风证券给予传智教育买入评级,参培需求持续恢复,教研营销双引擎助推发展

2023-02-06

安徽省省直住房公积金缴存基数下限调整的通知

2023-02-06

今野由爱

2023-02-06