黑猴子的家:Azkaban3.84.4之电话报警 REST API方式

1、选择 Rest API
2、保存并获取应用key
3、查看key
4、创建Maven项目
<?xml version="1.0" encoding="UTF-8"?>
<project xmlns="http://maven.apache.org/POM/4.0.0"
         xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance"
         xsi:schemaLocation="http://maven.apache.org/POM/4.0.0 http://maven.apache.org/xsd/maven-4.0.0.xsd">
    <modelVersion>4.0.0</modelVersion>
    <groupId>com.alex.azkaban</groupId>
    <artifactId>azkaban_phone</artifactId>
    <version>1.0-SNAPSHOT</version>
</project>
5、添加依赖
<?xml version="1.0" encoding="UTF-8"?>
<project xmlns="http://maven.apache.org/POM/4.0.0"
         xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance"
         xsi:schemaLocation="http://maven.apache.org/POM/4.0.0 http://maven.apache.org/xsd/maven-4.0.0.xsd">
    <modelVersion>4.0.0</modelVersion>

    <groupId>com.alex.azkaban</groupId>
    <artifactId>azkaban_phone</artifactId>
    <version>1.0-SNAPSHOT</version>

    <dependencies>
        <dependency>
            <groupId>org.apache.azkaban</groupId>
            <artifactId>az-core</artifactId>
            <version>3.84.4</version>
            <scope>system</scope>
            <systemPath>F:/jar/az-core-3.84.4.jar</systemPath>
        </dependency>

        <dependency>
            <groupId>org.apache.azkaban</groupId>
            <artifactId>azkaban-common</artifactId>
            <version>3.84.4</version>
            <scope>system</scope>
            <systemPath>F:/jar/azkaban-common-3.84.4.jar</systemPath>
        </dependency>

        <dependency>
            <groupId>commons-httpclient</groupId>
            <artifactId>commons-httpclient</artifactId>
            <version>3.1</version>
        </dependency>

        <dependency>
            <groupId>com.alibaba</groupId>
            <artifactId>fastjson</artifactId>
            <version>1.2.4</version>
        </dependency>

        <dependency>
            <groupId>com.google.code.gson</groupId>
            <artifactId>gson</artifactId>
            <version>2.8.2</version>
        </dependency>

        <!--日志 start-->
        <dependency>
            <groupId>log4j</groupId>
            <artifactId>log4j</artifactId>
            <version>1.2.17</version>
        </dependency>
        <dependency>
            <groupId>org.slf4j</groupId>
            <artifactId>slf4j-api</artifactId>
            <version>1.7.25</version>
        </dependency>
        <dependency>
            <groupId>org.slf4j</groupId>
            <artifactId>slf4j-log4j12</artifactId>
            <version>1.7.25</version>
            <scope>test</scope>
        </dependency>
        <dependency>
            <groupId>org.slf4j</groupId>
            <artifactId>slf4j-simple</artifactId>
            <version>1.7.25</version>
            <scope>test</scope>
        </dependency>
        <!--日志end-->

    </dependencies>

    <build>
        <plugins>
            <!-- java代码编译插件 -->
            <plugin>
                <groupId>org.apache.maven.plugins</groupId>
                <artifactId>maven-compiler-plugin</artifactId>
                <configuration>
                    <source>1.8</source>
                    <target>1.8</target>
                    <encoding>UTF-8</encoding>
                </configuration>
                <executions>
                    <execution>
                        <phase>compile</phase>
                        <goals>
                            <goal>compile</goal>
                        </goals>
                    </execution>
                </executions>
            </plugin>

            <!-- maven打包插件,以maven-assembly-plugin方式打包-->
            <plugin>
                <groupId>org.apache.maven.plugins</groupId>
                <artifactId>maven-assembly-plugin</artifactId>
                <version>3.0.0</version>
                <configuration>
                    <archive>
                        <manifest>
                            <mainClass>com.alex.json.test.FastJsonUtilTest</mainClass>
                        </manifest>
                    </archive>
                    <descriptorRefs>
                        <descriptorRef>jar-with-dependencies</descriptorRef>
                    </descriptorRefs>
                    <!-- this is used for not append id to the jar name -->
                    <appendAssemblyId>true</appendAssemblyId>
                </configuration>
                <executions>
                    <execution>
                        <id>make-assembly</id>
                        <phase>package</phase>
                        <goals>
                            <goal>single</goal>
                        </goals>
                    </execution>
                </executions>
            </plugin>
        </plugins>
    </build>
</project>
6、HttpUtils
package com.alex.azkaban.phone;

import org.apache.commons.httpclient.HttpClient;
import org.apache.commons.httpclient.methods.GetMethod;
import org.apache.commons.httpclient.methods.PostMethod;
import org.apache.commons.httpclient.methods.StringRequestEntity;

/**
 * @author 黑猴子的家
 */
public class HttpUtils {

    public static void get(String url) throws Exception {
        //todo 1、创建HttpClient
        HttpClient httpClient = new HttpClient();

        //todo 2、创建Method方法
        GetMethod getMethod = new GetMethod(url);

        //todo 3、发起请求
        int code = httpClient.executeMethod(getMethod);

        //todo 4、判断请求是否成功
        if (code == 200) {
            //todo 5、打印结果
            System.out.println(getMethod.getResponseBodyAsString());
        }

    }

