本文ShardingJDBC相关知识主要参考自ShardingJDBC官方文档,更多的用法建议到官网文档查看。

前言

传统的业务系统都是将数据集中存储至单一数据节点的解决方案,如今随着互联网数据的海量增长,单点存储早已无法满足性能、可用性和运维成本上的要求了,分库分表变成了目前数据库存储问题的主流解决方案。
目前最常见的MySQL分库分表选择主要为ShardingJDBC(基于JDBC驱动的轻量级Java框架)与MyCat(基于Proxy)。在这两个分库分表方案中个人更倾向于ShardingJDBC,主要原因如下:

  • 官方文档详细优雅(MyCat官网真的有点捞),入门容易
  • 轻量级服务,搭建简便
  • 相关产品与架构孵化演进都让人感到该开源项目未来可期

下图为ShardingSphere官网中的Sharding-JDBC+Sharding-Proxy架构图,通过混合使用Sharding-JDBC和Sharding-Proxy,并采用同一注册中心统一配置分片策略,灵活的搭建适用于各种场景的应用系统,更加自由的调整适合于当前业务的最佳系统架构。
sharding-mix-architecture

项目环境

本文例子主要基于Spring Boot+Mybatis plus+ShardingJDB框架集成搭建项目,通过Docker配置运行Mysql主从容器,Spring Boot项目运行连接Docker Mysql容器进行实现完整的分库分表与读写分离,主要的搭建流程如下:

  • Docker与Docker Compose安装
  • Docker Compose启动容器
  • Mysql从机容器同步主机配置
  • 启动Spring Boot项目

由于该项目主要是为了记录与展现分库分表与读写分离的实现搭建细节,所以Mysql的主从配置也是以双Master同时各配单Slave最低需求搭建的,具体架构图如(project-architecture)下:
project-architecture

搭建流程

数据表order_info_x:

create table order_info
(id          bigint                              not nullprimary key,user_id     bigint                              not null comment '用户id',username    varchar(50)                         not null comment '用户名',note        varchar(300)                        not null default '' comment '备注',create_time timestamp default CURRENT_TIMESTAMP null,update_time timestamp default CURRENT_TIMESTAMP not null on update CURRENT_TIMESTAMP
)comment '订单表';

该项目中实际的操作数据表为order_info_x,order_info表仅用于代码文件逆向生成。当生成的order.id%2==0时,则存到Master1数据库上,若order.id%==1时,则存到Master2数据库上;当确认存到哪台机器上时,再根据user_id%2判断是存到order_info_0还是order_info_1。
每当Master有数据库创建或数据更新时,Slave会通过日志同步将主机数据库信息同步。

