连接假死

什么是连接假死呢?

如果底层的TCP连接已经断开,但是服务器端并没有正常地关闭套接字,服务器端认为这条TCP连接仍然是存在。

连接假死的具体表现如下:

(1)在服务器端,会有一些处于TCP_ESTABLISHED状态的“正常”连接。

(2)但在客户端,TCP客户端已经显示连接已经断开。

(3)客户端此时虽然可以进行断线重连操作,但是上一次的连接状态依然被服务器端认为有效,并且服务器端的资源得不到正确释放,包括套接字上下文以及接收/发送缓冲区。

连接假死通常是由以下多个原因造成的,例如:

(1)应用程序出现线程堵塞,无法进行数据的读写。

(2)网络相关的设备出现故障,例如网卡、机房故障。

(3)网络丢包。公网环境非常容易出现丢包和网络抖动等"

解决假死的有效手段是:客户端定时进行心跳检测,服务器端定时进行空闲检测。

  • 空闲检测:就是每隔一段时间,检测子通道是否有数据读写,如果有,则子通道是正常的;如果没有,则子通道被判定为假死,关掉子通道。
  • 使用Netty自带的IdleStateHandler空闲状态处理器就可以实现空闲检测功能。HeartBeatServerHandler实现的主要功能是空闲检测,需要客户端定时发送心跳数据包(或报文、消息)进行配合。而且客户端发送心跳数据包的时间间隔需要远远小于服务器端的空闲检测时间间隔;与服务器端的空闲检测相配合,客户端需要定期发送数据包到服务器端,通常这个数据包称为心跳数据包。

Zookeeper:

ZooKeeper节点数有以下要求:

(1)ZooKeeper集群节点数必须是奇数。需要一个主节点,也称为Leader节点。主节点是集群通过选举的规则从所有节点中选举出来的。在选举的规则中很重要的一条是:要求可用节点数量>总节点数量/2。如果是偶数个节点,则可能会出现不满足这个规则的情况。

(2)ZooKeeper集群至少是3个。安装集群的第一步是在安装目录下提前为每一个伪节点创建好两个目录:日志目录和数据目录。

安装ZooKeeper集群:

  • 第一步是在安装目录下提前为每一个伪节点创建好两个目录:日志目录和数据目录。

  • 第二步,为创建一个文件名为myid的id文件。myid文件的特点如下:
    1. ·myid文件的唯一作用是记录(伪)节点的编号。
    2. ·myid文件是一个文本文件,文件名称为myid。
    3. ·myid文件内容为一个数字,表示节点的编号。
    4. ·myid文件中只能有一个数字,不能有其他的内容。
    5. ·myid文件的存放位置,默认处于数据目录下。
  • 第三步,为每个节点创建配置文件。仿照zoo_sample.cfg文件配置。配置节点的时候,需要注意四点:
    1. 不能有相同id的节点,需要确保每个节点的myid文件中的id值不同;
    2. 每一行“server.id=host:port:port”中的id值,需要与所对应节点的数据目录下的myid文件中的id值保持一致;
    3. 每一个配置文件都需要配置全部的节点信息。不仅仅是配置自己的那份,还需要配置所有节点的id、ip、端口。
    4. 在每一行“server.id=host:port:port”中,需要配置两个端口。前一个端口用于节点之间的通信,后一个端口用于选举主节点。

验证集群的启动是否成功的两个方法:

  • 方法一,可以通过执行jps命令,我们可以看到QuorumPeerMain进程的数量。
  • 方法二,启动ZooKeeper客户端,运行并查看一下是否能连接集群。 如果最后显示出“CONNECTED”连接状态,则表示已经成功连接。

Windows下,ZooKeeper是通过.cmd命令文件中的批处理命令来运行的,默认没有提供Windows后台服务方案。为了避免每次关闭后,再一次启动ZooKeeper时还需要使用cmd带来的不便,可以通过prunsrv第三方工具来将ZooKeeper做成Windows服务,将ZooKeeper变成后台服务来运行。