    public static void post(String url, String content) throws Exception {

        // todo 1、创建HttpClient
        HttpClient httpClient = new HttpClient();

        // todo 2、创建Method
        PostMethod method = new PostMethod(url);

        // todo 3、设置body参数
        StringRequestEntity entity = new StringRequestEntity(content, "application/json", "utf-8");
        method.setRequestEntity(entity);

        // todo 4、发起请求
        int code = httpClient.executeMethod(method);

        // todo 5、判断请求是否成功
        if(code==200){
            System.out.println(method.getResponseBodyAsString());
        }
    }
}
7、PhoneAlerter
package com.alex.azkaban.phone;

import azkaban.alert.Alerter;
import azkaban.executor.ExecutableFlow;
import azkaban.executor.Executor;
import azkaban.executor.ExecutorManagerException;
import azkaban.sla.SlaOption;
import azkaban.utils.Props;

import java.util.List;

/**
 * @author 黑猴子的家
 */
public class PhoneAlerter implements Alerter {

    private String url;
    private String content = "";
    private String app_key;

    //http://api.aiops.com/alert/api/event?app=a2db6c6083c144759e6fe8c3acd7781e&eventId=xxx&eventType=trigger&alarmName=xxx&priority=2
    //http://api.aiops.com/alert/api/event?app=%s&eventId=xxx&eventType=trigger&alarmName=xxx&priority=2
    public PhoneAlerter(Props props){
        url = props.getString("my.url");
        app_key = props.getString("my.app.key");
    }

    //todo 成功发通知调用
    @Override
    public void alertOnSuccess(ExecutableFlow executableFlow) throws Exception {
        HttpUtils.post(String.format(url,app_key), content);
    }

    //todo 失败发通知调用
    @Override
    public void alertOnError(ExecutableFlow executableFlow, String... strings) throws Exception {

    }

    //todo  第一次失败的时候调用
    @Override
    public void alertOnFirstError(ExecutableFlow executableFlow) throws Exception {

    }

    @Override
    public void alertOnSla(SlaOption slaOption, String s) throws Exception {

    }

    @Override
    public void alertOnFailedUpdate(Executor executor, List<ExecutableFlow> list, ExecutorManagerException e) {

    }
}
8、配置azkaban
[alex@hadoop102 azkaban]$ cd azkaban-web-server/
[alex@hadoop102 azkaban-web-server]$ mkdir -p plugins/alerter/phone-alerter
[alex@hadoop102 azkaban-web-server]$ cd plugins/alerter/phone-alerter/
[alex@hadoop102 phone-alerter]$ mkdir lib
[alex@hadoop102 phone-alerter]$ mkdir conf
[alex@hadoop102 phone-alerter]$ vim conf/plugin.properties
#name一定要设置email,用以覆盖默认的邮件报警
alerter.name=email
alerter.external.classpaths=lib
alerter.class=com.alex.azkaban.phone.PhoneAlerter
#这两个参数和你使用的Alerter API 有关系
my.app.key=a2db6c6083c144759e6fe8c3acd7781e
my.url=http://api.aiops.com/alert/api/event?app=%s&eventId=xxx&eventType=trigger&alarmName=xxx&priority=2
9、重启web 服务
[alex@hadoop102 azkaban-web-server]$ bin/shutdown-web.sh 
[alex@hadoop102 azkaban-web-server]$ bin/start-web.sh
  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 1
    评论
安装和配置Azkaban 3.84.4的步骤如下: 1. 下载Azkaban 3.84.4的安装包。可以从引用\[1\]中提供的链接下载,或者从其他可靠的来源获取。 2. 解压安装包。根据引用\[1\]和引用\[2\]的指示,使用tar命令解压安装包,并将解压后的文件夹重命名。 3. 选择Mysql作为Azkaban的数据库。根据引用\[3\]的建议,使用Mysql作为Azkaban的数据库,因为它提供了一些增强功能和可靠性。 4. 创建安装目录。根据引用\[3\]的指示,创建一个目录来存放Azkaban的安装文件。 5. 解压并重命名其他组件。根据引用\[2\]和引用\[3\]的指示,解压并重命名Azkaban的其他组件,如执行服务器和Web服务器。 6. 发送SQL文件。根据引用\[3\]的指示,将创建所有SQL文件发送到指定的目录。 7. 导入Azkaban脚本。根据引用\[3\]的指示,使用Azkaban脚本导入所需的配置。 请根据上述步骤进行Azkaban 3.84.4的安装和配置。 #### 引用[.reference_title] - *1* *2* [Azkaban-3.84.4 兼容 mysql-8.0](https://blog.csdn.net/qq_33316544/article/details/125074262)[target="_blank" data-report-click={"spm":"1018.2226.3001.9630","extra":{"utm_source":"vip_chatgpt_common_search_pc_result","utm_medium":"distribute.pc_search_result.none-task-cask-2~all~insert_cask~default-1-null.142^v91^insertT0,239^v3^insert_chatgpt"}} ] [.reference_item] - *3* [猴子:Centos7 安装部署 Azkaban 3.84.4](https://blog.csdn.net/qq_28652401/article/details/117772402)[target="_blank" data-report-click={"spm":"1018.2226.3001.9630","extra":{"utm_source":"vip_chatgpt_common_search_pc_result","utm_medium":"distribute.pc_search_result.none-task-cask-2~all~insert_cask~default-1-null.142^v91^insertT0,239^v3^insert_chatgpt"}} ] [.reference_item] [ .reference_list ]

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值