助力工业物联网,工业大数据项目介绍及环境构建【一】

news2025/1/10 3:30:29

文章目录

  • 工业大数据项目介绍及环境构建
    • 01:专栏目标
    • 02:项目背景
    • 03:项目需求
    • 04:业务流程
    • 05:技术选型
    • 06:Docker的介绍
    • 07:Docker的网络
    • 08:Docker的使用
    • 09:Oracle的介绍
    • 10:集群软件规划
    • 11:项目环境导入
    • 12:项目环境配置
    • 13:项目环境测试:Oracle
    • 14:项目环境测试:MySQL
    • 15:项目环境测试:Hadoop
    • 16:项目环境测试:Hive
    • 17:项目环境测试:Spark
    • 18:项目环境测试:Sqoop
    • 要求

工业大数据项目介绍及环境构建

01:专栏目标

  1. 项目目标
    • 项目1:在线教育
      • 学习如何做项目,项目中大数据工程师要负责实现的内容和流程
      • 学习数仓基础理论:建模、分层
    • 项目2:工业大数据
      • 企业中项目开发的落地:代码开发
        • 代码开发:SQL【DSL + SQL】
          • SparkCore
          • SparkSQL
      • 数仓的一些实际应用:分层体系、建模实现
  2. 内容目标
    • 项目业务介绍:背景、需求
    • 项目技术架构:选型、架构
    • 项目环境测试

02:项目背景

  • 目标:了解项目应用背景

  • 实施

    • 工业

      • 产业分类
        • 第一产业:植业、林业、畜牧业、水产养殖业等直接以自然物为生产对象的产业
        • 第二产业:工业、建筑业
        • 第三产业:交通运输业、通讯产业、商业、餐饮业、金融业、教育产业
      • 定义:属于第二产业,指的是采集原料,并把它们加工成产品的工作和过程
      • 划分
        • 开采业:对自然资源的开采,对采矿、晒盐、森林采伐等
        • 加工业:粮油加工、食品加工、 轧花、缫丝、纺织、制革等
        • 制造业:炼铁、炼钢、化工生产、 石油加工、机器制造、木材加工等,以及电力、自来水、煤气的生产和供应等
        • 机修业:对工业品的修理、翻新,如机器设备的修理、 交通运输工具的修理等
    • 物理网:IOT(Internet Of Things)

      • 定义:指的是互联网、传统电信网等信息承载体,让所有能行使独立功能的普通物体实现互联互通的网络
      • 特点
        • 物物相连
        • 远程监控和设备控制
        • 设备自动化,提升用户体验
        • 设备故障分析处理
      • 场景
        • 智能设备:手机、平板、手表、眼镜、汽车
        • 智能家居:门、空调、洗衣机、水壶、窗帘、灯具、马桶、牙刷
        • 智能机器人:语音助手、家庭管家、工业机器手臂、快递机器人
        • ……
    • 工业物联网:IIOT(Industrial Internet of Things)

      • 定义:指数以亿计的工业设备,在这些设备上装置传感器,连接到网络以收集和共享数据

      • 发展

        • IDC预测,到2024年全球物联网的联接量将接近650亿,是手机联接量的11.4倍

        image-20210819140743649

  • 小结

  • 了解项目应用背景

03:项目需求

  • 目标掌握项目业务需求

    • 这个项目属于哪个行业?
    • 为什么要做这个项目?
    • 这个项目的目的是什么?
  • 实施

    • 项目行业:工业大数据

    • 项目名称:加油站服务商数据运营管理平台

      • 中石化,中石油,中海油、壳牌,道达尔……
    • 整体需求

      基于加油站的设备安装、维修、巡检、改造等数据进行统计分析
      支撑加油站站点的设备维护需求以及售后服务的呼叫中心数据分析
      提高服务商服务加油站的服务质量
      保障零部件的仓储物流及供应链的需求
      实现服务商的所有成本运营核算
      
    • 具体需求

      • 运营分析:呼叫中心服务单数、设备工单数、参与服务工程师个数、零部件消耗与供应指标等
      • 设备分析:设备油量监控、设备运行状态监控、安装个数、巡检次数、维修次数、改造次数
      • 呼叫中心:呼叫次数、工单总数、派单总数、完工总数、核单次数
      • 员工分析:人员个数、接单次数、评价次数、出差次数
      • 报销统计分析、仓库物料管理分析、用户分析
    • 报表

      image-20210819151917199

  • 小结

  • 这个项目属于哪个行业?

    • 工业化大数据平台
    • 行业:加油站服务商运营数据分析平台
    • 为什么要做这个项目?
      • 基于所有设备的安装、维修、巡检、改造的工单数据,辅助公司的运营,提高服务质量,做合理的成本预算
    • 这个项目具体需求是什么?
      • 提高服务质量,做合理的成本预算
      • 需求一:对所有工单进行统计分析
        • 安装工单、维修工单、巡检工单、改造工单、回访分析
      • 需求二:付费分析、报销分析
        • 安装人工费用、安装维修材料费用、差旅交通费用