ZooKeeper的存储模型非常简单,它和Linux的文件系统非常的类似。简单地说,ZooKeeper的存储模型是一棵以"/"为根节点的树。ZooKeeper的存储模型中的每一个节点,叫作ZNode(ZooKeeper Node)节点。通过ZNode树,ZooKeeper提供了一个多层级的树形命名空间。与文件的目录系统中的目录有所不同的是,这些ZNode节点可以保存二进制有效负载数据(Payload)。而文件系统目录树中的目录,只能存放路径信息,而不能存放负载数据。ZooKeeper为了保证高吞吐和低延迟,整个树形的目录结构全部都放在内存中。ZooKeeper官方的要求是,每个节点存放的有效负载数据(Payload)的上限仅为1MB。

ZooKeeper API:

  • ZooKeeper官方API有一些不足之处:
  1. ·ZooKeeper的Watcher监测是一次性的,每次触发之后都需要重新进行注册。
  2. ·会话超时之后没有实现重连机制。
  3. ·异常处理烦琐,ZooKeeper提供了很多异常,对于开发人员来说可能根本不知道应该如何处理这些抛出的异常。
  4. ·仅提供了简单的byte[]数组类型的接口,没有提供Java POJO级别的序列化数据处理接口。
  5. ·创建节点时如果抛出异常,需要自行检查节点是否存在。
  6. ·无法实现级联删除。                                              
  • ZkClient对原生API进行了封装,但也有它自身的不足之处:
  1. ·ZkClient社区不活跃,文档不够完善,几乎没有参考文档。
  2. ·异常处理简化(抛出RuntimeException)。
  3. ·重试机制比较难用。
  4. ·没有提供各种使用场景的参考实现。
  • curator-framework:
  1. curator-framework是对ZooKeeper的底层API的一些封装。
  2. ·curator-client提供了一些客户端的操作,例如重试策略等。
  3. ·curator-recipes封装了一些高级特性,如:Cache事件监听、选举、分布式锁、分布式计数器、分布式Barrier等。

curator-framework

在使用curator-framework包操作ZooKeeper前,首先要创建一个客户端实例——这是一个CuratorFramework类型的对象,有两种方法:

  • ·使用工厂类CuratorFrameworkFactory的静态newClient()方法。
  • ·使用工厂类CuratorFrameworkFactory的静态builder构造者方法。

创建客户端实例:

public class ClientFactory {

    /**

     * @param connectionString zk的连接地址

     * @return CuratorFramework 实例

     */

    public static CuratorFramework createSimple(String connectionString) {

        // 重试策略:第一次重试等待1s,第二次重试等待2s,第三次重试等待4s

        // 第一个参数:等待时间的基础单位,单位为毫秒

        // 第二个参数:最大重试次数

        ExponentialBackoffRetry retryPolicy = new ExponentialBackoffRetry(1000, 3);

        // 获取 CuratorFramework 实例的最简单的方式

        // 第一个参数:zk的连接地址

        // 第二个参数:重试策略

  return CuratorFrameworkFactory.newClient(connectionString, retryPolicy);

    }

    /**

     * @param connectionString    zk的连接地址

     * @param retryPolicy         重试策略

     * @param connectionTimeoutMs 连接

     * @param sessionTimeoutMs

     * @return CuratorFramework 实例

     */

    public static CuratorFramework createWithOptions(String connectionString, RetryPolicy retryPolicy,

            int connectionTimeoutMs, int sessionTimeoutMs) {

        // builder 模式创建 CuratorFramework 实例

        return CuratorFrameworkFactory.builder()

                .connectString(connectionString)

                .retryPolicy(retryPolicy)

                .connectionTimeoutMs(connectionTimeoutMs)

                .sessionTimeoutMs(sessionTimeoutMs)

                // 其他的创建选项

                .build();

    }

}

通过Curator创建ZNode节点可以使用create()方法。create()方法不需要传入ZNode的节点路径,所以并不会立即创建节点,仅仅返回一个CreateBuilder构造者实例。通过该CreateBuilder构造者实例,可以设置创建节点时的一些行为参数,最后再通过构造者实例的forPath(String znodePath,byte[] payload)方法来完成真正的节点创建。

