事务是我们平时项目中对数据操作最为直接、常用的方式,现在无论是大小公司都离不开对事务的操作,伴随业务的提升,客户量的积累也大大增加了对事务管理的难度。
在本章节中将会讲到如下内容:
(相关资料图)
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 全球看热讯事务是我们平时项目中对数据操作最为直接、常用的方式,现在无论是大小公司都离不开对事务的操作,伴随业务的提升,客户量的积累也大大增加了
-
世界速读:中关村二手电脑市场在哪里中关村二手电脑市场在哪里,中关村二手电脑市场:北京利康金桥二手电脑市场地址:西操场1号北京硅谷电脑城B1层。小虾米二手笔记本地址:海淀中
-
【时快讯】23国金证券CP003今日发布发行公告23国金证券CP003发布发行公告
-
李隆基是谁的儿子李隆基是谁的儿子,1、李旦。2、李隆基是唐睿宗李旦的儿子,唐中宗李显是他的伯父。李隆基的生母是唐睿宗的德妃,可以说李隆基能够继承皇位,
-
胜利精密股东户数增加2.71%,户均持股7.98万元胜利精密最新股东户数11 01万户,高于行业平均水平。公司户均持有流通股份2 86万股;户均流通市值7 98万元。
-
【世界速看料】吴承恩1、吴承恩,男,汉族。2、字汝忠,号射阳居士,又称射阳山人。3、明代文学家。文章到此就分享结束,希望对大家有所帮助。
-
环球速讯:降价为王,2023年的汽车没有最便宜汽车产业在2023年迈进复苏新常态,汽车供应链和生产制造逐步恢复正常,各大车企迎来了市场和用户的争夺战,因为汽车市场已经进入了产能过剩的
-
给老婆买什么礼物最贴心老婆刚刚过生完孩子,一个可爱的小公婆,一直是个个女人,一起住在老家看电影。都说丈夫老妻了,老妻都一人照顾你,你是不会为你
-
世界快看点丨“你只管踩油门,剩下的交给我们!” 这一幕,网友狂赞“你只管踩油门,剩下的交给我们!”这一幕,网友狂赞,赵辉,交警,铁骑,油门,收费站,重大交通事故
-
送长辈的礼物排行榜很多长辈给老人送礼物可以根据他们的喜好和嗜好来选择礼物,慢慢的回想一下,礼物就想出来了,然后你挑一个你认为最好的礼物送给
-
情侣个签简短_情侣个签_全球头条1、男:请不要怀疑我对你旳爱。2、女:我不会怀念你对我旳爱。3、男:我旳个性签名里丶一直都有你。4、女:谁旳个性签
-
全球要闻:华尔街紧盯周二美国CPI ChatGPT“血汗工厂”曝光情绪回落,美股上周均录得跌幅,纳指累跌2 4%;本周二通胀数据或成为美股由涨转跌节点;ChatGPT背后“血汗工厂”曝光:标注员工最低时薪仅9元
-
世界视点!梦幻西游:175级五开最佳阵容,预算8万,上班族赚外快的首选!众所周知,玩五开刷任务不仅可以随时随地享受游戏带来的快感,而且还可以当做赚外快的副业。但是想打造一组真正可以赚钱的五开号,资金投入是
-
世界最资讯丨给心爱的男人送什么生日礼物男人要求女人送上一份礼物,不管是什么,只要是他喜欢的就都可以。像什么女人都不喜欢那些浪漫的,送男人的生日礼物一定会很开心
-
老婆出轨情夫聊天记录_老婆出轨后报复情夫老婆_当前热点1、月令七十二候集解》:七月中,处,止也,暑气至此而止矣。2、暑气渐止,天地始肃。3、疾风急雨,秋意初微。4、露蝉声咽,
-
今日报丨从涨18%到跌12%,被MSCI剔除后的海昌海洋公园(02255)上演惊魂48H进入2023年以来,身披“主题公园”概念的海昌海洋公园走势持续不温不火,维持震荡态势。2月9日,这“平淡”却突然被打破。
-
李佳悦回忆地震惊险时刻!凌晨4点被摇醒,穿着睡衣拖鞋往外跑李佳悦回忆地震惊险时刻!凌晨4点被摇醒,穿着睡衣拖鞋往外跑,地震,强震,睡衣,李佳悦,中国女足,中国足球,足球竞赛,法国足球,足球运动员
-
咖喱给给是什么歌_咖喱给给1、是不是黑眼豆豆---boomboompow估计听到的是:Gottagetthat 咖喱给给Gotta
-
适合摘抄的句子带出处_适合摘抄的句子1、1)轻轻地走入小巷。2、暮春的细雨在两旁的瓦楞上跳跃,忽而又顽皮地跳到青石板的路上,和他们在青石板上的伙伴们嬉闹着
-
冬儿姑娘好词好句摘抄大全_冬儿姑娘好词好句1、但冬天又是一个温柔的姑娘,她给朝阳抹上红润,给大地披上白纱,你瞧,那堪蓝的天空中旭日像醉汉的面孔涨的通红地从树后出现
-
百润股份02月10日获深股通增持278.69万股02月10日,百润股份获深股通增持278 69万股,已连续3日获深股通增持,共计436 44万股
-
世界看热讯:02月11日从嘉兴出发到安顺的防疫政策02月11日从嘉兴出发到安顺的防疫政策(数据来源:本地宝)1、出嘉兴-:正常通行2、到安顺-:落实7个“不再”要求。即:
-
新华全媒+|寒夜中的铁路“守护者” 世界速递新华全媒+|寒夜中的铁路“守护者”---初春深夜,气温降至零度以下,中国铁路兰州局集团有限公司银川供电段平川西高铁接触网运行工区的8名...
-
加盟店可靠吗?如何识破加盟骗局?_全球新动态现在创业的人是越来越多,即便毫无创业经验学历也不是很高,各种创业方式中,加盟投资是最常见的一种创业方式。有些人加盟创业成功,赚了不少
-
东西问丨金文京:汉文如何成为东亚世界文明交流的舟楫?东亚各国曾在历史上共享过相似文化,而汉字恰是其中的精髓所在。
-
小红书推广主要有哪些方式? 当前观点截至2019年7月,小红书用户数达到3亿,月增加一百万种草笔记,单日点击率达14亿,除了主要在美妆服饰、美食旅游等领域,还逐渐成为用户“XX前
-
强信心 开新局|怀化鹤城区实现外资实际到位资金“开门红”_当前热文强信心开新局|怀化鹤城区实现外资实际到位资金“开门红”
-
环球视讯!外汇局:2022年我国经常账户顺差28210亿元外汇局发布数据,2022年四季度,我国经常账户顺差7590亿元,其中,货物贸易顺差11668亿元,服务贸易逆差2044亿元,初次收入逆差2231亿元,二次
-
将军定制1号雪茄值多少钱 将军雪茄6h多少钱一盒 环球时快讯雪茄市场中,将军定制1号雪茄价格显示为600元一盒,这是参考价格,实际售价需要以商家的定价为准。将军定制1号雪茄是山东中烟工业旗下的产品,
-
【环球新要闻】杨迪大左发文悼念唐小强 赞其拥有世间所有好品德19年我因航班延误滞留了土耳其一天,唐小强知道后虽然他人不在土耳其,但从我落地到离开的那段时间,他一直很关心我在当地的情况,还想安排他