多数据源注解配置
使用方式(类、与方法上均可使用此注解):
配置目录结构参考:
maven依赖:
<!--jdbc--><dependency><groupId>org.springframework.boot</groupId><artifactId>spring-boot-starter-jdbc</artifactId><optional>true</optional></dependency><!--Druid数据源--><dependency><groupId>com.alibaba</groupId><artifactId>druid</artifactId></dependency><!--MySql驱动--><dependency><groupId>mysql</groupId><artifactId>mysql-connector-java</artifactId></dependency><!--SqlServer驱动--><dependency><groupId>com.microsoft.sqlserver</groupId><artifactId>mssql-jdbc</artifactId><scope>runtime</scope></dependency><!--Mybatis--><dependency><groupId>org.mybatis.spring.boot</groupId><artifactId>mybatis-spring-boot-starter</artifactId></dependency>
定义枚举类存放数据源的key值实现配置化 ,key值与yml中需一 一对应
public enum DataSourceKey {/*** key 为one的数据源*/ONE("one"),/*** key 为two的数据源*/TWO("two"),/*** key 为three的数据源*/THREE("three");private String name;public String getName() {return name;}public void setName(String name) {this.name = name;}DataSourceKey(String name) {this.name = name;}
}
yml配置:
spring: datasource:type: com.alibaba.druid.pool.DruidDataSourcemaster: #默认数据源url: username: password: driver-class-name: #数据源格式要一样cluster:- key: oneurl: username: password: driver-class-name: - key: twourl: username: password: driver-class-name: - key: threeurl: username: password: driver-class-name:
#线程池配置
parse:thread:pool:#线程池维护线程的最少数量corePoolSize: 10#线程池维护线程的最大数量maxPoolSize: 20#线程池维护线程所允许的空闲时间keepAliveTime: 30#线程池所使用的缓冲队列大小workQueueSize: 6000#调度线程池大小schedulerPoolSize: 5
自定义数据源注解类
import java.lang.annotation.*;/*** 注解类。使用该注解默认使用key为one的数据源**/
@Target({ElementType.TYPE, ElementType.METHOD})
@Retention(RetentionPolicy.RUNTIME)
@Documented
public @interface TargetDataSource {DataSourceKey value() default DataSourceKey.ONE;
}
数据源路由以及管理配置类
import com.xxx.DataSourceKey;import java.util.ArrayList;
import java.util.List;/*** 数据源上下文* 管理数据源**/
public class DynamicDataSourceContextHolder {private static ThreadLocal<Object> CONTEXT_HOLDER = ThreadLocal.withInitial(() -> DataSourceKey.ONE.getName());public static List<Object> dataSourceKeys = new ArrayList<>();/*** 设置数据源** @param key*/public static void setDataSourceKey(String key) {CONTEXT_HOLDER.set(key);}/*** 获取数据源** @return*/public static Object getDataSourceKey() {return CONTEXT_HOLDER.get();}/*** 删除数据源*/public static void clearDataSourceKey() {CONTEXT_HOLDER.remove();}/*** 判断数据源是否存在** @param key* @return*/public static Boolean containDataSourceKey(String key) {return dataSourceKeys.contains(key);}
}
import org.springframework.jdbc.datasource.lookup.AbstractRoutingDataSource;/*** 动态数据源路由配置**/
public class DynamicDataSource extends AbstractRoutingDataSource {@Overrideprotected Object determineCurrentLookupKey() {return DynamicDataSourceContextHolder.getDataSourceKey();}
}
读取yml配置实现动态注入
import com.alibaba.druid.pool.DruidDataSource;
import com.xxx.DynamicDataSource;
import com.xxx.DynamicDataSourceContextHolder;
import org.slf4j.Logger;
import org.slf4j.LoggerFactory;
import org.springframework.beans.MutablePropertyValues;
import org.springframework.beans.factory.support.BeanDefinitionRegistry;
import org.springframework.beans.factory.support.GenericBeanDefinition;
import org.springframework.boot.context.properties.bind.Bindable;
import org.springframework.boot.context.properties.bind.Binder;
import org.springframework.boot.context.properties.source.ConfigurationPropertyName;
import org.springframework.boot.context.properties.source.ConfigurationPropertyNameAliases;
import org.springframework.boot.context.properties.source.ConfigurationPropertySource;
import org.springframework.boot.context.properties.source.MapConfigurationPropertySource;
import org.springframework.context.EnvironmentAware;
import org.springframework.context.annotation.ImportBeanDefinitionRegistrar;
import org.springframework.core.env.Environment;
import org.springframework.core.type.AnnotationMetadata;
import org.springframework.util.StringUtils;import javax.sql.DataSource;
import java.util.HashMap;
import java.util.List;
import java.util.Map;/*** 动态数据源注册* 实现 ImportBeanDefinitionRegistrar 实现数据源注册* 实现 EnvironmentAware 用于读取application.yml配置**/
public class DynamicDataSourceRegister implements ImportBeanDefinitionRegistrar, EnvironmentAware {private static final Logger logger = LoggerFactory.getLogger(DynamicDataSourceRegister.class);/*** 配置上下文(也可以理解为配置文件的获取工具)*/private Environment evn;/*** 别名*/private final static ConfigurationPropertyNameAliases aliases = new ConfigurationPropertyNameAliases();/*** 由于部分数据源配置不同,所以在此处添加别名,避免切换数据源出现某些参数无法注入的情况*/static {aliases.addAliases("url", new String[]{"jdbc-url"});aliases.addAliases("username", new String[]{"user"});}/*** 存储我们注册的数据源*/private Map<String, DataSource> customDataSources = new HashMap<String, DataSource>();/*** 参数绑定工具 springboot2.0新推出*/private Binder binder;@Overridepublic void setEnvironment(Environment environment) {logger.info("开始注册数据源");this.evn = environment;// 绑定配置器binder = Binder.get(evn);}@Overridepublic void registerBeanDefinitions(AnnotationMetadata annotationMetadata, BeanDefinitionRegistry beanDefinitionRegistry) {Map config, defaultDataSourceProperties;//获取默认的数据源defaultDataSourceProperties = binder.bind("spring.datasource.master", Map.class).get();// 获取数据源类型String typeStr = evn.getProperty("spring.datasource.master.type");// 获取数据源类型Class<? extends DataSource> clazz = getDataSourceType(typeStr);// 绑定默认数据源参数 也就是主数据源DataSource consumerDatasource, defaultDatasource = bind(clazz, defaultDataSourceProperties);DynamicDataSourceContextHolder.dataSourceKeys.add("master");logger.info("注册默认数据源成功");// 获取其他数据源配置List<Map> configs = binder.bind("spring.datasource.cluster", Bindable.listOf(Map.class)).get();// 遍历从数据源for (int i = 0; i < configs.size(); i++) {config = configs.get(i);clazz = getDataSourceType((String) config.get("type"));defaultDataSourceProperties = config;// 绑定参数consumerDatasource = bind(clazz, defaultDataSourceProperties);// 获取数据源的key,以便通过该key可以定位到数据源String key = config.get("key").toString();customDataSources.put(key, consumerDatasource);// 数据源上下文,用于管理数据源与记录已经注册的数据源keyDynamicDataSourceContextHolder.dataSourceKeys.add(key);logger.info("注册数据源{}成功", key);}// bean定义类GenericBeanDefinition define = new GenericBeanDefinition();// 设置bean的类型,此处DynamicRoutingDataSource是继承AbstractRoutingDataSource的实现类define.setBeanClass(DynamicDataSource.class);// 需要注入的参数MutablePropertyValues mpv = define.getPropertyValues();// 添加默认数据源,避免key不存在的情况没有数据源可用mpv.add("defaultTargetDataSource", defaultDatasource);// 添加其他数据源mpv.add("targetDataSources", customDataSources);// 将该bean注册为datasource,不使用springboot自动生成的datasourcebeanDefinitionRegistry.registerBeanDefinition("datasource", define);logger.info("注册数据源成功,一共注册{}个数据源", customDataSources.keySet().size() + 1);}private Class<? extends DataSource> getDataSourceType(String typeStr) {Class<? extends DataSource> type;try {if (StringUtils.hasLength(typeStr)) {// 字符串不为空则通过反射获取class对象type = (Class<? extends DataSource>) Class.forName(typeStr);} else {// 使用阿里Druid数据源type = DruidDataSource.class;}return type;} catch (Exception e) {//无法通过反射获取class对象的情况则抛出异常,该情况一般是写错了,所以此次抛出一个Runtime exceptionthrow new IllegalArgumentException("can not resolve class with type: " + typeStr);}}private <T extends DataSource> T bind(Class<T> clazz, Map properties) {ConfigurationPropertySource source = new MapConfigurationPropertySource(properties);Binder binder = new Binder(new ConfigurationPropertySource[]{source.withAliases(aliases)});// 通过类型绑定参数并获得实例对象return binder.bind(ConfigurationPropertyName.EMPTY, Bindable.of(clazz)).get();}
}
定义切面监听上方自定义的注解,以达到在类与方法上实现数据源的动态切换:
import com.xxx.TargetDataSource;
import org.aopalliance.aop.Advice;
import org.springframework.aop.Pointcut;
import org.springframework.aop.support.AbstractPointcutAdvisor;
import org.springframework.aop.support.ComposablePointcut;
import org.springframework.aop.support.annotation.AnnotationMatchingPointcut;
import org.springframework.beans.BeansException;
import org.springframework.beans.factory.BeanFactory;
import org.springframework.beans.factory.BeanFactoryAware;/*** aop切入**/
public class DynamicDataSourceAnnotationAdvisor extends AbstractPointcutAdvisor implements BeanFactoryAware {/*** 切面通知*/private Advice advice;/*** 切点*/private Pointcut pointcut;public DynamicDataSourceAnnotationAdvisor(DynamicDataSourceAnnotationInterceptor dynamicDataSourceAnnotationInterceptor) {this.advice = dynamicDataSourceAnnotationInterceptor;this.pointcut = buildPointcut();}@Overridepublic Pointcut getPointcut() {return this.pointcut;}@Overridepublic Advice getAdvice() {return this.advice;}@Overridepublic void setBeanFactory(BeanFactory beanFactory) throws BeansException {if (this.advice instanceof BeanFactoryAware) {((BeanFactoryAware) this.advice).setBeanFactory(beanFactory);}}private Pointcut buildPointcut() {Pointcut cpc = new AnnotationMatchingPointcut(TargetDataSource.class, true);// 类注解Pointcut clpc = AnnotationMatchingPointcut.forClassAnnotation(TargetDataSource.class);// 方法注解Pointcut mpc = AnnotationMatchingPointcut.forMethodAnnotation(TargetDataSource.class);return new ComposablePointcut(cpc).union(clpc).union(mpc);}
}
import com.xxx.DataSourceKey;
import com.xxx.TargetDataSource;
import com.xxx.DynamicDataSourceContextHolder;
import org.aopalliance.intercept.MethodInterceptor;
import org.aopalliance.intercept.MethodInvocation;
import org.slf4j.Logger;
import org.slf4j.LoggerFactory;
import org.springframework.core.annotation.AnnotationUtils;import java.lang.reflect.Method;
import java.util.HashMap;
import java.util.Map;/*** 数据源切换**/
public class DynamicDataSourceAnnotationInterceptor implements MethodInterceptor {private static final Logger logger = LoggerFactory.getLogger(DynamicDataSourceAnnotationInterceptor.class);/*** 缓存方法注解值*/private static final Map<Method, DataSourceKey> METHOD_CACHE = new HashMap<>();@Overridepublic Object invoke(MethodInvocation methodInvocation) throws Throwable {try {DataSourceKey datasource = determineDatasource(methodInvocation);//如果数据源不存在,则使用默认数据源if (!DynamicDataSourceContextHolder.containDataSourceKey(datasource.getName())) {logger.info("数据源[{}]不存在,使用默认数据源 >", datasource);}DynamicDataSourceContextHolder.setDataSourceKey(datasource.getName());return methodInvocation.proceed();} finally {//设置数据源之前一定要先移除DynamicDataSourceContextHolder.clearDataSourceKey();}}private DataSourceKey determineDatasource(MethodInvocation invocation) {Method method = invocation.getMethod();if (METHOD_CACHE.containsKey(method)) {return METHOD_CACHE.get(method);} else {TargetDataSource ds = method.isAnnotationPresent(TargetDataSource.class) ? method.getAnnotation(TargetDataSource.class): AnnotationUtils.findAnnotation(method.getDeclaringClass(), TargetDataSource.class);METHOD_CACHE.put(method, ds.value());return ds.value();}}
}
import com.xxx.TargetDataSource;
import com.xxx.DynamicDataSourceContextHolder;
import org.aspectj.lang.JoinPoint;
import org.aspectj.lang.annotation.After;
import org.aspectj.lang.annotation.Before;
import org.slf4j.Logger;
import org.slf4j.LoggerFactory;public class DynamicDataSourceAspect {private static final Logger logger = LoggerFactory.getLogger(DynamicDataSourceAspect.class);@Before("@annotation(targetDataSource))")public void switchDataSource(JoinPoint joinPoint, TargetDataSource targetDataSource){if ( !DynamicDataSourceContextHolder.containDataSourceKey( targetDataSource.value().getName() ) ) {logger.error("DataSource [{}] doesn't exist, use default DataSource [{}]", targetDataSource.value());} else {DynamicDataSourceContextHolder.setDataSourceKey( targetDataSource.value().getName() );logger.info("Switch DataSource to [{}] in Method [{}]",DynamicDataSourceContextHolder.getDataSourceKey(), joinPoint.getSignature());}}@After("@annotation(targetDataSource))")public void restoreDataSource(JoinPoint joinPoint,TargetDataSource targetDataSource){DynamicDataSourceContextHolder.clearDataSourceKey();logger.info("Restore DataSource to [{}] in Method [{}]",DynamicDataSourceContextHolder.getDataSourceKey(), joinPoint.getSignature());}
}
如若内容造成侵权/违法违规/事实不符,请联系编程学习网邮箱:809451989@qq.com进行投诉反馈,一经查实,立即删除!
相关文章
- 约瑟夫环数组与递归程序(mips汇编实现)
一、问题描述 约瑟夫环问题是一个很经典的问题:一个圈共有N个人(N为不确定的数字),第一个人的编号为0或1,假设这边我将第一个人的编号设置为1号,那么第二个人的编号就为2号,第三个人的编号就为3…...
2024/3/6 11:35:41 - js小案例(二)抽奖
js之抽奖 实现效果 描述:点击开始后,开始按键变色,且再次点击无效果,上面文字快速随机出现,点击停止,文字停止,开始按钮变回原来颜色且可点击。 实现代码** html代码如下: <!…...
2024/3/6 11:35:40 - openstack CPU模式可配置:Custom/HostMode
整体需求 CPU模式可配置:Custom/HostMode 相关调研 libvirt 中,支持 3 种 cpu_mode host-passthrough: libvirt 令 KVM 把宿主机的 CPU 指令集全部透传给虚拟机。因此虚拟机能够最大限度的使用宿主机 CPU 指令集,故性能是最好的。但是在热迁…...
2024/3/6 11:35:39 - 这是我的自我介绍
朋友们大家好,我是来自贵州的小伙伴,大家可以叫我小吴,我是一名半路出家的Java程序员学员,我的性格比较内向,擅长仔细内容的编写,我想学习更多的Java知识,在学习过程中与大家交流,所…...
2024/3/6 11:35:38 - Redis中的常用命令
Redis中的常用命令哪些? a、hset 存储一个哈希键值对的集合 b、hget获取一个哈希键的值 c、hdel 删除一个或多个字段 d、hgetall 获取一个哈希是键值对的集合 e、lpush key value向链表左侧添加 f、rpush key value向链表右侧添加 g、lpop key 从左边移出一个元素 h…...
2024/3/6 11:35:38 - 2021年全球与中国油位计行业市场规模及发展前景分析
2021年全球与中国油位计行业市场规模及发展前景分析 本报告研究全球与中国市场油位计的发展现状及未来发展趋势,分别从生产和消费的角度分析油位计的主要生产地区、主要消费地区以及主要的生产商。重点分析全球与中国市场的主要厂商产品特点、产品规格、不同规格产品…...
2024/3/6 11:35:36 - 王道操作系统-进程管理速览
目录前言进程的定义、组成、组织方式、特征进程的状态与转换进程控制进程通信线程概念和多线程模型处理机调度进程调度调度算法的评价指标早期批处理系统的调度算法交互式系统的调度算法前言 本文是对王道操作系统课程的速览和总结,如有侵权,请联系我删…...
2024/3/6 11:35:35 - 数据库系统概论--第十一章:并发控制
文章目录1.并发控制概述(多事务执行方式、丢失修改、不可重复读、读 “脏”数据的定义)2.封锁(排它锁、共享锁、相容矩阵)3.封锁协议3.1 一级封锁协议(能解决:丢失修改)3.2 二级封锁协议(能解决…...
2024/3/4 14:43:10 - 攻防世界前五题和sql-labs
攻防世界 1.在地址前加上view source: 更多工具-web开发者工具-查看器 更多工具-页面源代码(CTRLu) 2.robots协议也叫做robots.txt robots里面的文件不能自己爬取,所以要手动输入 3.backup 常见的备份文件名后缀名是.bak 在地…...
2024/3/25 9:33:44 - DWVA——SQL Injection(LOW)
此文章仅供学习使用,请勿用作违法行为。 目录 注入的前提条件 基本思路 1.判断是否存在注入点,以及注入的类型(字符型/数字型) 2.猜解SQL查询语句中的字段数和字段顺序 3.确定回显点 4.获取当前数据库 5.获取数据库中的表…...
2024/3/4 14:43:08 - 22021年全球与中国火化炉行业市场规模及发展前景分析
2021年全球与中国火化炉行业市场规模及发展前景分析 本报告研究全球与中国市场火化炉的发展现状及未来发展趋势,分别从生产和消费的角度分析火化炉的主要生产地区、主要消费地区以及主要的生产商。重点分析全球与中国市场的主要厂商产品特点、产品规格、不同规格产品…...
2024/3/4 14:43:06 - 算法一【排序算法】
排序算法1.排序算法的稳定性2.冒泡排序2.1 冒泡排序的分析2.2 冒泡排序的代码实现2.3 时间复杂度3. 选择排序3.1 选择排序分析3.2 选择排序代码实现3.3 时间复杂度4.插入排序4.1 插入排序分析4.2 插入排序实现代码4.3 时间复杂度5.希尔排序5.1 希尔排序过程5.2 希尔排序的分析5…...
2024/3/4 14:43:05 - “21天好习惯”第一期- 14 深度学习(1)
深度学习(英语:deep learning)是机器学习的分支,是一种以人工神经网络为架构,对资料进行表征学习的算法。 深度学习是机器学习中一种基于对数据进行表征学习的算法。观测值(例如一幅图像)可以使…...
2024/3/4 14:43:05 - Ubuntu16.04 cuda10.1安装与卸载,NVIDIA驱动安装
Ubuntu16.04 cuda10.1安装与卸载,NVIDIA驱动安装 1 cuda 10.0卸载 sudo /usr/local/cuda-10.0/bin/uninstall_cuda_10.0.pl 删除残余 sudo /usr/local/cuda卸载完成! 2 安装nvidia驱动 sudo ubuntu-drivers devicessudo ubuntu-drivers autoinstall…...
2024/3/4 14:43:03 - 【kindle资源】一本不得不读的投资经典《唐朝-手把手教你读财报》
《手把手教你读财报》是一位久经沙场的老股民,在经历了无数次惨烈的投资战役之后,总结过往得失,呕心沥血而作。因为不是会计专业出身,所以没有晦涩的术语、难懂的公式。因为有多年的投资经历,所以更明白财报的意义所在…...
2024/3/6 11:35:34 - 简单理解DNS及解析流程
简单整理了下这周计算机网络课上的我的PPT分享题目。 参考 超详细 DNS 协议解析 DNS域名解析过程bilibili 我们知道,因特网上识别主机的方式有两种:1.使用IP地址。 2. 使用主机名(域名) 那么从浏览器地址栏输入 url 到请求返回…...
2024/3/6 11:35:33 - 吊哥FOC学习笔记---第二步开环FOC驱动
吊哥FOC学习笔记第二步—开环FOC驱动 在前面我们讲解了移植吊哥FOC的代码,点亮LED灯的程序,接下来就要正式进入FOC开环驱动了~ 我们赋值上次的工程文件,并将其修改成FOC_OpenLoopRun。我们在原来的基础上添加开环所需要的代码。 1、开环所…...
2024/3/22 16:08:45 - C++ map与unordered_map使用和区别
转至:https://blog.csdn.net/BillCYJ/article/details/78985895 https://www.cnblogs.com/langyao/p/8823092.html 需要引入的头文件不同 map: #include < map > unordered_map: #include < unordered_map > 内部实现机理不同 map: map内…...
2024/3/17 11:35:26 - 数据结构——图
一、图的基本概念 图(Graph)——图G是由两个集合 V(G) 和E(G) 组成的,记为 G(V,E),其中:V(G) 是顶点的非空有限集, E(G) 是边的有限集合,边是顶点的无序对或有序对。 图不能是空图 1.图的术语和定义 1)有…...
2024/3/6 11:35:30 - 2021年全球与中国电动辅助轮椅行业市场规模及发展前景分析
2021年全球与中国电动辅助轮椅行业市场规模及发展前景分析 本报告研究全球与中国市场电动辅助轮椅的发展现状及未来发展趋势,分别从生产和消费的角度分析电动辅助轮椅的主要生产地区、主要消费地区以及主要的生产商。重点分析全球与中国市场的主要厂商产品特点、产品…...
2024/3/6 11:35:29
最新文章
- SpringBoot与Prometheus监控整合
参考: springboot实战之prometheus监控整合-腾讯云开发者社区-腾讯云 https://www.cnblogs.com/skevin/p/15874139.html https://www.jianshu.com/p/e5dc2b45c7a4...
2024/3/29 0:42:23 - 梯度消失和梯度爆炸的一些处理方法
在这里是记录一下梯度消失或梯度爆炸的一些处理技巧。全当学习总结了如有错误还请留言,在此感激不尽。 权重和梯度的更新公式如下: w w − η ⋅ ∇ w w w - \eta \cdot \nabla w ww−η⋅∇w 个人通俗的理解梯度消失就是网络模型在反向求导的时候出…...
2024/3/20 10:50:27 - RESTful架构
RESTful架构中的URI设计与传统的URL设计有一些区别。让我通过具体的例子来解释一下: 传统的URL设计通常将操作和资源混合在一起,例如: 获取所有图书:GET /getBooks获取特定图书:GET /getBookById/{id}创建新图书&…...
2024/3/28 7:28:37 - python 爬取人民新闻
基础信息获取: 要闻url:https://www.gov.cn/yaowen/liebiao/home.htm 下一页的url:https://www.gov.cn/yaowen/liebiao/home_1.htm 基础代码: import re import openpyxl import requests from lxml import etree import osdef …...
2024/3/26 19:54:48 - 【外汇早评】美通胀数据走低,美元调整
原标题:【外汇早评】美通胀数据走低,美元调整昨日美国方面公布了新一期的核心PCE物价指数数据,同比增长1.6%,低于前值和预期值的1.7%,距离美联储的通胀目标2%继续走低,通胀压力较低,且此前美国一季度GDP初值中的消费部分下滑明显,因此市场对美联储后续更可能降息的政策…...
2024/3/27 10:21:24 - 【原油贵金属周评】原油多头拥挤,价格调整
原标题:【原油贵金属周评】原油多头拥挤,价格调整本周国际劳动节,我们喜迎四天假期,但是整个金融市场确实流动性充沛,大事频发,各个商品波动剧烈。美国方面,在本周四凌晨公布5月份的利率决议和新闻发布会,维持联邦基金利率在2.25%-2.50%不变,符合市场预期。同时美联储…...
2024/3/24 20:11:25 - 【外汇周评】靓丽非农不及疲软通胀影响
原标题:【外汇周评】靓丽非农不及疲软通胀影响在刚结束的周五,美国方面公布了新一期的非农就业数据,大幅好于前值和预期,新增就业重新回到20万以上。具体数据: 美国4月非农就业人口变动 26.3万人,预期 19万人,前值 19.6万人。 美国4月失业率 3.6%,预期 3.8%,前值 3…...
2024/3/18 12:12:47 - 【原油贵金属早评】库存继续增加,油价收跌
原标题:【原油贵金属早评】库存继续增加,油价收跌周三清晨公布美国当周API原油库存数据,上周原油库存增加281万桶至4.692亿桶,增幅超过预期的74.4万桶。且有消息人士称,沙特阿美据悉将于6月向亚洲炼油厂额外出售更多原油,印度炼油商预计将每日获得至多20万桶的额外原油供…...
2024/3/24 20:11:23 - 【外汇早评】日本央行会议纪要不改日元强势
原标题:【外汇早评】日本央行会议纪要不改日元强势近两日日元大幅走强与近期市场风险情绪上升,避险资金回流日元有关,也与前一段时间的美日贸易谈判给日本缓冲期,日本方面对汇率问题也避免继续贬值有关。虽然今日早间日本央行公布的利率会议纪要仍然是支持宽松政策,但这符…...
2024/3/26 20:58:42 - 【原油贵金属早评】欧佩克稳定市场,填补伊朗问题的影响
原标题:【原油贵金属早评】欧佩克稳定市场,填补伊朗问题的影响近日伊朗局势升温,导致市场担忧影响原油供给,油价试图反弹。此时OPEC表态稳定市场。据消息人士透露,沙特6月石油出口料将低于700万桶/日,沙特已经收到石油消费国提出的6月份扩大出口的“适度要求”,沙特将满…...
2024/3/28 17:01:12 - 【外汇早评】美欲与伊朗重谈协议
原标题:【外汇早评】美欲与伊朗重谈协议美国对伊朗的制裁遭到伊朗的抗议,昨日伊朗方面提出将部分退出伊核协议。而此行为又遭到欧洲方面对伊朗的谴责和警告,伊朗外长昨日回应称,欧洲国家履行它们的义务,伊核协议就能保证存续。据传闻伊朗的导弹已经对准了以色列和美国的航…...
2024/3/24 5:55:47 - 【原油贵金属早评】波动率飙升,市场情绪动荡
原标题:【原油贵金属早评】波动率飙升,市场情绪动荡因中美贸易谈判不安情绪影响,金融市场各资产品种出现明显的波动。随着美国与中方开启第十一轮谈判之际,美国按照既定计划向中国2000亿商品征收25%的关税,市场情绪有所平复,已经开始接受这一事实。虽然波动率-恐慌指数VI…...
2024/3/27 10:28:22 - 【原油贵金属周评】伊朗局势升温,黄金多头跃跃欲试
原标题:【原油贵金属周评】伊朗局势升温,黄金多头跃跃欲试美国和伊朗的局势继续升温,市场风险情绪上升,避险黄金有向上突破阻力的迹象。原油方面稍显平稳,近期美国和OPEC加大供给及市场需求回落的影响,伊朗局势并未推升油价走强。近期中美贸易谈判摩擦再度升级,美国对中…...
2024/3/26 23:04:51 - 【原油贵金属早评】市场情绪继续恶化,黄金上破
原标题:【原油贵金属早评】市场情绪继续恶化,黄金上破周初中国针对于美国加征关税的进行的反制措施引发市场情绪的大幅波动,人民币汇率出现大幅的贬值动能,金融市场受到非常明显的冲击。尤其是波动率起来之后,对于股市的表现尤其不安。隔夜美国股市出现明显的下行走势,这…...
2024/3/26 11:20:25 - 【外汇早评】美伊僵持,风险情绪继续升温
原标题:【外汇早评】美伊僵持,风险情绪继续升温昨日沙特两艘油轮再次发生爆炸事件,导致波斯湾局势进一步恶化,市场担忧美伊可能会出现摩擦生火,避险品种获得支撑,黄金和日元大幅走强。美指受中美贸易问题影响而在低位震荡。继5月12日,四艘商船在阿联酋领海附近的阿曼湾、…...
2024/3/24 20:11:18 - 【原油贵金属早评】贸易冲突导致需求低迷,油价弱势
原标题:【原油贵金属早评】贸易冲突导致需求低迷,油价弱势近日虽然伊朗局势升温,中东地区几起油船被袭击事件影响,但油价并未走高,而是出于调整结构中。由于市场预期局势失控的可能性较低,而中美贸易问题导致的全球经济衰退风险更大,需求会持续低迷,因此油价调整压力较…...
2024/3/28 9:10:53 - 氧生福地 玩美北湖(上)——为时光守候两千年
原标题:氧生福地 玩美北湖(上)——为时光守候两千年一次说走就走的旅行,只有一张高铁票的距离~ 所以,湖南郴州,我来了~ 从广州南站出发,一个半小时就到达郴州西站了。在动车上,同时改票的南风兄和我居然被分到了一个车厢,所以一路非常愉快地聊了过来。 挺好,最起…...
2024/3/24 20:11:16 - 氧生福地 玩美北湖(中)——永春梯田里的美与鲜
原标题:氧生福地 玩美北湖(中)——永春梯田里的美与鲜一觉醒来,因为大家太爱“美”照,在柳毅山庄去寻找龙女而错过了早餐时间。近十点,向导坏坏还是带着饥肠辘辘的我们去吃郴州最富有盛名的“鱼头粉”。说这是“十二分推荐”,到郴州必吃的美食之一。 哇塞!那个味美香甜…...
2024/3/24 20:11:15 - 氧生福地 玩美北湖(下)——奔跑吧骚年!
原标题:氧生福地 玩美北湖(下)——奔跑吧骚年!让我们红尘做伴 活得潇潇洒洒 策马奔腾共享人世繁华 对酒当歌唱出心中喜悦 轰轰烈烈把握青春年华 让我们红尘做伴 活得潇潇洒洒 策马奔腾共享人世繁华 对酒当歌唱出心中喜悦 轰轰烈烈把握青春年华 啊……啊……啊 两…...
2024/3/27 7:12:50 - 扒开伪装医用面膜,翻六倍价格宰客,小姐姐注意了!
原标题:扒开伪装医用面膜,翻六倍价格宰客,小姐姐注意了!扒开伪装医用面膜,翻六倍价格宰客!当行业里的某一品项火爆了,就会有很多商家蹭热度,装逼忽悠,最近火爆朋友圈的医用面膜,被沾上了污点,到底怎么回事呢? “比普通面膜安全、效果好!痘痘、痘印、敏感肌都能用…...
2024/3/24 20:11:13 - 「发现」铁皮石斛仙草之神奇功效用于医用面膜
原标题:「发现」铁皮石斛仙草之神奇功效用于医用面膜丽彦妆铁皮石斛医用面膜|石斛多糖无菌修护补水贴19大优势: 1、铁皮石斛:自唐宋以来,一直被列为皇室贡品,铁皮石斛生于海拔1600米的悬崖峭壁之上,繁殖力差,产量极低,所以古代仅供皇室、贵族享用 2、铁皮石斛自古民间…...
2024/3/26 11:21:23 - 丽彦妆\医用面膜\冷敷贴轻奢医学护肤引导者
原标题:丽彦妆\医用面膜\冷敷贴轻奢医学护肤引导者【公司简介】 广州华彬企业隶属香港华彬集团有限公司,专注美业21年,其旗下品牌: 「圣茵美」私密荷尔蒙抗衰,产后修复 「圣仪轩」私密荷尔蒙抗衰,产后修复 「花茵莳」私密荷尔蒙抗衰,产后修复 「丽彦妆」专注医学护…...
2024/3/28 18:26:34 - 广州械字号面膜生产厂家OEM/ODM4项须知!
原标题:广州械字号面膜生产厂家OEM/ODM4项须知!广州械字号面膜生产厂家OEM/ODM流程及注意事项解读: 械字号医用面膜,其实在我国并没有严格的定义,通常我们说的医美面膜指的应该是一种「医用敷料」,也就是说,医用面膜其实算作「医疗器械」的一种,又称「医用冷敷贴」。 …...
2024/3/28 12:42:28 - 械字号医用眼膜缓解用眼过度到底有无作用?
原标题:械字号医用眼膜缓解用眼过度到底有无作用?医用眼膜/械字号眼膜/医用冷敷眼贴 凝胶层为亲水高分子材料,含70%以上的水分。体表皮肤温度传导到本产品的凝胶层,热量被凝胶内水分子吸收,通过水分的蒸发带走大量的热量,可迅速地降低体表皮肤局部温度,减轻局部皮肤的灼…...
2024/3/28 20:09:10 - 配置失败还原请勿关闭计算机,电脑开机屏幕上面显示,配置失败还原更改 请勿关闭计算机 开不了机 这个问题怎么办...
解析如下:1、长按电脑电源键直至关机,然后再按一次电源健重启电脑,按F8健进入安全模式2、安全模式下进入Windows系统桌面后,按住“winR”打开运行窗口,输入“services.msc”打开服务设置3、在服务界面,选中…...
2022/11/19 21:17:18 - 错误使用 reshape要执行 RESHAPE,请勿更改元素数目。
%读入6幅图像(每一幅图像的大小是564*564) 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 - 配置 已完成 请勿关闭计算机,win7系统关机提示“配置Windows Update已完成30%请勿关闭计算机...
win7系统关机提示“配置Windows Update已完成30%请勿关闭计算机”问题的解决方法在win7系统关机时如果有升级系统的或者其他需要会直接进入一个 等待界面,在等待界面中我们需要等待操作结束才能关机,虽然这比较麻烦,但是对系统进行配置和升级…...
2022/11/19 21:17:15 - 台式电脑显示配置100%请勿关闭计算机,“准备配置windows 请勿关闭计算机”的解决方法...
有不少用户在重装Win7系统或更新系统后会遇到“准备配置windows,请勿关闭计算机”的提示,要过很久才能进入系统,有的用户甚至几个小时也无法进入,下面就教大家这个问题的解决方法。第一种方法:我们首先在左下角的“开始…...
2022/11/19 21:17:14 - win7 正在配置 请勿关闭计算机,怎么办Win7开机显示正在配置Windows Update请勿关机...
置信有很多用户都跟小编一样遇到过这样的问题,电脑时发现开机屏幕显现“正在配置Windows Update,请勿关机”(如下图所示),而且还需求等大约5分钟才干进入系统。这是怎样回事呢?一切都是正常操作的,为什么开时机呈现“正…...
2022/11/19 21:17:13 - 准备配置windows 请勿关闭计算机 蓝屏,Win7开机总是出现提示“配置Windows请勿关机”...
Win7系统开机启动时总是出现“配置Windows请勿关机”的提示,没过几秒后电脑自动重启,每次开机都这样无法进入系统,此时碰到这种现象的用户就可以使用以下5种方法解决问题。方法一:开机按下F8,在出现的Windows高级启动选…...
2022/11/19 21:17:12 - 准备windows请勿关闭计算机要多久,windows10系统提示正在准备windows请勿关闭计算机怎么办...
有不少windows10系统用户反映说碰到这样一个情况,就是电脑提示正在准备windows请勿关闭计算机,碰到这样的问题该怎么解决呢,现在小编就给大家分享一下windows10系统提示正在准备windows请勿关闭计算机的具体第一种方法:1、2、依次…...
2022/11/19 21:17:11 - 配置 已完成 请勿关闭计算机,win7系统关机提示“配置Windows Update已完成30%请勿关闭计算机”的解决方法...
今天和大家分享一下win7系统重装了Win7旗舰版系统后,每次关机的时候桌面上都会显示一个“配置Windows Update的界面,提示请勿关闭计算机”,每次停留好几分钟才能正常关机,导致什么情况引起的呢?出现配置Windows Update…...
2022/11/19 21:17:10 - 电脑桌面一直是清理请关闭计算机,windows7一直卡在清理 请勿关闭计算机-win7清理请勿关机,win7配置更新35%不动...
只能是等着,别无他法。说是卡着如果你看硬盘灯应该在读写。如果从 Win 10 无法正常回滚,只能是考虑备份数据后重装系统了。解决来方案一:管理员运行cmd:net stop WuAuServcd %windir%ren SoftwareDistribution SDoldnet start WuA…...
2022/11/19 21:17:09 - 计算机配置更新不起,电脑提示“配置Windows Update请勿关闭计算机”怎么办?
原标题:电脑提示“配置Windows Update请勿关闭计算机”怎么办?win7系统中在开机与关闭的时候总是显示“配置windows update请勿关闭计算机”相信有不少朋友都曾遇到过一次两次还能忍但经常遇到就叫人感到心烦了遇到这种问题怎么办呢?一般的方…...
2022/11/19 21:17:08 - 计算机正在配置无法关机,关机提示 windows7 正在配置windows 请勿关闭计算机 ,然后等了一晚上也没有关掉。现在电脑无法正常关机...
关机提示 windows7 正在配置windows 请勿关闭计算机 ,然后等了一晚上也没有关掉。现在电脑无法正常关机以下文字资料是由(历史新知网www.lishixinzhi.com)小编为大家搜集整理后发布的内容,让我们赶快一起来看一下吧!关机提示 windows7 正在配…...
2022/11/19 21:17:05 - 钉钉提示请勿通过开发者调试模式_钉钉请勿通过开发者调试模式是真的吗好不好用...
钉钉请勿通过开发者调试模式是真的吗好不好用 更新时间:2020-04-20 22:24:19 浏览次数:729次 区域: 南阳 > 卧龙 列举网提醒您:为保障您的权益,请不要提前支付任何费用! 虚拟位置外设器!!轨迹模拟&虚拟位置外设神器 专业用于:钉钉,外勤365,红圈通,企业微信和…...
2022/11/19 21:17:05 - 配置失败还原请勿关闭计算机怎么办,win7系统出现“配置windows update失败 还原更改 请勿关闭计算机”,长时间没反应,无法进入系统的解决方案...
前几天班里有位学生电脑(windows 7系统)出问题了,具体表现是开机时一直停留在“配置windows update失败 还原更改 请勿关闭计算机”这个界面,长时间没反应,无法进入系统。这个问题原来帮其他同学也解决过,网上搜了不少资料&#x…...
2022/11/19 21:17:04 - 一个电脑无法关闭计算机你应该怎么办,电脑显示“清理请勿关闭计算机”怎么办?...
本文为你提供了3个有效解决电脑显示“清理请勿关闭计算机”问题的方法,并在最后教给你1种保护系统安全的好方法,一起来看看!电脑出现“清理请勿关闭计算机”在Windows 7(SP1)和Windows Server 2008 R2 SP1中,添加了1个新功能在“磁…...
2022/11/19 21:17:03 - 请勿关闭计算机还原更改要多久,电脑显示:配置windows更新失败,正在还原更改,请勿关闭计算机怎么办...
许多用户在长期不使用电脑的时候,开启电脑发现电脑显示:配置windows更新失败,正在还原更改,请勿关闭计算机。。.这要怎么办呢?下面小编就带着大家一起看看吧!如果能够正常进入系统,建议您暂时移…...
2022/11/19 21:17:02 - 还原更改请勿关闭计算机 要多久,配置windows update失败 还原更改 请勿关闭计算机,电脑开机后一直显示以...
配置windows update失败 还原更改 请勿关闭计算机,电脑开机后一直显示以以下文字资料是由(历史新知网www.lishixinzhi.com)小编为大家搜集整理后发布的内容,让我们赶快一起来看一下吧!配置windows update失败 还原更改 请勿关闭计算机&#x…...
2022/11/19 21:17:01 - 电脑配置中请勿关闭计算机怎么办,准备配置windows请勿关闭计算机一直显示怎么办【图解】...
不知道大家有没有遇到过这样的一个问题,就是我们的win7系统在关机的时候,总是喜欢显示“准备配置windows,请勿关机”这样的一个页面,没有什么大碍,但是如果一直等着的话就要两个小时甚至更久都关不了机,非常…...
2022/11/19 21:17:00 - 正在准备配置请勿关闭计算机,正在准备配置windows请勿关闭计算机时间长了解决教程...
当电脑出现正在准备配置windows请勿关闭计算机时,一般是您正对windows进行升级,但是这个要是长时间没有反应,我们不能再傻等下去了。可能是电脑出了别的问题了,来看看教程的说法。正在准备配置windows请勿关闭计算机时间长了方法一…...
2022/11/19 21:16:59 - 配置失败还原请勿关闭计算机,配置Windows Update失败,还原更改请勿关闭计算机...
我们使用电脑的过程中有时会遇到这种情况,当我们打开电脑之后,发现一直停留在一个界面:“配置Windows Update失败,还原更改请勿关闭计算机”,等了许久还是无法进入系统。如果我们遇到此类问题应该如何解决呢࿰…...
2022/11/19 21:16:58 - 如何在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