ZooKeeper节点有4种类型:

(1)PERSISTENT——持久化节点

(2)PERSISTENT_SEQUENTIAL——持久化顺序节点

(3)PHEMERAL——临时节

(4)EPHEMERAL_SEQUENTIAL——临时顺序节点

public class ZKclient {

    private CuratorFramework client;

    //Zk集群地址

    private static final String ZK_ADDRESS = "127.0.0.1:2181";

    public static ZKclient instance = null;

    static {

        instance = new ZKclient();

        instance.init();

    }

    private ZKclient() {

    }

    public void init() {

        if (null != client) {

            return;

        }

        //创建客户端

        client = ClientFactory.createSimple(ZK_ADDRESS);

        //启动客户端实例,连接服务器

        client.start();

    }

    public void destroy() {

        CloseableUtils.closeQuietly(client);

    }

    /**

     * 创建节点

     */

    public void createNode(String zkPath, String data) {

        try {

            // 创建一个 ZNode 节点

            // 节点的数据为 payload

            byte[] payload = "to set content".getBytes("UTF-8");

            if (data != null) {

                payload = data.getBytes("UTF-8");

            }

            client.create().creatingParentsIfNeeded().withMode(CreateMode.PERSISTENT).forPath(zkPath, payload);

        } catch (Exception e) {

            e.printStackTrace();

        }

    }

 

    /**

     * 删除节点

     */

    public void deleteNode(String zkPath) {

        try {

            if (!isNodeExist(zkPath)) {

                return;

            }

            client.delete().forPath(zkPath);

        } catch (Exception e) {

            e.printStackTrace();

        }

    }

    /**

     * 检查节点

     */

    public boolean isNodeExist(String zkPath) {

        try {

            Stat stat = client.checkExists().forPath(zkPath);

            if (null == stat) {

                log.info("节点不存在:", zkPath);

                return false;

            } else {

                log.info("节点存在 stat is:", stat.toString());

                return true;

            }

 

        } catch (Exception e) {

            e.printStackTrace();

        }

        return false;

    }

    /**

     * 创建 临时 顺序 节点

     */

    public String createEphemeralSeqNode(String srcpath) {

        try {

            // 创建一个 ZNode 节点

            String path = client.create().creatingParentsIfNeeded()

                    .withMode(CreateMode.EPHEMERAL_SEQUENTIAL).forPath(srcpath);

            return path;

        } catch (Exception e) {

            e.printStackTrace();

        }

        return null;

    }

}

Curator更新节点

节点的更新分为同步更新与异步更新。同步更新就是更新线程是阻塞的,一直阻塞到更新操作执行完成为止。通过SetDataBuilder构造者实例的inBackground(AsyncCallback callback)方法,设置一个AsyncCallback回调实例。简简单单的一个函数,就将更新数据的行为从同步执行变成了异步执行。异步执行完成之后,SetDataBuilder构造者实例会再执行AsyncCallback实例的processResult(…)方法中的回调逻辑,即可完成更新后的其他操作。

public class CRUD {

    private static final String ZK_ADDRESS = "127.0.0.1:2181";

    /**

     * 检查节点

     */

    @Test

public void checkNode() {

        CuratorFramework client = ClientFactory.createSimple(ZK_ADDRESS); //创建客户端

        try {

            client.start();//启动客户端实例,连接服务器

            // 创建一个 ZNode 节点,节点的数据为 payload

            String zkPath = "/test/CRUD/remoteNode-1";

            Stat stat = client.checkExists().forPath(zkPath);

            if (null == stat) {

                log.info("节点不存在:", zkPath);

            } else {

                log.info("节点存在 stat is:", stat.toString());

            }

        } catch (Exception e) {

            e.printStackTrace();

        } finally {

            CloseableUtils.closeQuietly(client);

        }

    }

    /**

     * 创建节点  持久化节点、临时节点、持久化顺序节点

     */

    @Test