04:业务流程

  • 目标掌握加油站设备维护的主要业务流程

  • 实施

    image-20210819151836340

    • step1:加油站服务商联系呼叫中心,申请服务:安装/巡检/维修/改造加油机
    • step2:呼叫中心联系对应服务站点,分派工单:联系站点主管,站点主管分配服务人员
    • step3:服务人员确认工单和加油站点信息
    • step4:服务人员在指定日期到达加油站,进行设备检修
    • step5:如果为安装或者巡检服务,安装或者巡检成功,则服务完成
    • step6:如果为维修或者改造服务,需要向服务站点申请物料,物料到达,实施结束,则服务完成
    • step7:服务完成,与加油站站点服务商确认服务结束,完成订单核验
    • step8:工程师报销过程中产生的费用
    • step9:呼叫中心会定期对该工单中的工程师的服务做回访
  • 小结

    • 掌握加油站设备维护的主要业务流程
    • 工单分析、费用分析、物料分析、回访分析

05:技术选型

  • 目标掌握加油站服务商数据运营平台的技术选型

  • 实施

    • 数据生成:业务数据库系统

      • Oracle:工单数据、物料数据、服务商数据、报销数据等
    • 数据采集

      • Sqoop:离线数据库采集
    • 数据存储

      • Hive【HDFS】:离线数据仓库【表】
    • 数据计算

      • SparkCore:类MR开发方式【写代码调用方法函数来处理:面向对象 + 面向函数】
        • 对非结构化数据进行代码处理
        • 场景:ETL
      • SparkSQL:类HiveSQL开发方式【面向表】
        • 对数据仓库中的结构化数据做处理分析
        • 场景:统计分析
        • 开发方式
          • DSL:使用函数【DSL函数 + RDD函数】
          • SQL:使用SQL语句对表的进行处理
        • 功能:离线计算 + 实时计算
      • 注意:SparkSQL可以解决所有场景的分布式计算,离线计算的选型不仅仅是SparkSQL
        • SparkSQL/Impala/Presto
      • 使用方式
        • Python/Jar:spark-submit
          • ETL
        • ThriftServer:SparkSQL用于接收SQL请求的服务端,类似于Hive的Hiveserver2
          • PyHive :Python连接SparkSQL的服务端,提交SQL语句
          • JDBC:Java连接SparkSQL的服务端,提交SQL语句
          • spark-sql -f :运行SQL文件,类似于hive -f
          • beeline:交互式命令行,一般用于测试
    • 数据应用

      • MySQL:结果存储
      • Grafana:数据可视化工具
    • 监控工具

      • Prometheus:服务器性能指标监控工具
    • 调度工具

      • AirFlow:任务流调度工具
    • 技术架构

      image-20210819163301868

  • 小结

    • 本次项目的技术架构是什么?

      • Lambda架构:离线计算层 + 实时计算层 + 数据服务层
    • 项目中用到了哪些技术?

      • 数据生成:Oracle

      • 数据采集:Sqoop

      • 数据存储:Hive

      • 数据处理:SparkSQL

      • 数据应用:MySQL + Grafana

      • 数据监控:Prometheus

      • 任务调度:AirFlow

      • 版本控制:Git + Gitee

      • 资源容器:Docker