项目搭建

  • 项目文件树
    project-file-tree

  • Maven依赖

    <properties><shardingsphere.version>4.0.0</shardingsphere.version>
    </properties><dependencies><dependency><groupId>com.baomidou</groupId><artifactId>mybatis-plus-boot-starter</artifactId></dependency><dependency><groupId>org.apache.commons</groupId><artifactId>commons-lang3</artifactId></dependency><dependency><groupId>org.springframework.boot</groupId><artifactId>spring-boot-starter-web</artifactId></dependency><!-- 个人参数校验框架,可忽略 --><dependency><groupId>io.github.wilson-he</groupId><artifactId>spring-boot-common</artifactId><version>0.0.2</version></dependency><dependency><groupId>org.apache.shardingsphere</groupId><artifactId>sharding-jdbc-spring-boot-starter</artifactId><version>${shardingsphere.version}</version></dependency><dependency><groupId>com.alibaba</groupId><artifactId>druid</artifactId></dependency><dependency><groupId>mysql</groupId><artifactId>mysql-connector-java</artifactId></dependency><dependency><groupId>com.google.guava</groupId><artifactId>guava</artifactId></dependency>
    </dependencies><build><finalName>${project.artifactId}</finalName><plugins><plugin><groupId>org.springframework.boot</groupId><artifactId>spring-boot-maven-plugin</artifactId></plugin><!-- 个人代mybatis-plus码生成器插件 --><plugin><groupId>io.github.wilson-he</groupId><artifactId>generator-maven-plugin</artifactId><version>0.2.4</version><configuration><basePackage>io.wilson.sharding</basePackage><dataSource><url>jdbc:mysql://localhost/order_1</url><username>root</username><password>tiger</password></dataSource><templates><excludeController>false</excludeController></templates><crudIdType>Long</crudIdType><!-- 只生成表order_info的实体类 --><inclusions>order_info</inclusions></configuration></plugin></plugins>
    </build>
    • Mybatis Plus语句打印优化配置:ExtMybatisXMLLanguageDriver.java
    /*** 解决Mybatis Plus原生Mapper语句的格式问题** @author Wilson* @since 2020/1/13**/
    public class ExtMybatisXMLLanguageDriver extends MybatisXMLLanguageDriver {/*** 缓存反射字段,减少反射带来的性能损耗*/private final Field sqlField;public ExtMybatisXMLLanguageDriver() throws NoSuchFieldException {Class boundSqlClass = BoundSql.class;sqlField = boundSqlClass.getDeclaredField("sql");try {sqlField.setAccessible(true);} catch (Exception e) {e.printStackTrace();}
    }@Overridepublic MybatisDefaultParameterHandler createParameterHandler(MappedStatement mappedStatement,Object parameterObject, BoundSql boundSql) {String sql = boundSql.getSql();try {sqlField.set(boundSql, sql.replaceAll("\r\n|\n", " ").replaceAll("\\s{2,}", " "));} catch (IllegalAccessException e) {e.printStackTrace();}return new MybatisDefaultParameterHandler(mappedStatement, parameterObject, boundSql);}
    }
    

    该配置类主要用于优化在使用Sharding JDBC时Mybatis Plus的语句格式问题,下图为去除当前类配置后ShardingJDBC打印MybtisPlus原生Mapper语句的格式问题图:
    在这里插入图片描述

    • OrderController.java
    @RestController
    @RequestMapping("/orderInfo")
    public class OrderInfoController {@Resourceprivate OrderInfoService orderInfoService;@PostMapping("/")public ServerResponse add(@Validated @RequestBody OrderVO vo) {return ServerResponse.success(orderInfoService.insert(vo.orderInfo()));}@PutMapping("/")public ServerResponse update(@Validated @RequestBody OrderVO vo) {return ServerResponse.success(orderInfoService.updateById(vo.orderInfo()));}@GetMapping("/")public ServerResponse get(@RequestParam Long id) {return ServerResponse.success(orderInfoService.findById(id));}@GetMapping("/list")public ServerResponse list() {return ServerResponse.success(orderInfoService.list());}
    }
    • 主程序ShardingApplication.java
    @SpringBootApplication
    @MapperScan("io.wilson.sharding.mapper")
    public class ShardingApplication {public static void main(String[] args) {SpringApplication.run(ShardingApplication.class, args);}
    }
    
    • 配置文件application-sharding.yml,分片规则根据以上project-architecture图
    spring:shardingsphere:# 根据个人实际配置,该实例中配置的是个人的ecs iphost: localhostdatasource:ds0:username: rootpassword: tigertype: com.alibaba.druid.pool.DruidDataSourceurl: jdbc:mysql://${spring.shardingsphere.host}:3306/order_0ds0-slave:username: rootpassword: tigertype: com.alibaba.druid.pool.DruidDataSourceurl: jdbc:mysql://${spring.shardingsphere.host}:3307/order_0ds1:username: rootpassword: tigertype: com.alibaba.druid.pool.DruidDataSourceurl: jdbc:mysql://${spring.shardingsphere.host}:4306/order_0ds1-slave:username: rootpassword: tigertype: com.alibaba.druid.pool.DruidDataSourceurl: jdbc:mysql://${spring.shardingsphere.host}:4306/order_0# 配置数据源名称names: ds0,ds0-slave,ds1,ds1-slavesharding:default-database-strategy:inline:# 根据id%2取模判断当前数据存取是在ds0还是ds1对应的数据库algorithm-expression: ds$->{id % 2}# 根据user_id分片存取数据sharding-column: idtables:order_info:# 根据sharding生成的id%2是0还是1分配到数据库_0还是_1actual-data-nodes: ds$->{0..1}.order_info_$->{0..1}# 雪花算法生成idkeyGenerator:type: SNOWFLAKEcolumn: id# 根据user_id%2取模确定分配到数据表_0还是_1table-strategy:inline:# 根据user_id%2取模判断当前数据存取是在表order_info_0还是order_info_1algorithm-expression: order_info_$->{user_id % 2}# 根据user_id分片存取数据sharding-column: user_id# 多主从配置master-slave-rules:ds0:masterDataSourceName: ds0slave-data-source-names: [ds0-slave]ds1:masterDataSourceName: ds1slaveDataSourceNames: [ds1-slave]# 单主从配置
    #    masterslave:
    #      name: ds0_ms
    #      masterDataSourceName: ds0
    #      slaveDataSourceNames: [ds0-slave]
    props:# 打印分片信息与SQL语句sql.show: true
    • 配置文件application.yml
    spring:common:validation:msg-locale: zh_CNserialization:longToString: trueprofiles:include: sharding
    swagger:docket:base-package: io.wilson.sharding.controller
    mybatis-plus:configuration:default-scripting-language: io.wilson.sharding.mybatis.ExtMybatisXMLLanguageDriver
    

Docker容器配置

该例子中为了简便Docker只用于部署Mysql集群,若想更全面的使用Docker将Mysql与SpringBoot项目可参考 Docker+Jenkins+Nginx+SpringBoot自动化部署项目,然后将在docker-compose.yml中将Spring Boot容器depends_on Mysql容器。

  • 配置文件Docker Compose.yml
version: "3.7"
services:db-master:image: mysql:5.7.28container_name: mysql-master1command: --default-authentication-plugin=mysql_native_passwordrestart: alwaysenvironment:# root用户密码MYSQL_ROOT_PASSWORD: tigerTZ: Asia/Shanghai# 设置容器hostname,使从机可通过hostname连接主机而不必使用iphostname: mysql-master1ports:- 3306:3306volumes:- ./mysql/master1/data:/var/lib/mysql- ./mysql/master1/log:/var/log/mysql- ./mysql/master1/conf:/etc/mysql# mysql初始化执行文件,用于创建同步用户- ./mysql/init.sql:/docker-entrypoint-initdb.d/init.sqldb-slave:image: mysql:5.7.28container_name: mysql-master1-slave1command: --default-authentication-plugin=mysql_native_passwordrestart: alwayshostname: mysql-master1-slave1environment:MYSQL_ROOT_PASSWORD: tigerTZ: Asia/Shanghaiports:- 3307:3306volumes:- ./mysql/slave1/data:/var/lib/mysql- ./mysql/slave1/log:/var/log/mysql- ./mysql/slave1/conf:/etc/mysqldb-master2:image: mysql:5.7.28container_name: mysql-master2command: --default-authentication-plugin=mysql_native_passwordrestart: alwaysenvironment:# root用户密码MYSQL_ROOT_PASSWORD: tigerTZ: Asia/Shanghai# 设置容器hostname,使从机可通过hostname连接主机而不必使用iphostname: mysql-master2ports:- 4306:3306volumes:- ./mysql/master2/data:/var/lib/mysql- ./mysql/master2/log:/var/log/mysql- ./mysql/master2/conf:/etc/mysql# mysql初始化执行文件,用于创建同步用户slave- ./mysql/init.sql:/docker-entrypoint-initdb.d/init.sqldb-master2-slave1:image: mysql:5.7.28container_name: mysql-master2-slave1command: --default-authentication-plugin=mysql_native_passwordrestart: alwayshostname: mysql-master2-slave1environment:MYSQL_ROOT_PASSWORD: tigerTZ: Asia/Shanghaiports:- 4307:3306volumes:- ./mysql/slave2/data:/var/lib/mysql- ./mysql/slave2/log:/var/log/mysql- ./mysql/slave2/conf:/etc/mysql