    public void createNode() {

        CuratorFramework client = ClientFactory.createSimple(ZK_ADDRESS); //创建客户端

        try {

            client.start();//启动客户端实例,连接服务器

            // 创建一个 ZNode 节点,节点的数据为 payload

            String data = "hello";

            byte[] payload = data.getBytes("UTF-8");

            String zkPath = "/test/CRUD/remoteNode-1";

     client.create().creatingParentsIfNeeded().withMode(CreateMode.PERSISTENT)

.forPath(zkPath, payload);

// client.create().creatingParentsIfNeeded().withMode(CreateMode.EPHEMERAL)

.forPath(zkPath, payload);

// client.create().creatingParentsIfNeeded().withMode(CreateMode.PERSISTENT_SEQUENTIAL)

.forPath(zkPath, payload);

        } catch (Exception e) {

            e.printStackTrace();

        } finally {

            CloseableUtils.closeQuietly(client);

        }

    }

  

    /**

     * 读取节点

     */

    @Test

    public void readNode() {

        //创建客户端

        CuratorFramework client = ClientFactory.createSimple(ZK_ADDRESS);

        try {

            //启动客户端实例,连接服务器

            client.start();

            String zkPath = "/test/CRUD/remoteNode-1";

            Stat stat = client.checkExists().forPath(zkPath);

            if (null != stat) {

                //读取节点的数据

                byte[] payload = client.getData().forPath(zkPath);

                String data = new String(payload, "UTF-8");

                log.info("read data:", data);

                String parentPath = "/test";

                List<String> children = client.getChildren().forPath(parentPath);

                for (String child : children) {

                    log.info("child:", child);

                }

            }

        } catch (Exception e) {

            e.printStackTrace();

        } finally {

            CloseableUtils.closeQuietly(client);

        }

    }

    /**

     * 更新节点

     */

    @Test

    public void updateNode() {

        //创建客户端

        CuratorFramework client = ClientFactory.createSimple(ZK_ADDRESS);

        try {

            //启动客户端实例,连接服务器

            client.start();

            String data = "hello world";

            byte[] payload = data.getBytes("UTF-8");

            String zkPath = "/test/remoteNode-1";

            client.setData().forPath(zkPath, payload);

        } catch (Exception e) {

            e.printStackTrace();

        } finally {

            CloseableUtils.closeQuietly(client);

        }

    }

    /**

     * 更新节点 - 异步模式

     */

    @Test

    public void updateNodeAsync() {

        //创建客户端

        CuratorFramework client = ClientFactory.createSimple(ZK_ADDRESS);

        try {

            //更新完成监听器

            AsyncCallback.StringCallback callback = new AsyncCallback.StringCallback() {

                @Override

                public void processResult(int i, String s, Object o, String s1) {

                    System.out.println(

                            "i = " + i + " | " +

                                    "s = " + s + " | " +

                                    "o = " + o + " | " +

                                    "s1 = " + s1

                    );

                }

            };

            //启动客户端实例,连接服务器

            client.start();

            String data = "hello ,every body! ";

            byte[] payload = data.getBytes("UTF-8");

            String zkPath = "/test/CRUD/remoteNode-1";

            client.setData().inBackground(callback).forPath(zkPath, payload);

            Thread.sleep(10000);

        } catch (Exception e) {

            e.printStackTrace();

        } finally {

            CloseableUtils.closeQuietly(client);

        }

    }

    /**

     * 删除节点

     */

    @Test

    public void deleteNode() {

        //创建客户端

        CuratorFramework client = ClientFactory.createSimple(ZK_ADDRESS);

        try {

            //启动客户端实例,连接服务器

            client.start();

            //删除节点

            String zkPath = "/test/CRUD/remoteNode-1";

            client.delete().forPath(zkPath);

            //删除后查看结果

            String parentPath = "/test";

            List<String> children = client.getChildren().forPath(parentPath);

            for (String child : children) {

                log.info("child:", child);

            }

        } catch (Exception e) {

            e.printStackTrace();

        } finally {

            CloseableUtils.closeQuietly(client);

        }

    }

}

 

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

