java databus_linkedin 的 databus 部署「建议收藏」

java databus_linkedin 的 databus 部署「建议收藏」1.下载源码复制ojdbc.jar到相应的文件夹gitclonehttps://github.com/linkedin/databus/sandbox-repo/com/oracle/ojdbc6/11.2.0.2.0/ojdbc6-11.2.0.2.0.jar2.在subprojects.gradle中加上options.addStringOption(‘encodi…

大家好,又见面了,我是你们的朋友全栈君。如果您正在找激活码,请点击查看最新教程,关注关注公众号 “全栈程序员社区” 获取激活教程,可能之前旧版本教程已经失效.最新Idea2022.1教程亲测有效,一键激活。

Jetbrains全系列IDE稳定放心使用

1. 下载源码 复制 ojdbc.jar 到相应的文件夹

git clone https://github.com/linkedin/databus/

sandbox-repo/com/oracle/ojdbc6/11.2.0.2.0/ojdbc6-11.2.0.2.0.jar

2. 在 subprojects.gradle 中 加上

options.addStringOption(‘encoding’, ‘UTF-8’)

最后的结果为

if (JavaVersion.current().isJava8Compatible()) {

allprojects {

tasks.withType(Javadoc) {

options.addStringOption(‘Xdoclint:none’, ‘-quiet’)

options.addStringOption(‘encoding’, ‘UTF-8’)

}

}

}

3. 在 build.gradle 中加上

tasks.withType(JavaCompile) { options.encoding = “UTF-8” }

4. 在 com.linkedin.databus2.core.container.netty.ServerContainer 的 initializeContainerJmx() 方法中加上一句

LocateRegistry.createRegistry(_containerStaticConfig.getJmx().getRmiRegistryPort());

