当前位置: 首页 > article >正文

shell案例之一键部署kafka

Shell案例之一键部署kafka

一、案例问题

(1)Kafka是用Java编写的,需要配置jdk环境变量

(2)Kafka配置文件数目多

(3)命令安装繁琐

二、案例分析:

(1)检查Java环境

(2)下载并解压kafka

(3)设置环境变量

(4)启动Zookeeper和kafka

(5)验证启动是否成功

三、流程图:

四、案例实现:

(1)首先配置Java环境:

下载地址:Apache Kafka

选择需要的版本下载到本地,上传到虚拟机(wget拉取速度慢)

通过wget下载到本地,解压到/usr/local/jdk/文件下

(2)配置环境变量

打开/etc/profile在文件最后填写如下内容

export JAVA_HOME=/usr/local/jdk/jdk1.8.0_271

export PATH=$JAVA_HOME/bin:$PATH

当看到输入命令# which java,得到如下输出证明jdk环境配置完成

(3)编写一键部署脚本:

[root@localhost shell]# cat 1.sh

#!/bin/bash

installDir="/opt/module/kafka"

kafka_version="1.1.1"

scala_version="2.11"

#检查Java环境

if [ -z "$JAVA_HOME" ] || [ ! -f "$JAVA_HOME/bin/java" ]; then

  echo "JAVA_HOME未设置或无效,请安装JDK 1.8并设置Java环境变量再来执行此脚本"

  exit 1

fi

#检查并创建安装目录

if [ ! -d "${installDir}" ]; then

  sudo mkdir -p "${installDir}"

  if [ $? -eq 0 ]; then

    echo "安装目录${installDir}已创建"

  else

    echo "请确保您有足够的权限来创建目录,请增加权限后再次执行"

    exit 1

  fi

fi

#下载kafka压缩包

if [ ! -f /tmp/kafka_$scala_version-$kafka_version.tgz ]; then

  wget https://downloads.apache.org/kafka/$kafka_version/kafka_$scala_version-$kafka_version.tgz -P /tmp/

  if [ $? -eq 0 ]; then

    echo "kafka_$scala_version-$kafka_version.tgz下载成功"

  else

    echo "kafka_$scala_version-$kafka_version.tgz下载失败,请重试或手动下载到/tmp目录下再次执行"

    echo "下载地址:https://archive.apache.org/dist/kafka/$kafka_version/kafka_$scala_version-$kafka_version.tgz"

    exit 1

  fi

fi

#解压kafka压缩包

tar -zxvf /tmp/kafka_$scala_version-$kafka_version.tgz -C $installDir

if [ $? -eq 0 ]; then

  echo "/tmp/kafka_$scala_version-$kafka_version.tgz解压成功"

else

  echo "/tmp/kafka_$scala_version-$kafka_version.tgz解压失败,请查看异常信息后重试"

  exit 1

fi

#设置kafka环境变量

if [ -z "$KAFKA_HOME" ]; then

  echo >> ~/.bashrc

  echo '#KAFKA_HOME' >> ~/.bashrc

  echo "export KAFKA_HOME=$installDir/kafka_$scala_version-$kafka_version" >> ~/.bashrc

  echo 'export PATH=$PATH:$KAFKA_HOME/bin' >> ~/.bashrc

else

  echo "KAFKA_HOME已有设置:$KAFKA_HOME"

Fi

# 备份原始配置文件

cp "$installDir/kafka_2.11-1.1.1/config/server.properties" "$installDir/kafka_2.11-1.1.1/config/server.properties.bak"

#修改kafka配置文件

ip_addr=$(ip addr | grep 'inet ' | awk '{print $2}'| tail -n 1 | grep -oP '\d+\.\d+\.\d+\.\d+')

sed -i "s|#listeners=PLAINTEXT://:9092|listeners=PLAINTEXT://$ip_addr:9092|" "$installDir/kafka_$scala_version-$kafka_version/config/server.properties"

if [ $? -eq 0 ]; then

  echo "kafka配置文件修改成功"

else

  echo "kafka配置文件修改失败,请查看异常信息后重试"

  exit 1