相关文章

  1. 企业级app组件化开发3-----分享组件开发

    在各类的App中,都存在分享功能,可以分享到QQ、微信、微博等,当然分享可以到具体平台进行对接,但是平台众多,如果每个平台都对接一次,不易于扩展,因此可以使用友盟或者ShareSDK,尤其是ShareSDK,可以对接QQ、QQ空间、微信、朋友圈、微博等。 1、ShareSDK 首先去MobTech平…...

    2024/4/16 22:13:52
  2. 区块链作为本科毕业论文的研究方向之分布式一致性

    下学期大四,我的导师叫我做区块链方向的。我想问问大家这个区块链方向的毕业论文可以写些什么?做逆向软件保护方向的导师又说不合适,希望大佬们给点建议分布式一致性在一个分布式系统中,如何保证集群中所有节点中的数据完全相同并且能够对某个提案(Proposal)达成一致是分布…...

    2024/4/24 6:35:32
  3. SaaS-Export 第一天

    SaaS-Export 第一天学习目标理解Saas模式以及SaaS-Export项目的需求能够使用PD工具完成项目用例图绘制完成项目搭建完成企业列表展示 1. 初识云服务(一)什么是云服务?目标了解云服务的概念云服务的公司分类云服务的概念 “云”其实是互联网的一个隐喻,“云计算” 是基于互…...

    2024/4/24 6:35:32
  4. 什么是私有云、公有云、混合云?什么是云计算管理平台?

    IT新技术总是不停的更新换代,IT术语也在不断的推陈出新,在谈及什么是云计算管理平台(Cloud Management Platform)的前提下,我们应该简单回顾一下云计算的前世今生,以方便读者更好的理解。 一、 什么是云计算 一个比较形象的例子是小区的停车位。如果一个小区只有10个车位…...

    2024/4/24 6:35:30
  5. FFmpeg API 之 AVOption

    options,可以翻译为“选项”,是 FFmpeg 中非常重要的一个概念。在 FFmpeg 中,我们可以对input , output, muxer, demuxer, encoder, decoder, device,protocols 等设置选项,以便于对它们的行为做控制。因此,options可以理解为是物体的属性或者特征。首先,我们要区…...

    2024/4/24 6:35:29
  6. 阿里巴巴的零知识证明

    战争中你被俘了,敌人拷问你情报。你是这么想的:如果我把情报都告诉他们,他们就会认为我没有价值了,就会杀了我省粮食,但如果我死活不说,他们也会认为我没有价值而杀了我。怎样才能做到既让他们确信我知道情报,但又一丁点情报也不泄露呢?这的确是一个令人纠结的问题,但…...

    2024/4/27 12:45:12
  7. 腾讯翻译君 VS 谷歌翻译

    腾讯翻译君 VS 谷歌翻译0.小贴士:文章比较长,请耐心观看。1.先贴网址腾讯翻译君谷歌翻译2.找一段高难度的英文测试文本孔子的英文百科:Confucius (September 28, 551 BC – 479 BC) was a Chinese teacher, editor, politician, and philosopher of the Spring and Autumn p…...

    2024/5/1 17:11:34
  8. 《Credit Risk Scorecard》第四章:Data Review and Project Parameters

    第四章:Scorecard Development Process, Stage 2: Data Review and Project Parameters一: data avaliablity and quality 数据获取,数量和质量,可靠和干净的数据是需要的。 数据数量需要满足多样性,统计显著和随机。 具体数量大小,目前不是关键,依赖坏样本定义。 对于申…...

    2024/4/24 6:35:29
  9. php工厂模式使用场景

    场景:使用工厂模式接入:阿里短信验证、腾讯短信验证、百度短信验证 创建类文件BaseSMS.php – 基础短信服务接口类 AliSMS.php – 阿里短信服务类 BaiduSMS.php – 百度短信服务类 TencentSMS.php – 腾讯短信服务类 SmsBusiness.php – 短信业务逻辑类具体代码 BaseSMS.php …...

    2024/4/26 9:26:33
  10. SpringBoot系列之(三):启动过程

    前言不得不说我们的SpringBoot给Java开发人员带来了很多的便利之处。比如:不用再配置一些的xml文件了;加载程序的容器也帮我们嵌套在代码里了;Web的中心控制器入口也自动写在了代码里;真正的做到了随处可见的自启动及兼容性。既然说是随处可见的自启动那是怎么自启动的呢?…...

    2024/4/24 6:35:32
  11. Java-数据加解密实现

    注意:强烈建议阅读本文之前,先行阅读下面这篇文章,建立对密码学技术体系的整体认知: https://blog.csdn.net/weixin_39190897/article/details/82223408先来一个故事(可粗略理解 数字签名、散列函数、证书机构、非对称加密、公私密钥 等密码学技术的应用)~ 假如A授权B的一…...

    2024/4/24 6:35:26
  12. 各种传送门

    迷路的看过来! 学术工具专区 打字练习 打字技巧视频 程序猿专用打字练习 AC A+B问题的14种方法 LaTeX数学公式大全 LaTeX字体集合 学历史必备-全历史 骗分导论 复赛记住这30句话 整数百科全书 算法模板 提问的智慧-洛谷移植版 怀念一代经典-洛谷试炼场 各种编程语言教程-菜鸟教…...

    2024/4/24 6:35:22
  13. 根据百度地图开发者文档尝试定位

    百度定位包的使用模块 百度定位包的使用模块 1.预备:访问http://lbsyun.baidu.com,依次选择:开发文档->Android 地图SDK->产品下载->自定义下载,勾选百度定位包后下载、解压 2.在项目里,新建名为example10_2的模块 3.选择模块视图为Project,复制定位包BaiduLBS_…...

    2024/5/2 3:59:26
  14. [SUCTF 2019]EasySQL

    打开题目发现 发现存在堆叠注入 然后尝试读取表Flag, 发现union,prepare,handler等都过滤了,基本我会的方法都过滤了。。。 然后有两种解 解题思路1: payload:*,1 查询语句:select *,1||flag from Flag 解题思路2: payload:1;set sql_mode=PIPES_AS_CONCAT;select 1 解…...

    2024/4/24 6:35:23
  15. tensorflow中np.vstack()用法

    tensorflow中np.vstack()用法import numpy as npnp.vstack(array1, array2) #将数组1:array1和数组2:array2垂直方向相加np.vstack()用法import numpy as np #导入numpy模块 a = np.array([1, 2, 3]) #新建数组ab = np.array([4, 5, 6]) #新建数组bc = np.vstack((a, b)) #使…...

    2024/4/24 6:35:22
  16. 启发式搜索解决八皇后问题

    1.问题描述在一个3*3的方棋盘上放置着1,2,3,4,5,6,7,8八个数码,每个数码占一格,且有一个空格。这些数码可以在棋盘上移动,其移动规则是:与空格相邻的数码方格可以移入空格。现在的问题是:对于指定的初始棋局和目标棋局,给出数码的移动序列。该问题称八数码难题或者重排九宫…...

    2024/5/3 6:45:11
  17. Ajax完整实例代码(模糊查询员工信息)

    1.Cs页面代码:显示信息 namespace ajax_demo {public partial class WebForm1 : System.Web.UI.Page{protected void Page_Load(object sender, EventArgs e){...

    2024/4/24 6:35:25
  18. python unittest使用HTMLTestRunnerNew报错:ValueError: write to closed file解决方式

    使用unittest+HTMLTestRunnerNew的时候出现以下报错:self.stream.write(output.encode(‘utf8’)) ValueError: write to closed file 解决方式一: 将runner.run(Test_suit)缩进到with open下运行。解决方式二: 如果还是想要将runner顶格,那就不使用with open方法,写一个正…...

    2024/4/16 22:15:04
  19. 联想小新700增加内存条

    17年买的小新700竞技版,8G内存条不够用了。最近想搭建k8s的集群,不想玩minikube了,本来打算入手一个二手的联想p50移动工作站,但是后来想了想,买了工作站也得用虚拟机,不如升级一下电脑内存先试试。选择内存条小新700配置如下:注意,这张图内存是DDR4 2133的,切记,内存…...

    2024/4/19 19:35:14
  20. cv2.xfeature2d.sift报错最新亲测可行解决方案

    OpenCV xfeature2d SIFT 解决方法 引用官方代码 gray= cv2.cvtColor(img,cv2.COLOR_BGR2GRAY) sift = cv2.xfeatures2d.SIFT_create()的时候,会弹出cv2 中没有xfeature2d这个 attributues。 但是这是官方代码。。好 我们面向谷歌编程, 发现需要安装依赖 pip3 install opencv…...

    2024/4/16 22:14:58

最新文章

  1. 申请Sectigo证书流程详解

    Sectigo&#xff08;前身为Comodo CA&#xff09;&#xff0c;是目前主流SSL证书的一种&#xff0c;目前全球范围内应用度也非常广泛&#xff0c;是目前众多品牌中市场份额最大的一个品牌了&#xff0c;在全球证书市场份额占比约为40%。 其超高的市场份额占比主要还是基于其超…...

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

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

    2024/5/6 9:38:23
  3. 【VTKExamples::Meshes】第七期 TableBasedClipDataSetWithPolyData

    很高兴在雪易的CSDN遇见你 VTK技术爱好者 QQ:870202403 公众号:VTK忠粉 前言 本文分享VTK样例TableBasedClipDataSetWithPolyData,并解析接口vtkTableBasedClipDataSet,希望对各位小伙伴有所帮助! 感谢各位小伙伴的点赞+关注,小易会继续努力分享,一起进步! 你…...

    2024/5/5 8:45:33
  4. OpenHarmony实战:Combo解决方案之ASR芯片移植案例

    本方案基于 OpenHarmony LiteOS-M 内核&#xff0c;使用 ASR582X 芯片的 DEV.WIFI.A 开发板进行开发移植。作为典型的 IOT Combo&#xff08;Wi-FiBLE&#xff09;解决方案&#xff0c;本文章介绍 ASR582X 的适配过程。 编译移植 目录规划 本方案的目录结构使用 Board 和 So…...

    2024/5/6 16:35:39
  5. 【外汇早评】美通胀数据走低,美元调整

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

    2024/5/4 23:54:56
  6. 【原油贵金属周评】原油多头拥挤,价格调整

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

    2024/5/4 23:54:56
  7. 【外汇周评】靓丽非农不及疲软通胀影响

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

    2024/5/4 23:54:56
  8. 【原油贵金属早评】库存继续增加,油价收跌

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

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

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

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

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

    2024/5/4 23:55:05
  11. 【外汇早评】美欲与伊朗重谈协议

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

    2024/5/4 23:54:56
  12. 【原油贵金属早评】波动率飙升,市场情绪动荡

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

    2024/5/4 23:55:16
  13. 【原油贵金属周评】伊朗局势升温,黄金多头跃跃欲试

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

    2024/5/4 23:54:56
  14. 【原油贵金属早评】市场情绪继续恶化,黄金上破

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

    2024/5/6 1:40:42
  15. 【外汇早评】美伊僵持,风险情绪继续升温

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

    2024/5/4 23:54:56
  16. 【原油贵金属早评】贸易冲突导致需求低迷,油价弱势

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

    2024/5/4 23:55:17
  17. 氧生福地 玩美北湖(上)——为时光守候两千年

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

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

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

    2024/5/4 23:54:56
  19. 氧生福地 玩美北湖(下)——奔跑吧骚年!

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

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

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

    2024/5/5 8:13:33
  21. 「发现」铁皮石斛仙草之神奇功效用于医用面膜

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

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

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

    2024/5/4 23:54:58
  23. 广州械字号面膜生产厂家OEM/ODM4项须知!

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

    2024/5/6 21:42:42
  24. 械字号医用眼膜缓解用眼过度到底有无作用?

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

    2024/5/4 23:54:56
  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