06:Docker的介绍

  • 目标了解Docker的基本功能和设计

    • 为什么要用Docker?
    • 什么是Docker?
  • 路径

    • step1:生产环境的问题
    • step2:容器的概念
    • step3:Docker的设计
  • 实施

    • 生产环境的问题

      • 运维层面:一台机器上的应用太多,不同的环境,安装过程也不一样,管理麻烦,怎么办?
      • 开发层面:不同程序的运行受到环境、资源等因素的干扰,不同的环境,开发的方式也不一样,怎么办?
    • 容器的概念

      • 硬件容器:将一个硬件虚拟为多个硬件,上层共用硬件
        • VMware WorkStation
    • 应用容器:将一个操作系统虚拟为多个操作系统,不同操作系统之间互相隔离

  • Docker

  • Docker的设计

    image-20210820114930076

    • 定义:Docker是一个开源的应用容器引擎,使用GO语言开发,基于Linux内核的cgroup,namespace,Union FS等技术,对应用程序进行封装隔离,并且独立于宿主机与其他进程,这种运行时封装的状态称为容器。

      • 目标

        • 提供简单的应用程序打包工具
      • 开发人员和运维人员职责逻辑分离

    • 多环境保持一致性,消除了环境差异

    • 功能:“Build,Ship and Run Any App,Anywhere”

      • 通过对应用组件的封装,分发,部署,运行等生命周期的管理,达到应用组件级别的一次封装,多次分发,到处部署
    • 架构

      image-20210820121717954

    • 组成

      • 宿主机:安装Docker的那台实际的物理机器

      • docker client 【客户端】:用于连接服务端,提交命令给服务端

        #拉取镜像
        docker pull ……
        #启动容器
        docker run ……
        #进入容器
        docker exec ……
        #查看容器
        docker ps ……
        
        
        
      • docker daemon【服务端】:用于接收客户端请求,实现所有容器管理操作

      • docker image【镜像】:用于安装APP的软件库,简单点理解为软件的安装包

      • docker container 【容器】:用于独立运行、隔离每个APP的单元,相当于每个独立的Linux系统

        
        
  • 小结

    • 了解Docker的基本功能和设计

07:Docker的网络

  • 目标了解Docker的网络管理设计

    • Docker的
  • 路径

    • step1:问题
    • step2:模式
    • step3:选型
  • 实施

    • 问题

      • Docker的本质在一个操作上虚拟了多个操作系统出来,那每个操作之间如何进行网络通信呢?
    • 模式

      • host模式:每个虚拟系统与主机共享网络,IP一致,用不同端口区分不同虚拟系统

        image-20210820125842299
      • container模式:第一个容器构建一个独立的虚拟网络,其他的容器与第一个容器共享网络

image-20210820125921926
- **none模式**:允许自定义每个容器的网络配置及网卡信息,每个容器独立一个网络
image-20210820130000207
- **bridge模式**:构建虚拟网络桥,所有容器都可以基于网络桥来构建自己的网络配置
image-20210820130011944
  • 选型

    • 本次项目中使用bridge模式,类似于VM中的Net模式使用
  • 管理

    • 了解即可,不用操作

    • 创建

      docker network create --subnet=172.33.0.0/24 docker-bd0
      
    • 查看模式

      docker network ls
      
    • 删除

      docker network rm ……
      
  • 小结

    • 了解Docker的网络管理设计

08:Docker的使用

  • 目标:了解docker的基本使用

  • 路径

    • step1:docker管理
    • step2:image管理
    • step3:container管理
  • 实施

    • docker管理

      • 默认开机自启

      • 了解即可,不用操作

      • 启动服务

        systemctl start docker
        
      • 查看状态

        systemctl status docker
        
      • 关闭服务

        systemctl stop docker
        
    • image管理

      • 了解即可,不用操作

      • 添加镜像

        docker pull registry.cn-hangzhou.aliyuncs.com/helowin/oracle_11g
        
      • 列举镜像

        docker images
        
      • 移除镜像

        docker rmi ……
        
    • container管理

      • 熟悉常用操作

      • 创建并启动container:不用做

        docker run --net docker-bd0 --ip 172.33.0.100 -d -p 1521:1521 --name oracle 3fa112fd3642
        
        • run = create + start
      • 列举container

        #列举所有的
        docker ps -a
        #列举正在运行的
        docker ps
        
      • 进入container

        docker exec -it Name bash
        
      • 退出container

        exit
        
      • 删除container

        docker rm ……
        
  • 小结

    • 了解docker的基本使用