在docker-compose.yml目录下执行docker-compose up -d指令,查看mysql master容器mysql binary log文件(File)与位置(Position):
在这里插入图片描述

docker exec -it mysql-master1 /bin/bash
mysql -uroot -ptiger
show master status;

slave容器mysql master连接配置并进行同步:

docker exec -it mysql-master1-slave1 /bin/bash
mysql -uroot -ptiger
# master_host可设为ip或容器hostname,使用用户为slave连接主机并通过log同步
change master to master_host='mysql-master1', master_user='slave', master_password='123456', master_port=3306, master_log_file='master1-bin.000005', master_log_pos=154, master_connect_retry=30;
# 开启同步
start slave;

Slave1根据Master1配置binlog,Slave2根据Master2配置binlog,更具体的主从同步可参考Docker搭建基于binlog的Mysql主从同步,此处便省略一些配置文件讲解了,更详细的项目信息可到文末查看项目地址,当完成配置后即可启动本地Spring Boot项目,可以看到2主2从都已被初始化。
在这里插入图片描述

运行测试

  1. 插入数据根据id与user_id是否成功写入到相应的库与数据表,并查看从库数据是否同步
    在这里插入图片描述
    插入数据的id%2=0,user_id%2=1,根据前面定义的规则会放入master1的order_0.order_info_0表,查看控制台与master-slave1数据库数据校验数据是否正确、数据是否同步,如下图:在这里插入图片描述
    id与user_id都为基数时,根据规则数据放入master2的order_1.order_info_1,以下为测试数据与校验图:
    在这里插入图片描述
    在这里插入图片描述

  2. 读分离测试
    1中已经成功验证了只会写Master库并从库通过binlog同步数据,读分离验证则只需获取OrderInfo列表(OrderController.list接口)查看JDBC从哪查即可:
    在这里插入图片描述
    在这里插入图片描述
    从上图可以看出ShardingJDBC已成功从所有从库中获取数据

github项目地址

查看全文
如若内容造成侵权/违法违规/事实不符,请联系编程学习网邮箱:809451989@qq.com进行投诉反馈,一经查实,立即删除!