fi

echo "kafka下载、安装、配置成功"

exit 0

五、实现解析:

确定完jdk环境后,运行一键部署脚本

1.检查并创建安装目录:

◎检查指定的安装目录是否存在,若不存在使用mkdir -p 创建

◎若创建成功,输出提示信息,否则,提示用户增加权限后重新执行

2.下载kafka压缩包:

◎检查/tmp目录下是否已经存在kafka压缩包,如果不存在使用wget下载

◎如果下载成功,输出提示信息,否则提示用户重试或手动下载

3.解压kafka压缩包:

◎使用tar命令将kafka压缩包解压到指定的安装目录

◎如果解压成功,输出提示信息,否则,提示用户查看异常信息后重试

4.设置kafka环境变量

◎检查KAFKA_HOME环境变量是否已经设置

◎若未设置,则将kafka的安装路径添加到~/.bashrc文件中,并更新PATH变量

◎若已经设置,输出当前的KAFKA_HOME值

5.修改kafka配置文件

◎获取主机的IP地址(最后一个匹配的IP地址)

◎使用sed命令修改server.properties文件中的listeners配置,将其设置为PLAINTEXT://9092

◎如果修改成功,输出提示信息,否则,提示用户查看异常信息后重试

下面是运行过程:


6.进入安装目录:

7.启动Zookeeper和kafka

六、测试结果:

(1)通过jps命令查看Java进程

(2)查看端口已被监听,启动成功

(3)测试创建一个topic

#移动工作目录

[root@localhost kafka]# cd /opt/kafka/bin

#创建topic

[root@localhost bin]# ./kafka-topics.sh --create --zookeeper 192.168.110.153:2181 --replication-factor 1 --partitions 1 --topic topic1

Created topic "topic1".

#查看topic信息

[root@localhost bin]# ./kafka-topics.sh --describe --zookeeper 192.168.110.153:2181 --topic topic1

Topic:topic1    PartitionCount:1        ReplicationFactor:1     Configs:

        Topic: topic1   Partition: 0    Leader: 0       Replicas: 0     Isr: 0

#启动生产者控制台

[root@localhost bin]# ./kafka-console-producer.sh --broker-list 192.168.110.153:9092 --topic1

>test

>123456

#启动消费者控制台(新开一个窗口)

[root@localhost bin]#  ./kafka-console-consumer.sh --bootstrap-server localhost:9092 --topic yahei --from-beginning

test

123456


http://www.kler.cn/a/350965.html

相关文章:

  • Maven 配置本地仓库
  • 年后找工作需要注意的事项
  • 数据结构-线性表
  • django在线考试系统
  • 我国无人机新增实名登记110.3 万架,累计完成飞行2666万小时
  • MySQL 中删除重复数据 SQL 写法
  • Triton矩阵乘
  • 数据分析:R语言计算XGBoost二分类模型的SHAP值
  • python基于大数据的电影市场预测分析
  • 什么是MoE?
  • electron 操作 cookie
  • 大数据与人工智能在金融风险控制中的应用
  • Ajax(web笔记)
  • 《京东金融APP的鸿蒙之旅系列专题》鸿蒙工程化:Hvigor构建技术
  • 考研日语 - 高频核心 2200 词(十)
  • 【从零开始的LeetCode-算法】3158.求出出现两次数字的 XOR 值
  • latex公式输入-矩阵
  • 《深度学习》OpenCV 风格迁移、DNN模块 案例解析及实现
  • MyBatis-Plus 记录
  • wireshark 解密浏览器https数据包
  • 【Oracle篇】SQL执行计划之多表连接(含内连接、外连接、半连接、反连接、笛卡尔连接五种连接方式和嵌套、哈希、排序合并三种连接算法)(第四篇,总共七篇)
  • docker-compose里定义的参数来创建容器
  • Apache jmeter中MIME类型如何定义
  • 网络安全之密码学
  • StarRocks大批量数据导入方案-使用 Kafka connector 导入数据
  • 软考中级 - 软件设计师学习笔记 - 1.3 计算机安全