09:Oracle的介绍

  • 目标了解Oracle工具的基本功能和应用场景

  • 路径

    • step1:数据库分类
    • step2:Oracle的介绍
  • 实施

    • 数据库分类

      • RDBMS:关系型数据库管理系统
        • 工具:MySQL、Oracle、SQL Server……
        • 应用:业务性数据存储系统:事务和稳定性
        • 特点:体现数据之间的关系,支持事务,保证业务完整性和稳定性,小数据量的性能也比较好
        • 开发:SQL
      • NoSQL:Not Only SQL:非关系型数据库
        • 工具:Redis、HBASE、MongoDB……
        • 分类:KV、文档、时序、图……
        • 应用:一般用于高并发高性能场景下的数据缓存或者数据库存储
        • 特点:读写速度特别快,并发量非常高,相对而言不如RDBMS稳定,对事务性的支持不太友好
        • 开发:每种NoSQL都有自己的命令语法
    • Oracle的介绍

      • 概念:甲骨文公司的一款关系数据库管理系统

        • Oracle在古希腊神话中被称为“神谕”,指的是上帝的宠儿
        • 在中国的商周时期,把一些刻在龟壳上的文字也称为上天的指示,所以在中国Oracle又翻译为甲骨文
        • Oracle是现在全世界最大的数据库提供商,编程语言提供商,应用软件提供商,它的地位等价于微软的地位
      • 分类:RDBMS,属于大型RDBMS数据库

        • 大型数据库:IBM DB2、Oracle、Sybase
        • 中型数据库:SQL Server、MySQL、Informix、PostgreSQL
        • 小型数据库:Access、Visual FoxPro、SQLite
      • 功能:实现大规模关系型数据存储

      • 特点

        • 功能全面:数据字典、动态性能视图、TRACE跟踪、AWR、ASH、SQL Monitor等
        • 性能优越:支持SQL大量的表连接、子查询、集合运算,长度可达上千行
        • 数据量大:相比较于其他的数据库,Oracle支持千万级别以上的数据高性能存储
        • 高可靠性:基于Oracle自带的RAC架构下,可靠性和稳定性相对比较高
      • 综合排名

        image-20210820144336062

      • 应用

        • 中国各大银行、电信、政府单位等机构所有系统
      • 趋势

        • 去IOE【IBM服务器、Oracle数据库、EMC存储】
  • 小结

    • 了解Oracle工具的基本功能和应用场景

10:集群软件规划

  • 目标:了解项目的集群软件规划

  • 实施

    image-20210819235429756

    172.33.0.100    oracle.bigdata.cn
    172.33.0.110    sqoop.bigdata.cn
    172.33.0.121    hadoop.bigdata.cn
    172.33.0.131    hive.bigdata.cn
    172.33.0.133    spark.bigdata.cn
    
  • 小结

    • 了解项目的集群软件规划

11:项目环境导入

  • 目标:实现项目虚拟机的导入

  • 实施

    • step1:导入:找到OneMake虚拟机中以.vmx结尾的文件,使用VMware打开

      image-20210820153724328 image-20210820153811764
    • step2:启动:启动导入的虚拟机,选择我已移动该虚拟机

      image-20210820153928034

  • step3:登陆:登陆到虚拟机内部,或者使用远程工具连接

    • 默认IP:192.168.88.100
    • 主机名:node1
    • 用户名:root
    • 密码:123456

    image-20210820154156327

    image-20210820154301298

  • 小结

    • 实现项目虚拟机的导入

