zoukankan      html  css  js  c++  java
  • Storm入门,看这篇就够了

    Srorm 简介

    1.1 Storm是实时的数据流,Hadoop是批量离线数据

    起源背景

    • Twitter 开源的一个类似于Hadoop的实时数据处理框架
    • Storm是由Nathan Marz 在BackType公司【做社交数据分析,数据量大】工作中实现的,这家公司后来被Twitter收购。

    Ps:·Hadoop分布式存储和分布式计算两个难题全部解决了。但是缺点就是不能实时处理数据,Storm的作者就像写一个这样实时数据处理场景的框架出来

    1.2 Storm应用场景【实时处理数据】
    • 推荐系统:实时推荐,根据下单或加入购物车等操作
    • 网站统计:实时销量,流量统计
    • 监控预警系统,金融系统
    1.3Storm特性
    • 扩展性强,当计算能力不足时,可以进行横向扩展机器
    • 保证数据不丢失,且数据可以消费一次或多次
    • 容错性好,消息处理过程出现异常,会进行重试
    • 语言无关性:storm程序可以使用各种语言进行编写

    Storm原理

    2.1拓展:大数据框架都有哪些架构类型?

    主从架构:简单高效,单主节点存在单点问题
    HDFSYARNStormHbaseSparkFlink

    对称架构:复杂,效率较低,无单点问题,更加可靠
    ZookeeperKafka [会进行主节点的选举]

    Storm的主从架构

    • Nimbus 主节点
    • Sipervisor 从节点

    Nimbus—zookeeper–supervisor

    Storm组件:Nimbus

    • 接收客户端的topo代码,拆分成多个task,将task信息存入zk,并将task分配给Supervisor,将映射关系存入ZK,并进行故障检测

    • 类比:部门经理将需求拆分为 多个任务(每个任务有多个模块) 将这些任务写入项目文档中去,,并将每个任务与每一程序员进行对应

    Storm组件:Supervisor

    • 从Nimbus目录读取代码,从zk上读取Nimbus分配的task
    • 启动工作进程Worker
    • 监控每一个工作进程Worker

    Storm 组件:Worker

    • 从zk上读取分配的task,并计算出task需要给哪些task发信息
    • 启动一个或多个Execucor线程执行任务Task

    Storm组件:Zookeeper

    • Nimbus与Supervisor进行通信(分配任务与心跳)
    • Supervisor与Worker进行通信(分配任务和心跳)
    • Nimbus高可用(HA机制)

    动手实践

    • Zookeeper简介与集群配置【Storm的各个组件间是通过这个组件进行通信】
    • Zookeeper 的核心,单机和集群的配置方法
    • Storm的单机和集群环境的搭建

    Storm的安装配置

    单机环境的安装配置
    下载啊storm.apache.org 或CDH5 1.1.0 ,1.2.1等版本
    解压 tar –zxvf storm.tar.gz –C /opt/module

    Storm的启动是需要依赖于zookeeper服务的
    在这之前,先使用单个zk服务(单节点)

    Storm解压后的目录
    bin 包含

    • storm 核心脚本,可以通过这个脚本进行启动
    • Storm.py 是一个python脚本

    Conf 包含

    • Storm.yaml最核心的配置文件
    • storm.zookeeper.servers
    • nimbus.seeds
    • drpc.servers
      暂时不做任何修改

    启动主节点
    bin/storm nimbus &
    启动从节点
    bin/storm supervisor &
    启动UI
    bin/storm ui &
    启动日志
    bin/storm logviewer &

    ps:nohup java –jar hh.jar &
    nohup + & 客户端和虚拟机是不需要保持连接的,即当前输入的命令界面是可以进行关闭的

    Storm性能调优
    为了解决数据不一致的问题,我们先把zookeeper的data目录下先删除,保持一致
    每个机器上执行
    rm –rf $ZK_HOME/data
    mkdir $ZK_HOME/data
    vim $ZK_HOME/data/myid 写入相应的 1,2,3等 :wq

    每个机器上启动zookeeper
    bin/zkServer.sh start

    开始配置storm的单机环境为集群环境配置

    Vim #STORM_HOME/conf/storm.yaml
    storm.zookeeper.servers:
    -	“192.168.1.1”
    -	“192.168.1.2”
    -	“192.168.1.3”
    Nimbus.seeds: [“192.168.1.1”,”192.168.1.2”]
    

    就简单做这样的操作就 可以了
    接着 拷贝storm文件到其余的机器上面去

    就可以启动storm了

    启动主节点【第一台机器上】
    Nohup bin/storm nimbus &
    启动从节点【第二台机器上】
    Nohup bin/storm supervisor &
    启动UI
    可以在第一台 也可以在第二台上面
    nohup bin/storm ui
    WebUI查看:
    192.168.1.2:8080/index.html

    ---------这里可以做节点故障转义的实验

  • 相关阅读:
    74.QT窗口实现类的封装
    73,QT指针数组实战(指针数组与数组指针)
    72.函数模板指针与类函数模板的绑定
    71.lambda表达式的递归
    C++ new delete(一)
    ios之@class
    xcode菜单栏
    ios 自定义delegate(一)
    strong&weak
    TCP/UDP
  • 原文地址:https://www.cnblogs.com/liuge36/p/12614768.html
Copyright © 2011-2022 走看看