最后的结果为 (不然会报 Cannot bind to URL rmi://localhost:1099 ServiceUnavailableException )

protected void initializeContainerJmx() {

if (_containerStaticConfig.getJmx().isRmiEnabled()) {

try {

JMXServiceURL jmxServiceUrl = new JMXServiceURL(

“service:jmx:rmi://” + _containerStaticConfig.getJmx().getJmxServiceHost() + “:”

+ _containerStaticConfig.getJmx().getJmxServicePort() + “/jndi/rmi://”

+ _containerStaticConfig.getJmx().getRmiRegistryHost() + “:”

+ _containerStaticConfig.getJmx().getRmiRegistryPort() + “/jmxrmi”

+ _containerStaticConfig.getJmx().getJmxServicePort());

LocateRegistry.createRegistry(_containerStaticConfig.getJmx().getRmiRegistryPort());

_jmxConnServer = JMXConnectorServerFactory.newJMXConnectorServer(jmxServiceUrl, null, getMbeanServer());

} catch (Exception e) {

LOG.warn(“Unable to instantiate JMX server”, e);

}

}

}

5. 修改 databus2-example-client-pkg/conf/client_person.properties (非必须)

databus.client.connectionDefaults.enablePullerMessageQueueLogging=false

不然 databus2-example-client-pkg 中的 databus2-client-person.out 日志文件会快速增长

6. 修改 oracle/bin/createUser.sh

sqlplus system/manager\@${DBNAME} as sysdba << __EOF__

改为自己的oracle管理员 用户名 密码

system为管理员用户名 manager为密码

7. 修改 databus2-example/database/person/tablespace (不改也没关系 下面的要一致 我是改成了 tbs_dbbus)

8. 修改 sources-person.json 改为

{

“name”: “person”,

“id”: 1,

“uri”: “jdbc:oracle:thin:dbbus/dbbus@localhost:1521:orcl”,

“slowSourceQueryThreshold”: 2000,

“sources”: [

{

“id”: 101,

“name”: “com.linkedin.events.example.person.Person”,

“uri”: “dbbus.person”,

“partitionFunction”: “constant:1”

}

]

}

9. 打包命令

gradle -Dopen_source=true assemble

生成的工程在 父项目的 build 目录下 (这一点gradle和maven不一样的 )

10. 运行 createUser.sh 新建oracle 用户 dbbus/dbbus 这里的 db_table_space 要与 第8步骤中 databus2-example/database/person/tablespace 里面内容一致

db_path 存放 oracle .dbf 文件的地方 如果不知道 find / -name ‘.dbf’ 就可以找到路径了 乱写应该问题也不大(我没试过)

#createUser.sh db_username db_password db_id db_table_space db_path

sh createUser.sh dbbus dbbus orcl tbs_dbbus /home/u02/11g/dbs/

11.运行 createSchema.sh 在oracle中生成必要的 package table seq tigger Procedure 等

#createSchema.sh db_username/db_password@db_id tab_and_view_path

sh createSchema.sh dbbus/dbbus@orcl /home/yiwu/databus/databus2-example/database/person/

12. 生成 apache-avro 序列化文件

如 com.linkedin.events.example.person.Person.1.avsc com.linkedin.events.example.person.Person_V1.java

这步可以省略 官方的例子已经给你生成好了

avroOutDir javaOutDir 自定义 不需要太准确 生成好之后 拷贝到相应的目录就可以了

#create Avro records

sh dbus2-avro-schema-gen.sh -namespace com.linkedin.events.example.person -recordName Person -viewName “sy\$person” -avroOutDir /home/yiwu/dbtmp -avroOutVersion 1 -javaOutDir /home/yiwu/dbtmp -userName dbbus -password dbbus -database jdbc:oracle:thin:@127.0.0.1:1521:orcl

13. 运行 relay

#解压

tar -zxvf build/databus2-example-relay-pkg/distributions/databus2-example-relay-pkg-2.0.0.tar.gz

#运行

sh start-example-relay.sh person

14. 运行 client

#解压

tar -zxvf build/databus2-example-client-pkg/distributions/databus2-example-client-pkg-2.0.0.tar.gz

#运行

sh start-example-client.sh person

15. 在oracle中执行insert语句

INSERT INTO person(id,first_name, last_name) VALUES(1,’balaji’, ‘varadaran’);

就可以在 build/databus2-example-client-pkg/distributions/logs/client.log 中看到相应的记录了

2017-08-24 14:46:46,795 +752167 [callback-1] (INFO) {PersonConsumer} firstName: balaji, lastName: varadaran, birthDate: null, deleted: false

end

版权声明:本文内容由互联网用户自发贡献,该文观点仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请联系我们举报,一经查实,本站将立刻删除。

发布者:全栈程序员-站长,转载请注明出处:https://javaforall.net/181118.html原文链接:https://javaforall.net

(0)
全栈程序员-站长的头像全栈程序员-站长


相关推荐

  • kindeditor 加载 html,kindeditor配置

    kindeditor 加载 html,kindeditor配置kindeditor 编辑器 php 的详细配置方法怎样为 kindeditor 设置初始内容下拉菜单 Menu APIContents 下拉菜单 Menu APIK menu options K menu options 创建下拉菜单 参数 objectoption 配置信息返回 KMenu 继承 KWidget K widget options 创建并配置 KindE

    2026年2月6日
    0
  • pychram激活码[最新免费获取]

    (pychram激活码)本文适用于JetBrains家族所有ide,包括IntelliJidea,phpstorm,webstorm,pycharm,datagrip等。https://javaforall.net/100143.htmlIntelliJ2021最新激活注册码,破解教程可免费永久激活,亲测有效,上面是详细链接哦~C…

    2022年4月1日
    38
  • winform界面美化

    winform界面美化 介绍如下:1.这是DELPHI的换肤软件的DOTNET版,使用简单并有皮肤编辑工具,可到官方网站去下,当前版本为:1.20.1,更新时间:2008-04-202.这次发布的版本包括了DotNetSkin的ForVS2003和VS2005两个版本。3.未破解前,如果要显示标题栏,则标题标显示的是Logo图片,样式请看官方的DEMO程序;如果不显示标题栏,则在程序启动的时候提示一个对话框(T

    2022年5月8日
    46
  • mac navicat激活码【中文破解版】

    (mac navicat激活码)JetBrains旗下有多款编译器工具(如:IntelliJ、WebStorm、PyCharm等)在各编程领域几乎都占据了垄断地位。建立在开源IntelliJ平台之上,过去15年以来,JetBrains一直在不断发展和完善这个平台。这个平台可以针对您的开发工作流进行微调并且能够提供…

    2022年3月26日
    43
  • CMD查看端口占用并关闭命令

    CMD查看端口占用并关闭命令1.查询端口netstat-ano|findstr“123456”TCP127.0.0.1:12340.0.0.0:0LISTENING67892.查询端口名tasklist|findstr“6789”studio64.exe6789Console31,385,024K3.关闭端口taskkill/pid“6789”/F.

    2022年5月12日
    50
  • C语言之格式化输出字符

    C语言之格式化输出字符1、格式化输出字符:%d十进制有符号整数%ld十进制long有符号整数%u十进制无符号整数%o以八进制表示的整数%x以十六进制表示的整数%ffloat型浮点数%lfdouble型浮点数%e指数形式的浮点数%c单个字符%s字符串%p指针的值2、特殊应用:%5d要求宽度为5位,如果不足5位,前面空格补齐;如果足够5位,此语句无效。%05d要求宽度为5位,如果不足5位,前面0补…

    2022年7月24日
    15

发表回复

您的邮箱地址不会被公开。 必填项已用 * 标注

关注全栈程序员社区公众号