12:项目环境配置

  • 目标根据需求实现项目环境配置

  • 实施

    • 注意:所有软件Docker、Hadoop、Hive、Spark、Sqoop都已经装好,不需要额外安装配置,启动即可

    • 配置网络:如果你的VM Nat网络不是88网段,请按照以下修改

      • 修改Linux虚拟机的ens33网卡,网卡和网关,修改为自己的网段

        vim /etc/sysconfig/network-scripts/ifcfg-ens33
        

        image-20210820155039740

      • 重启网卡

        systemctl restart network
        
      • 查看是否修改成功

        ifconfig
        
    • 配置映射

      • 修改Linux映射,修改为自己的网段

        vim /etc/hosts
        
      • 配置Windows上的映射,方便使用主机名访问【把以前的有冲突的注释掉】

      192.168.88.100 oracle.bigdata.cn
      192.168.88.100 hadoop.bigdata.cn
      192.168.88.100 hive.bigdata.cn
      192.168.88.100 mysql.bigdata.cn
      192.168.88.100 node1

      
      ![image-20210820155305287](https://img-blog.csdnimg.cn/img_convert/5d91eae2217116ace3aaceb9a5f03e92.png)
      
      
  • 小结

    • 根据需求实现项目环境配置

13:项目环境测试:Oracle

  • 目标实现项目Oracle环境的测试

  • 实施

    • 启动

      docker start oracle
      
    • 进入

      docker exec -it oracle bash
      
    • 连接

      #进入客户端命令行:/nolog表示只打开,不登录,不用输入用户名和密码
      sqlplus /nolog
      #登陆连接服务端:/ as sysdba表示使用系统用户登录
      conn / as sysdba
      
    • 测试

    select TABLE_NAME from all_tables where TABLE_NAME LIKE ‘CISS_%’;

    
    - 退出
    
    

    exit

    
    - 远程连接:DG
    
    - step1:安装DG
    
    - step2:创建连接
    
      - SID:helowin
    - 用户名:ciss
      - 密码:123456
    
    ![image-20210820163624308](https://img-blog.csdnimg.cn/img_convert/b53444744b1b7e1a42cfc342618725ed.png)
    
    
    

image-20210820163359518

  • step3:配置驱动包

    image-20210820163845730

  • step4:配置JDK

    image-20210820163858178

  • step5:测试

    image-20210820163938882

  • 关闭

      docker stop oracle
    
  • 小结

    • 实现项目Oracle环境的测试

14:项目环境测试:MySQL

  • 目标实现项目MySQL环境的测试

  • 实施

    • 大数据平台中自己管理的MySQL:两台机器

      • 存储软件元数据:Hive、Sqoop、Airflow、Oozie、Hue
      • 存储统计分析结果
    • 注意:MySQL没有使用Docker容器部署,直接部署在当前node1宿主机器上

    • 启动/关闭:默认开启自启动

    • 连接:使用命令行客户端、Navicat、DG都可以

      • 用户名:root
      • 密码:123456

      image-20210820165818751

      image-20210820165832168

    • 查看

      image-20210820165910239

  • 小结

    • 实现项目MySQL环境的测试

15:项目环境测试:Hadoop

  • 目标实现项目Hadoop环境的测试

  • 实施

    • 启动

      docker start hadoop
      
    • 进入

      docker exec -it hadoop bash
      
    • 查看进程

      jps
      
    • 启动进程

      start-dfs.sh
      start-yarn.sh
      mr-jobhistory-daemon.sh start historyserver
      
    • 访问页面

      • node1:50070

        image-20211006145842446

      • node1:8088

        image-20211006145858903

      • node1:19888

        image-20211006145908808

    • 退出

      exit
      
    • 关闭

      docker stop hadoop
      
  • 小结

    • 实现项目Hadoop环境的测试

16:项目环境测试:Hive

  • 目标:实现项目Hive环境的测试

  • 实施

    • 启动Hive容器

      docker start hive
      
    • 进入Hive容器

      docker exec -it hive bash
      source /etc/profile
      
    • 连接

      beeline
      !connect jdbc:hive2://hive.bigdata.cn:10000
      账号为root,密码为123456
      
    • SQL测试

      select count(1);
      
      • Shuffle【分区、排序、分组】三种场景
      • 重分区:repartition:分区个数由小变大
        • 调用分区器对所有数据进行重新分区
        • rdd1
          • part0:1 2 3
          • part1: 4 5 6
        • rdd2:调用分区器【只有shuffle阶段才能调用分区器】
          • part0:0 6
          • part1:1 4
          • part2:2 5
        • 全局排序:sortBy
          • part0:1 2 5
          • part1: 4 3 6
          • 方案:将所有数据放入磁盘
          • 实现:对数据做了范围分区:将所有数据做了采样:4
            • part0:6 5 4
            • part1:3 2 1
        • 全局分组:groupBy,reduceByKey
    • 关闭Hive容器

      docker stop hive
      
  • 小结

    • 实现项目Hive环境的测试

17:项目环境测试:Spark

  • 目标实现项目Spark环境的测试

  • 实施

    • 启动Spark容器

      docker start spark
      
    • 进入Spark容器

      docker exec -it spark bash
      source /etc/profile
      
    • 启动Thrift Server【默认已经启动】

      start-thriftserver.sh \
      --name sparksql-thrift-server \
      --master yarn \
      --deploy-mode client \
      --driver-memory 1g \
      --hiveconf hive.server2.thrift.http.port=10001 \
      --num-executors 3 \
      --executor-memory 1g \
      --conf spark.sql.shuffle.partitions=2
      

      image-20211006152344248

    • 测试

      beeline -u jdbc:hive2://spark.bigdata.cn:10001 -n root -p 123456
      select count(1);
      
    • 关闭Spark容器

      docker stop spark
      
  • 小结

    • 实现项目Spark环境的测试

18:项目环境测试:Sqoop

  • 目标实现项目Sqoop环境的测试

  • 实施

    • 启动Sqoop容器

      docker start sqoop
      
    • 进入Sqoop容器

      docker exec -it sqoop bash
      source /etc/profile
      
    • 测试

      sqoop list-databases \
      --connect jdbc:oracle:thin:@oracle.bigdata.cn:1521:helowin \
      --username ciss \
      --password 123456
      
    • 关闭Sqoop容器

      docker stop sqoop
      
  • 小结

    • 实现项目Sqoop环境的测试

要求

  1. Python面向对象

    • 类和对象
    • 方法
  2. Hive中建表语法

    create [external] table tbname(
    	字段 类型 comment,
    ) 
    comment
    partitioned by 
    clustered by col into N buckets
    row format 
    stored as textfile
    location
    
  3. 提前预习:EntranceApp.py

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.coloradmin.cn/o/43007.html

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈,一经查实,立即删除!

相关文章

关于SQL的返回行数top

第一节.知识点三:关键字wlth tles 我要讲的是关于SQL的3个限制返回行数top: 1.使用具有恒定值的top; 2.关键字percent(%)返回行的百分比; 3.理解关键字wlth tles 上一次已经讲了前两个了,现在我要讲的是第三个 3.理解关键字wlth t…

【计算机毕业设计】69.助残志愿者系统源码

一、系统截图(需要演示视频可以私聊) 摘 要 本课题要求实现一套助残助残志愿者系统设计与开发,系统主要包括系统用户信息、志愿者信息、服务项目、志愿项目,志愿者培训、志愿项目、公益活动等功能模块。 基于上述分析&#xff0…

助力教育信创快速发展,统信软件与山东四所高校建立信创应用重点实验室

国家在“十三五”、“十四五”规划中重点强调了信息安全在国家战略中的重要地位,而大力发展教育信创有助于我国信息安全的快速落地。同时,教育部等六部门印发《关于推进教育新型基础设施建设构建高质量教育支撑体系的指导意见》也提到:推广可…

E+H浊度仪维修CUE22-A1A浊度分析仪维修概述

CUE21/22浊度仪参数如下: 测量参数:浊度 测量原理:散射光原理 应用场合:饮用水;生产用水 处理后的过程水 测量范围:0…100NTU;0…1000NTU 信号输出:4 ... 20 mA 通讯协议&…

多线程同步,信号,生产者消费者模型

目录1.线程互斥它是对的吗?合理吗?(任何场景)2.怎么解决饥饿问题?3.条件编译1.生产者和消费者模型2.编写代码实现一个基于堵塞队列的生产者消费者模型4.POSIX信号量5.环形队列1.线程互斥它是对的吗?合理吗?(任何场景) …

【JavaSE】多态

目录 1、多态 1.1、多态的概念 1.2、多态的实现条件 1.3、向上转型和向下转型 1.3.1、向上转型 1.3.2、向下转型 1.3.3、instanceof关键字 2、重写 2.1、重写的使用 2.2、动态绑定和静态绑定 2.2.1、动态绑定 2.2.2、静态绑定 2.3、再谈重写 3、多态的优缺点 4、…

LabVIEW浮点型和双精度数据类型之间的精度差异是什么 为什么 在LabVIEW 中, 浮点 数 会 失去 精度?

LabVIEW浮点型和双精度数据类型之间的精度差异是什么 为什么 在LabVIEW 中, 浮点 数 会 失去 精度? 程序中使用浮点数据类型或双精度数据类型。这些数据类型之间有什么区别? 浮点型的变量只有 7 位精度,而双精度类型的变量有 15…

算法竞赛入门【码蹄集进阶塔335题】(MT2296-2300)

算法竞赛入门【码蹄集进阶塔335题】(MT2296-2300) 文章目录算法竞赛入门【码蹄集进阶塔335题】(MT2296-2300)前言为什么突然想学算法了?为什么选择码蹄集作为刷题软件?目录1. MT2296 找朋友2. MT2297 盒子与球3. MT2298 点餐4. MT…

第二章Java概述

第二章Java概述 2.1 Java技术体系平台 Java SE:标准版 Java EE:企业版 Java ME:小型版 2.2Java重要特点(四个) 1)java语言是面向对象的(oop) 2)java语言是健壮的。java的强类型机制、异常处理、垃圾的自动…