相关文章

  1. C++学习笔记

    C++学习笔记(1) 一、二、 6?,是的话就把10 赋给num,否则把12赋给num">三、*= 的应用 int main() {double price1 = 1234.5;double price2 = 2345.7;double price3 = 6453.3;double total = price1 + price2 + price3;double discount;if (total > 10000){disco…...

    2024/3/29 13:40:43
  2. equals和==的区别

    优美的讲解equals和==的区别初步了解在JVM中的内存分配知识在JVM中,内存分为堆内存跟栈内存。他们二者的区别是: 当我们创建一个对象(new Object)时,就会调用对象的构造函数来开辟空间,将对象数据存储到堆内存中,与此同时在栈内存中生成对应的引用,当我们在后续代码中调…...

    2024/3/29 13:40:42
  3. Weblogic禁用SSLv2和SSLv3步骤

    1.linux环境在Domain安装目录下bin目录找到setDomainEnv.sh找到"JAVA_OPTIONS="处,对于10.3.6.x及之后的版本在其后追加:-Djava.net.preferIPv4Stack=true -Dweblogic.security.SSL.minimumProtocolVersion=TLSv1.010.3.6.x之前的版本-Dweblogic.security.SSL.prot…...

    2024/3/29 13:40:40
  4. Bootstrap -栅格布局

    把所有的布局都看成一行,每行等分12份 布局: (1)table布局①简单,易控制②语义错误,渲染效率低 (2)div+css布局①语义正确,渲染效率高②控制起来比较繁琐 (3)boot封装的栅格布局①简单,易控制,语义正确,渲染效率高,支持响应式②复杂的页面,不适合使用栅格 响应式栅格: …...

    2024/4/29 12:38:39
  5. 一条SQL语句执行得很慢的原因有哪些?

    一、前言说实话,这个问题可以涉及到 MySQL 的很多核心知识,可以扯出一大堆,就像要考你计算机网络的知识时,问你“输入URL回车之后,究竟发生了什么”一样,看看你能说出多少了? 二、分类讨论大多数情况是正常的,只是偶尔会出现很慢的情况。 在数据量不变的情况下,这条SQ…...

    2024/4/25 5:54:14
  6. 思源宋体,如何评价,以及如何正确使用

    ...

    2024/3/29 7:03:55
  7. newCachedThreadPool线程池的使用

    newCachedThreadPool是ThreadPoolExecutor的一种实现。如代码: public static ExecutorService newCachedThreadPool() {return new ThreadPoolExecutor(0, Integer.MAX_VALUE,60L, TimeUnit.SECONDS,new SynchronousQueue<Runnable>()); }...

    2024/4/16 21:54:28
  8. Redis Utils类

    redis的安装和下载:https://www.runoob.com/redis/redis-install.html使用 JedisPoolConfig 需要导入 Commons Pool 包,下载地址 http://commons.apache.org/proper/commons-pool/download_pool.cgi。 public class RedisUtil {//服务器IP地址private static String ADDR = &…...

    2024/3/29 7:03:53
  9. SparkStreaming-DStream与DataFrame SQL联合操作

    查询使用的SparkSession 可由StreamingContext中的SparkContext来创建,以此用来进行DataFrame Sql操作。 val words: DStream[String] = ...words.foreachRDD { rdd =>// 获取单例SparkSessionval spark = SparkSession.builder.config(rdd.sparkContext.getConf).getOrCre…...

    2024/4/24 10:59:42
  10. 小白用户选择阿里云服务器过程中的注意事项 新手必看

    很多小白用户在选择阿里云服务器时,往往对于服务器的规格、配置、带宽等不知道怎么选是适合自己的,那么说在选择过程中,规格、带宽、镜像、安全组、时长都是有需要注意的地方,下面我分享这些需要注意的地方。 一、注册阿里云账号并做实名认证 账号注册好之后,第一步不是去…...

    2024/4/16 18:39:41
  11. c#获得当前日期

    var currentDate = DateTime.Parse(DateTime.Now.ToString("yyyy-MM-dd"));...

    2024/3/29 13:40:36
  12. SpringBoot学习之注解释义

    一、注解(annotations)列表 @SpringBootApplication:包含了@ComponentScan、@Configuration和@EnableAutoConfiguration注解。其中@ComponentScan让spring Boot扫描到Configuration类并把它加入到程序上下文。 @Configuration 等同于spring的XML配置文件;使用Java代码可以检查…...

    2024/4/29 9:17:40
  13. 好玩的命令行版本蔡徐坤打篮球

    github地址...

    2024/4/24 16:34:39
  14. VMware上Ubuntu虚拟机黑屏问题的案例

    VMware上Ubuntu虚拟机黑屏问题的案例 最近想学习ROS,但是由于入门不敢冒着损失电脑其他已近装好的软件需要再重装的风险,决定先用虚拟机学习,完成正常的安装后,出现了系统安装完成后重启即黑屏的问题 经过网上查找大致有几个方案在cmd里输入netsh winsock reset再重启,修复…...

    2024/4/25 9:25:11
  15. 2020 蓝桥杯省赛 B 组模拟赛(一) I:最短路(正反向建边)

    I:最短路 给你一组数据(n个点),让你求从1号点走到i号点,再从i号点走到1号点的所有最短路和。(i从1到n) 正向建边跑一边spfa,反向建边跑一边spfa,建图的时候用邻接表建图。 wa的原因:1.题没理解透,跑2遍spfa就行了,我每求一次跑了一个spfaTLE… 2.spfa的dis数组初始…...

    2024/3/29 13:40:32
  16. docker常用的一些基础命令

    1、从镜像仓库中拉取或者更新指定镜像 docker pull 镜像名:TAG 2、将本地的镜像上传到镜像仓库,要先登陆到镜像仓库 docker push 镜像名:TAG 3、从镜像仓库搜索镜像 docker search 镜像名关键字 4、对本地镜像的操作 #列出本地所有镜像 docker images #删除一个或多个镜像 dock…...

    2024/4/28 8:59:22
  17. 工厂方法模式(Factory Method)

    一、 普通工厂模式就是建立一个工厂类,对实现了同一接口的一些类进行实例的创建。首先看下关系图:举例如下:(我们举一个发送邮件和短信的例子)首先,创建二者的共同接口:package test.factory;public interface Sender {public void Send(); }其次,创建实现类:邮件实现…...

    2024/4/24 15:11:31
  18. Node.JS实战53:调试node程序。

    当需要检测问题、调试,甚至想要一步步的运行代码时,使用调试器是最好的办法。Node有内置的调试器:debug,而且颇强大,可以下断点、查看变量、单步执行等等。下面通过一段示例,展示其用法:var a = 1; function b(){ a = 2; } b(); a = 3; a = 4; debugger; a = 5; var c; …...

    2024/4/23 10:28:54
  19. 【软件工程基础】个人项目之数独求解代码优化

    1.0版本性能分析这一部分出现了一些小问题,主要是忘记进行性能检测了。因为在生成数独题目的时候,就索性进行了数独读入方面的优化,然后那部分的优化代码写完之后就直接把求解数独部分的读入一块更新了。所以只能直接把优化好的代码和性能分析结果贴出来了。代码优化前面也介…...

    2024/4/25 12:19:44
  20. 牛客小白月赛21 C.Channels

    牛客小白月赛21 C.Channels 题目链接 (略) 输入描述: (略) 输出描述: 若干行:每行一个整数,表示能品味电视节目的时刻数。 示例1 输入 1 61输出 51示例2 输入 116969978 507978500 180480072 791550396 139567120 655243745 1470545 167613747 57644034 176077476 44676 5698…...

    2024/3/29 13:40:27

最新文章

  1. vue3+vite+js 实现移动端,PC端响应式布局

    目前使用的是vue3vite&#xff0c;没有使用ts 纯移动端|PC端 这种适用于只适用一个端的情况 方法&#xff1a;amfe-flexible postcss-pxtorem相结合 ① 执行以下两个命令 npm i -S amfe-flexible npm install postcss-pxtorem --save-dev② main.js文件引用 import amfe-f…...

    2024/5/2 23:17:21
  2. 梯度消失和梯度爆炸的一些处理方法

    在这里是记录一下梯度消失或梯度爆炸的一些处理技巧。全当学习总结了如有错误还请留言&#xff0c;在此感激不尽。 权重和梯度的更新公式如下&#xff1a; w w − η ⋅ ∇ w w w - \eta \cdot \nabla w ww−η⋅∇w 个人通俗的理解梯度消失就是网络模型在反向求导的时候出…...

    2024/3/20 10:50:27
  3. 触想四代ARM架构工业一体机助力手功能康复机器人应用

    一、行业发展背景 手功能康复机器人是医疗机器人的一个分支&#xff0c;设计用于帮助肢体障碍患者进行手部运动和力量训练&#xff0c;在医疗健康领域有着巨大的成长空间。 手功能康复机器人融合了传感、控制、计算、AI视觉等智能科技与医学技术&#xff0c;能够帮助患者改善康…...

    2024/5/1 5:48:50
  4. 逻辑回归(Logistic Regression)详解

    逻辑回归是一种用于解决二分类问题的统计方法&#xff0c;它通过构建一个模型来预测某个事件的概率。 以下是逻辑回归的一些关键要点&#xff1a; 适用场景&#xff1a;逻辑回归特别适合于处理二分类问题&#xff0c;即两个类别的分类问题&#xff0c;例如判断一封邮件是否为…...

    2024/4/29 11:35:37
  5. 【外汇早评】美通胀数据走低,美元调整

    原标题:【外汇早评】美通胀数据走低,美元调整昨日美国方面公布了新一期的核心PCE物价指数数据,同比增长1.6%,低于前值和预期值的1.7%,距离美联储的通胀目标2%继续走低,通胀压力较低,且此前美国一季度GDP初值中的消费部分下滑明显,因此市场对美联储后续更可能降息的政策…...

    2024/5/1 17:30:59
  6. 【原油贵金属周评】原油多头拥挤,价格调整

    原标题:【原油贵金属周评】原油多头拥挤,价格调整本周国际劳动节,我们喜迎四天假期,但是整个金融市场确实流动性充沛,大事频发,各个商品波动剧烈。美国方面,在本周四凌晨公布5月份的利率决议和新闻发布会,维持联邦基金利率在2.25%-2.50%不变,符合市场预期。同时美联储…...

    2024/5/2 16:16:39
  7. 【外汇周评】靓丽非农不及疲软通胀影响

    原标题:【外汇周评】靓丽非农不及疲软通胀影响在刚结束的周五,美国方面公布了新一期的非农就业数据,大幅好于前值和预期,新增就业重新回到20万以上。具体数据: 美国4月非农就业人口变动 26.3万人,预期 19万人,前值 19.6万人。 美国4月失业率 3.6%,预期 3.8%,前值 3…...

    2024/4/29 2:29:43
  8. 【原油贵金属早评】库存继续增加,油价收跌

    原标题:【原油贵金属早评】库存继续增加,油价收跌周三清晨公布美国当周API原油库存数据,上周原油库存增加281万桶至4.692亿桶,增幅超过预期的74.4万桶。且有消息人士称,沙特阿美据悉将于6月向亚洲炼油厂额外出售更多原油,印度炼油商预计将每日获得至多20万桶的额外原油供…...

    2024/5/2 9:28:15
  9. 【外汇早评】日本央行会议纪要不改日元强势

    原标题:【外汇早评】日本央行会议纪要不改日元强势近两日日元大幅走强与近期市场风险情绪上升,避险资金回流日元有关,也与前一段时间的美日贸易谈判给日本缓冲期,日本方面对汇率问题也避免继续贬值有关。虽然今日早间日本央行公布的利率会议纪要仍然是支持宽松政策,但这符…...

    2024/4/27 17:58:04
  10. 【原油贵金属早评】欧佩克稳定市场,填补伊朗问题的影响

    原标题:【原油贵金属早评】欧佩克稳定市场,填补伊朗问题的影响近日伊朗局势升温,导致市场担忧影响原油供给,油价试图反弹。此时OPEC表态稳定市场。据消息人士透露,沙特6月石油出口料将低于700万桶/日,沙特已经收到石油消费国提出的6月份扩大出口的“适度要求”,沙特将满…...

    2024/4/27 14:22:49
  11. 【外汇早评】美欲与伊朗重谈协议

    原标题:【外汇早评】美欲与伊朗重谈协议美国对伊朗的制裁遭到伊朗的抗议,昨日伊朗方面提出将部分退出伊核协议。而此行为又遭到欧洲方面对伊朗的谴责和警告,伊朗外长昨日回应称,欧洲国家履行它们的义务,伊核协议就能保证存续。据传闻伊朗的导弹已经对准了以色列和美国的航…...

    2024/4/28 1:28:33
  12. 【原油贵金属早评】波动率飙升,市场情绪动荡

    原标题:【原油贵金属早评】波动率飙升,市场情绪动荡因中美贸易谈判不安情绪影响,金融市场各资产品种出现明显的波动。随着美国与中方开启第十一轮谈判之际,美国按照既定计划向中国2000亿商品征收25%的关税,市场情绪有所平复,已经开始接受这一事实。虽然波动率-恐慌指数VI…...

    2024/4/30 9:43:09
  13. 【原油贵金属周评】伊朗局势升温,黄金多头跃跃欲试

    原标题:【原油贵金属周评】伊朗局势升温,黄金多头跃跃欲试美国和伊朗的局势继续升温,市场风险情绪上升,避险黄金有向上突破阻力的迹象。原油方面稍显平稳,近期美国和OPEC加大供给及市场需求回落的影响,伊朗局势并未推升油价走强。近期中美贸易谈判摩擦再度升级,美国对中…...

    2024/4/27 17:59:30
  14. 【原油贵金属早评】市场情绪继续恶化,黄金上破

    原标题:【原油贵金属早评】市场情绪继续恶化,黄金上破周初中国针对于美国加征关税的进行的反制措施引发市场情绪的大幅波动,人民币汇率出现大幅的贬值动能,金融市场受到非常明显的冲击。尤其是波动率起来之后,对于股市的表现尤其不安。隔夜美国股市出现明显的下行走势,这…...

    2024/5/2 15:04:34
  15. 【外汇早评】美伊僵持,风险情绪继续升温

    原标题:【外汇早评】美伊僵持,风险情绪继续升温昨日沙特两艘油轮再次发生爆炸事件,导致波斯湾局势进一步恶化,市场担忧美伊可能会出现摩擦生火,避险品种获得支撑,黄金和日元大幅走强。美指受中美贸易问题影响而在低位震荡。继5月12日,四艘商船在阿联酋领海附近的阿曼湾、…...

    2024/4/28 1:34:08
  16. 【原油贵金属早评】贸易冲突导致需求低迷,油价弱势

    原标题:【原油贵金属早评】贸易冲突导致需求低迷,油价弱势近日虽然伊朗局势升温,中东地区几起油船被袭击事件影响,但油价并未走高,而是出于调整结构中。由于市场预期局势失控的可能性较低,而中美贸易问题导致的全球经济衰退风险更大,需求会持续低迷,因此油价调整压力较…...

    2024/4/26 19:03:37
  17. 氧生福地 玩美北湖(上)——为时光守候两千年

    原标题:氧生福地 玩美北湖(上)——为时光守候两千年一次说走就走的旅行,只有一张高铁票的距离~ 所以,湖南郴州,我来了~ 从广州南站出发,一个半小时就到达郴州西站了。在动车上,同时改票的南风兄和我居然被分到了一个车厢,所以一路非常愉快地聊了过来。 挺好,最起…...

    2024/4/29 20:46:55
  18. 氧生福地 玩美北湖(中)——永春梯田里的美与鲜

    原标题:氧生福地 玩美北湖(中)——永春梯田里的美与鲜一觉醒来,因为大家太爱“美”照,在柳毅山庄去寻找龙女而错过了早餐时间。近十点,向导坏坏还是带着饥肠辘辘的我们去吃郴州最富有盛名的“鱼头粉”。说这是“十二分推荐”,到郴州必吃的美食之一。 哇塞!那个味美香甜…...

    2024/4/30 22:21:04
  19. 氧生福地 玩美北湖(下)——奔跑吧骚年!

    原标题:氧生福地 玩美北湖(下)——奔跑吧骚年!让我们红尘做伴 活得潇潇洒洒 策马奔腾共享人世繁华 对酒当歌唱出心中喜悦 轰轰烈烈把握青春年华 让我们红尘做伴 活得潇潇洒洒 策马奔腾共享人世繁华 对酒当歌唱出心中喜悦 轰轰烈烈把握青春年华 啊……啊……啊 两…...

    2024/5/1 4:32:01
  20. 扒开伪装医用面膜,翻六倍价格宰客,小姐姐注意了!

    原标题:扒开伪装医用面膜,翻六倍价格宰客,小姐姐注意了!扒开伪装医用面膜,翻六倍价格宰客!当行业里的某一品项火爆了,就会有很多商家蹭热度,装逼忽悠,最近火爆朋友圈的医用面膜,被沾上了污点,到底怎么回事呢? “比普通面膜安全、效果好!痘痘、痘印、敏感肌都能用…...

    2024/4/27 23:24:42
  21. 「发现」铁皮石斛仙草之神奇功效用于医用面膜

    原标题:「发现」铁皮石斛仙草之神奇功效用于医用面膜丽彦妆铁皮石斛医用面膜|石斛多糖无菌修护补水贴19大优势: 1、铁皮石斛:自唐宋以来,一直被列为皇室贡品,铁皮石斛生于海拔1600米的悬崖峭壁之上,繁殖力差,产量极低,所以古代仅供皇室、贵族享用 2、铁皮石斛自古民间…...

    2024/4/28 5:48:52
  22. 丽彦妆\医用面膜\冷敷贴轻奢医学护肤引导者

    原标题:丽彦妆\医用面膜\冷敷贴轻奢医学护肤引导者【公司简介】 广州华彬企业隶属香港华彬集团有限公司,专注美业21年,其旗下品牌: 「圣茵美」私密荷尔蒙抗衰,产后修复 「圣仪轩」私密荷尔蒙抗衰,产后修复 「花茵莳」私密荷尔蒙抗衰,产后修复 「丽彦妆」专注医学护…...

    2024/4/30 9:42:22
  23. 广州械字号面膜生产厂家OEM/ODM4项须知!

    原标题:广州械字号面膜生产厂家OEM/ODM4项须知!广州械字号面膜生产厂家OEM/ODM流程及注意事项解读: 械字号医用面膜,其实在我国并没有严格的定义,通常我们说的医美面膜指的应该是一种「医用敷料」,也就是说,医用面膜其实算作「医疗器械」的一种,又称「医用冷敷贴」。 …...

    2024/5/2 9:07:46
  24. 械字号医用眼膜缓解用眼过度到底有无作用?

    原标题:械字号医用眼膜缓解用眼过度到底有无作用?医用眼膜/械字号眼膜/医用冷敷眼贴 凝胶层为亲水高分子材料,含70%以上的水分。体表皮肤温度传导到本产品的凝胶层,热量被凝胶内水分子吸收,通过水分的蒸发带走大量的热量,可迅速地降低体表皮肤局部温度,减轻局部皮肤的灼…...

    2024/4/30 9:42:49
  25. 配置失败还原请勿关闭计算机,电脑开机屏幕上面显示,配置失败还原更改 请勿关闭计算机 开不了机 这个问题怎么办...

    解析如下&#xff1a;1、长按电脑电源键直至关机&#xff0c;然后再按一次电源健重启电脑&#xff0c;按F8健进入安全模式2、安全模式下进入Windows系统桌面后&#xff0c;按住“winR”打开运行窗口&#xff0c;输入“services.msc”打开服务设置3、在服务界面&#xff0c;选中…...

    2022/11/19 21:17:18
  26. 错误使用 reshape要执行 RESHAPE,请勿更改元素数目。

    %读入6幅图像&#xff08;每一幅图像的大小是564*564&#xff09; f1 imread(WashingtonDC_Band1_564.tif); subplot(3,2,1),imshow(f1); f2 imread(WashingtonDC_Band2_564.tif); subplot(3,2,2),imshow(f2); f3 imread(WashingtonDC_Band3_564.tif); subplot(3,2,3),imsho…...

    2022/11/19 21:17:16
  27. 配置 已完成 请勿关闭计算机,win7系统关机提示“配置Windows Update已完成30%请勿关闭计算机...

    win7系统关机提示“配置Windows Update已完成30%请勿关闭计算机”问题的解决方法在win7系统关机时如果有升级系统的或者其他需要会直接进入一个 等待界面&#xff0c;在等待界面中我们需要等待操作结束才能关机&#xff0c;虽然这比较麻烦&#xff0c;但是对系统进行配置和升级…...

    2022/11/19 21:17:15
  28. 台式电脑显示配置100%请勿关闭计算机,“准备配置windows 请勿关闭计算机”的解决方法...

    有不少用户在重装Win7系统或更新系统后会遇到“准备配置windows&#xff0c;请勿关闭计算机”的提示&#xff0c;要过很久才能进入系统&#xff0c;有的用户甚至几个小时也无法进入&#xff0c;下面就教大家这个问题的解决方法。第一种方法&#xff1a;我们首先在左下角的“开始…...

    2022/11/19 21:17:14
  29. win7 正在配置 请勿关闭计算机,怎么办Win7开机显示正在配置Windows Update请勿关机...

    置信有很多用户都跟小编一样遇到过这样的问题&#xff0c;电脑时发现开机屏幕显现“正在配置Windows Update&#xff0c;请勿关机”(如下图所示)&#xff0c;而且还需求等大约5分钟才干进入系统。这是怎样回事呢&#xff1f;一切都是正常操作的&#xff0c;为什么开时机呈现“正…...

    2022/11/19 21:17:13
  30. 准备配置windows 请勿关闭计算机 蓝屏,Win7开机总是出现提示“配置Windows请勿关机”...

    Win7系统开机启动时总是出现“配置Windows请勿关机”的提示&#xff0c;没过几秒后电脑自动重启&#xff0c;每次开机都这样无法进入系统&#xff0c;此时碰到这种现象的用户就可以使用以下5种方法解决问题。方法一&#xff1a;开机按下F8&#xff0c;在出现的Windows高级启动选…...

    2022/11/19 21:17:12
  31. 准备windows请勿关闭计算机要多久,windows10系统提示正在准备windows请勿关闭计算机怎么办...

    有不少windows10系统用户反映说碰到这样一个情况&#xff0c;就是电脑提示正在准备windows请勿关闭计算机&#xff0c;碰到这样的问题该怎么解决呢&#xff0c;现在小编就给大家分享一下windows10系统提示正在准备windows请勿关闭计算机的具体第一种方法&#xff1a;1、2、依次…...

    2022/11/19 21:17:11
  32. 配置 已完成 请勿关闭计算机,win7系统关机提示“配置Windows Update已完成30%请勿关闭计算机”的解决方法...

    今天和大家分享一下win7系统重装了Win7旗舰版系统后&#xff0c;每次关机的时候桌面上都会显示一个“配置Windows Update的界面&#xff0c;提示请勿关闭计算机”&#xff0c;每次停留好几分钟才能正常关机&#xff0c;导致什么情况引起的呢&#xff1f;出现配置Windows Update…...

    2022/11/19 21:17:10
  33. 电脑桌面一直是清理请关闭计算机,windows7一直卡在清理 请勿关闭计算机-win7清理请勿关机,win7配置更新35%不动...

    只能是等着&#xff0c;别无他法。说是卡着如果你看硬盘灯应该在读写。如果从 Win 10 无法正常回滚&#xff0c;只能是考虑备份数据后重装系统了。解决来方案一&#xff1a;管理员运行cmd&#xff1a;net stop WuAuServcd %windir%ren SoftwareDistribution SDoldnet start WuA…...

    2022/11/19 21:17:09
  34. 计算机配置更新不起,电脑提示“配置Windows Update请勿关闭计算机”怎么办?

    原标题&#xff1a;电脑提示“配置Windows Update请勿关闭计算机”怎么办&#xff1f;win7系统中在开机与关闭的时候总是显示“配置windows update请勿关闭计算机”相信有不少朋友都曾遇到过一次两次还能忍但经常遇到就叫人感到心烦了遇到这种问题怎么办呢&#xff1f;一般的方…...

    2022/11/19 21:17:08
  35. 计算机正在配置无法关机,关机提示 windows7 正在配置windows 请勿关闭计算机 ,然后等了一晚上也没有关掉。现在电脑无法正常关机...

    关机提示 windows7 正在配置windows 请勿关闭计算机 &#xff0c;然后等了一晚上也没有关掉。现在电脑无法正常关机以下文字资料是由(历史新知网www.lishixinzhi.com)小编为大家搜集整理后发布的内容&#xff0c;让我们赶快一起来看一下吧&#xff01;关机提示 windows7 正在配…...

    2022/11/19 21:17:05
  36. 钉钉提示请勿通过开发者调试模式_钉钉请勿通过开发者调试模式是真的吗好不好用...

    钉钉请勿通过开发者调试模式是真的吗好不好用 更新时间:2020-04-20 22:24:19 浏览次数:729次 区域: 南阳 > 卧龙 列举网提醒您:为保障您的权益,请不要提前支付任何费用! 虚拟位置外设器!!轨迹模拟&虚拟位置外设神器 专业用于:钉钉,外勤365,红圈通,企业微信和…...

    2022/11/19 21:17:05
  37. 配置失败还原请勿关闭计算机怎么办,win7系统出现“配置windows update失败 还原更改 请勿关闭计算机”,长时间没反应,无法进入系统的解决方案...

    前几天班里有位学生电脑(windows 7系统)出问题了&#xff0c;具体表现是开机时一直停留在“配置windows update失败 还原更改 请勿关闭计算机”这个界面&#xff0c;长时间没反应&#xff0c;无法进入系统。这个问题原来帮其他同学也解决过&#xff0c;网上搜了不少资料&#x…...

    2022/11/19 21:17:04
  38. 一个电脑无法关闭计算机你应该怎么办,电脑显示“清理请勿关闭计算机”怎么办?...

    本文为你提供了3个有效解决电脑显示“清理请勿关闭计算机”问题的方法&#xff0c;并在最后教给你1种保护系统安全的好方法&#xff0c;一起来看看&#xff01;电脑出现“清理请勿关闭计算机”在Windows 7(SP1)和Windows Server 2008 R2 SP1中&#xff0c;添加了1个新功能在“磁…...

    2022/11/19 21:17:03
  39. 请勿关闭计算机还原更改要多久,电脑显示:配置windows更新失败,正在还原更改,请勿关闭计算机怎么办...

    许多用户在长期不使用电脑的时候&#xff0c;开启电脑发现电脑显示&#xff1a;配置windows更新失败&#xff0c;正在还原更改&#xff0c;请勿关闭计算机。。.这要怎么办呢&#xff1f;下面小编就带着大家一起看看吧&#xff01;如果能够正常进入系统&#xff0c;建议您暂时移…...

    2022/11/19 21:17:02
  40. 还原更改请勿关闭计算机 要多久,配置windows update失败 还原更改 请勿关闭计算机,电脑开机后一直显示以...

    配置windows update失败 还原更改 请勿关闭计算机&#xff0c;电脑开机后一直显示以以下文字资料是由(历史新知网www.lishixinzhi.com)小编为大家搜集整理后发布的内容&#xff0c;让我们赶快一起来看一下吧&#xff01;配置windows update失败 还原更改 请勿关闭计算机&#x…...

    2022/11/19 21:17:01
  41. 电脑配置中请勿关闭计算机怎么办,准备配置windows请勿关闭计算机一直显示怎么办【图解】...

    不知道大家有没有遇到过这样的一个问题&#xff0c;就是我们的win7系统在关机的时候&#xff0c;总是喜欢显示“准备配置windows&#xff0c;请勿关机”这样的一个页面&#xff0c;没有什么大碍&#xff0c;但是如果一直等着的话就要两个小时甚至更久都关不了机&#xff0c;非常…...

    2022/11/19 21:17:00
  42. 正在准备配置请勿关闭计算机,正在准备配置windows请勿关闭计算机时间长了解决教程...

    当电脑出现正在准备配置windows请勿关闭计算机时&#xff0c;一般是您正对windows进行升级&#xff0c;但是这个要是长时间没有反应&#xff0c;我们不能再傻等下去了。可能是电脑出了别的问题了&#xff0c;来看看教程的说法。正在准备配置windows请勿关闭计算机时间长了方法一…...

    2022/11/19 21:16:59
  43. 配置失败还原请勿关闭计算机,配置Windows Update失败,还原更改请勿关闭计算机...

    我们使用电脑的过程中有时会遇到这种情况&#xff0c;当我们打开电脑之后&#xff0c;发现一直停留在一个界面&#xff1a;“配置Windows Update失败&#xff0c;还原更改请勿关闭计算机”&#xff0c;等了许久还是无法进入系统。如果我们遇到此类问题应该如何解决呢&#xff0…...

    2022/11/19 21:16:58
  44. 如何在iPhone上关闭“请勿打扰”

    Apple’s “Do Not Disturb While Driving” is a potentially lifesaving iPhone feature, but it doesn’t always turn on automatically at the appropriate time. For example, you might be a passenger in a moving car, but your iPhone may think you’re the one dri…...

    2022/11/19 21:16:57