Kamiya丨Kamiya艾美捷人CP ELISA说明书

Kamiya艾美捷人CP ELISA预期用途: 人CP ELISA是一种高灵敏度的双位点酶联免疫分析(ELISA)人体生物样品中CP的测定。仅供研究使用。不用于诊断程序。 引言 铜蓝蛋白是参与铜转运的多功能蛋白,也是重要的血清抗氧化剂。在此期间炎…

【Canvas】js用Canvas绘制漩涡螺旋图动画效果

学习JavaScript编程,会用Canvas画图吗,学会它,能画很多有趣的事物,可自由发挥想象,会发现图形学的美,收获很多,这里有一个例子,如何用canvas画漩涡螺旋图动图效果,接下来…

c语言tips-结构体

1. 结构体定义和使用 #include <stdio.h>struct stu {int age;int height;int weight; };int main(int argc, char *argv[]) {struct stu stu1;stu1.age 18;stu1.height 172;stu1.weight 62;printf("年龄为&#xff1a;%d, 身高为&#xff1a;%d, 体重为&#x…

Self-attention自注意力机制——李宏毅机器学习笔记

self-attention想要解决的问题 复杂的输入 每次输入的length不同时&#xff0c;即Vector Set大小不同&#xff0c;该如何处理&#xff1f; one-hot encoding&#xff0c;缺点&#xff1a;所有的词汇之间没有语义资讯。 word embedding&#xff0c;会给每一个词汇一个向量&…

02-Docker-常用命令

目录 一、帮助启动类命令 启动docker 停止docker 重启docker 查看docker状态 开机启动 查看docker概要信息 查看docker总体帮助文档 查看docker命令帮助文档 二、镜像命令 1. 列出本地主机上的镜像 2. 查找镜像 3. 下载镜像 4. 查看镜像/容器/数据卷所占的空间 5.…

[附源码]SSM计算机毕业设计小说网站的设计与实现1JAVA

项目运行 环境配置&#xff1a; Jdk1.8 Tomcat7.0 Mysql HBuilderX&#xff08;Webstorm也行&#xff09; Eclispe&#xff08;IntelliJ IDEA,Eclispe,MyEclispe,Sts都支持&#xff09;。 项目技术&#xff1a; SSM mybatis Maven Vue 等等组成&#xff0c;B/S模式 M…

Java#数据结构----2

目录 一.数据结构(树) 二.二叉树(任意节点的度<2) 二叉查找树又称为二叉排序树/二叉搜索树 平衡二叉树 平衡二叉树的旋转机制 三.红黑树 一.数据结构(树) 基本概念: 度: 每一个节点的子节点数量 树高: 树的总层数 根节点: 最顶层的节点 左子节点: 左下方的节点 右子节…

【Java八股文总结】之面试题(二)

文章目录面试题一、几种锁的区别1、synchronized 和ReentrantLock的区别二、Java高级1、反射1、反射的应用场合2、Java反射API3、反射使用步骤&#xff08;获取Class 对象、调用对象方法&#xff09;4、获取Class对象的3种方法5、创建对象的两种方法 newInstance(&#xff09;2…

数据结构和算法——基于Java——3.1链表(单链表)

理论补充 概念:链表是以节点的方式存储&#xff0c;是链式存储 特性 每个节点包含一个data数据域&#xff08;存放数据&#xff09;&#xff0c;一个next域&#xff08;指向下一个节点&#xff09;链表分带头结点和不带头节点&#xff08;单链表带头&#xff09;链表的内存分…

移动端开发:WebView介绍和使用、JSBridge等

Android应用层的开发有几大模块&#xff0c;其中WebView是最重要的模块之一。Android系统的WebView发展历史可谓一波三折&#xff0c;系统WebView开发者肯定费劲心思才换取了今天的局面——应用里的WebView和Chrome表现一致。 webview是什么&#xff1f; WebView是一种控件&a…

计算机的存储器(详解)

文章目录一&#xff0c;存储器&#xff08;一&#xff09;存储器的分类1) 根据功能和特性分类2) 根据存储容量和所在位置分类二&#xff0c;寄存器&#xff08;一&#xff09;寄存器的类别三&#xff0c;高速缓冲存储器&#xff08;一&#xff09;高速缓存的类别1) 一级高速缓存…