前往小程序,Get更优阅读体验!
立即前往
首页
学习
活动
专区
圈层
工具
发布
首页
学习
活动
专区
圈层
工具
MCP广场
社区首页 >专栏 >Azkaban Two Server模式部署 原

Azkaban Two Server模式部署 原

作者头像
云飞扬
发布于 2019-03-12 10:01:54
发布于 2019-03-12 10:01:54
2.8K04
代码可运行
举报
文章被收录于专栏:星汉技术星汉技术
运行总次数:4
代码可运行

Azkaban Two Server模式部署

Two Server模式就是把Azkaban和MySQL进行了分离,下面就介绍一下这种部署模式。

1、准备工作

1.结点规划

node1:azkaban-web、azkaban-exec

node2:MySQL

这里本人将azkaban的相关服务放置到一台服务器中,将MySQL放置到另外一台服务器中。

2.服务器准备

两台服务器,服务器系统这里选择的是CentOS7。一台称之为node1、另外一台称之为node2。

  • 主机名称修改:根据自己的需求修改。
  • 添加主机名解析:
  • 免密登录:为了避免麻烦的操作,这里本人配置了免密登录。主机中如果安装了hadoop大数据相关的软件,那么肯定已经配置过了。
  • 两台服务器都安装jdk,jdk版本1.8以上。
  • 编译源码,参见:Azkaban源码编译,此处使用的是Azkaban-3.66.0版本。
  • node2中安装MySQL,此处忽略安装MySQL的过程。详情参见:Linux中安装MySQL

2、MySQL相关操作

1.拷贝建表文件

在node2上创建一个放置建表文件的目录:

代码语言:javascript
代码运行次数:0
运行
AI代码解释
复制
mkdir –p /home/script/azkabansql

到编译的目录中,将编译好的文件远程拷贝到目标主机:

代码语言:javascript
代码运行次数:0
运行
AI代码解释
复制
cd /opt/azkaban/azkaban/azkaban-db/build/distributions/
scp azkaban-db-3.66.0-6-ge20c886.tar.gz root@node2:/home/script/azkabansql/

到node2上解压文件

代码语言:javascript
代码运行次数:0
运行
AI代码解释
复制
cd /home/script/azkabansql
tar -zxvf azkaban-db-3.66.0-6-ge20c886.tar.gz

以上为解压出来的文件,这里需要使用的就是红框框起来的sql文件。

2.建库

在存放建表语句文件的目录下登录MySQL,如果不在此目录的话,建表文件使用非常麻烦。

代码语言:javascript
代码运行次数:0
运行
AI代码解释
复制
mysql –u root –p
代码语言:javascript
代码运行次数:0
运行
AI代码解释
复制
create database azkaban66;
use azkaban66

本人的数据库中已经有一个azkaban的数据库在使用了,这里本人创建了一个新的数据库,以azkaban的版本号结尾,数据库的名字可按需创建。

3.创建用户

这一步可以省略,你可以使用原有的root账户进行数据库的操作。

代码语言:javascript
代码运行次数:0
运行
AI代码解释
复制
create user ‘azkaban’@’%’ identified by ‘azkaban’;

前一个azkaban是用户名,后一个azkaban是密码。

4.设置权限

给用户赋予权限

代码语言:javascript
代码运行次数:0
运行
AI代码解释
复制
grant select,insert,update,delete on azkaban66.* to ‘azkaban’@’%with grant option;
flush privileges ;

5.建表

执行以下文件,进行建表:

代码语言:javascript
代码运行次数:0
运行
AI代码解释
复制
source azkaban-db-3.66.0-6-ge20c886/create-all-sql-3.66.0-6-ge20c886.sql

如果不是在当前目录下进入MySQL的话,可以使用绝对路径来进行文件导入。

下图为数据库中建立的表:

6.修改字符集

如果如果想要使azkaban在创建项目的时候description支持中文输入,那么这里就需要更改一个表的一个字段的字符集即可。

需要修改的表为projects表。

使用数据库连接工具Navicat for MySQL,连接到库,右键projects表,选择设计表,出现如下图的界面:

选中字段,修改字符集为utf8,然后保存即可。

7.修改上传文件限制

有的时候,会上传的文件过大,超过MySQL接收的默认最大值,这里可以修改一下MySQL的默认最大值。

代码语言:javascript
代码运行次数:0
运行
AI代码解释
复制
vim /etc/my.cnf

max_allowed_packet=1024M

修改完成之后,重启数据库。

3、拷贝文件

将编译好的文件拷贝到node2中规划的目录里去:

代码语言:javascript
代码运行次数:0
运行
AI代码解释
复制
cd opt/azkaban/azkaban/azkaban-web-server/build/distributions/
cp azkaban-exec-server-3.66.0-6-ge20c886.tar.gz /opt/azkaban/
cd opt/azkaban/azkaban/azkaban-exec-server/build/distributions/
cp azkaban-web-server-3.66.0-6-ge20c886.tar.gz /opt/azkaban/
# 解压
cd /opt/azkaban/
tar -zxvf azkaban-web-server-3.66.0-6-ge20c886.tar.gz
tar -zxvf azkaban-exec-server-3.66.0-6-ge20c886.tar.gz

解压之后,web下的文件夹列表如下:

exec下的文件夹列表如下:

官方网站上提示:

  • web解压之后有如下几个目录:bin、conf、lib、web
  • exec解压之后有如下几个目录:bin、conf、lib、extlib、plugins

所以现在只有exec目录下少了一个文件。

4、配置exec

官方的文档顺序,是先配置的exec,这里也先从exec开始配置。

进入exec的conf目录中,可以看到有如下三个个文件:

其中global.properties是一个空的文件。

1.azkaban.properties

编辑此文件,命令如下:

代码语言:javascript
代码运行次数:0
运行
AI代码解释
复制
vim azkaban.properties

文件的原始内容,如下图:

由官方文档得知,exec可以配置两大项内容:

  • 第一项是执行器服务器属性。
  • 第二项是MySQL连接属性。

下面开始配置,可将原来的文件中,不需要的属性注释掉,或者将原始文件改名复制一份,再进行修改。

代码语言:javascript
代码运行次数:0
运行
AI代码解释
复制
# Azkaban Personalization Settings
# 可以将其他的属性注释掉或者删除,这里只配置时区这一项
default.timezone.id=Asia/Shanghai

# Azkaban UserManager class
# Loader for projects
executor.global.properties=conf/global.properties
azkaban.project.dir=projects
# Velocity dev mode
velocity.dev.mode=false
# Azkaban Jetty server properties.
# mail settings
lockdown.create.projects=false
cache.directory=cache
# JMX stats
jetty.connector.stats=true
executor.connector.stats=true
# Azkaban Executor settings
executor.maxThreads=50
executor.flow.threads=30
# 这里添加一个端口配置
executor.port=12321
azkaban.execution.dir=executions

# Azkaban plugin settings
azkaban.jobtype.plugin.dir=plugins/jobtypes
# Azkaban mysql settings by default. Users should configure their own username and password.
database.type=mysql
mysql.port=3306
mysql.host=MySQL的ip地址
mysql.database=azkaban66
mysql.user=azkaban
mysql.password=azkaban
mysql.numconnections=100

2.log4j.properties

打开此文件,文件中已经配置好了

3.启动

在exec的home目录下执行以下目录,启动exec服务:

代码语言:javascript
代码运行次数:0
运行
AI代码解释
复制
bin/start-exec.sh

启动之后,home目录下的文件变为如下:

4.激活执行器

激活执行器有一个明显的地方可以看到,在数据库中executors表中,你可以查看当前服务器的active字段,没有激活的时候是0,激活之后是1。

如果不激活,那么在启动web的时候执行任务会报出找不到执行器的错误。

启动exec服务器之后,在exec服务器的home目录中立即执行如下命令,激活执行器:

代码语言:javascript
代码运行次数:0
运行
AI代码解释
复制
curl -G "localhost:$(<./executor.port)/executor?action=activate" && echo

如下图:

经过后续的测试发现,每次重启exec服务器,都需要激活。

5、配置Web

1.生成keystore文件

进入web的目录,执行如下命令:

代码语言:javascript
代码运行次数:0
运行
AI代码解释
复制
keytool -keystore keystore -alias jetty -genkey -keyalg RSA

此命令是固定的,不需要更改什么。如下是执行过程:

代码语言:javascript
代码运行次数:0
运行
AI代码解释
复制
[root@node1 azkaban-web-server-3.66.0-6-ge20c886]# keytool -keystore keystore -alias jetty -genkey -keyalg RSA
Enter keystore password: #密码
Re-enter new password: #密码
What is your first and last name?
  [Unknown]:  
What is the name of your organizational unit?
  [Unknown]:  
What is the name of your organization?
  [Unknown]:  
What is the name of your City or Locality?
  [Unknown]:  
What is the name of your State or Province?
  [Unknown]:  
What is the two-letter country code for this unit?
  [Unknown]:  
Is CN=Unknown, OU=Unknown, O=Unknown, L=Unknown, ST=Unknown, C=Unknown correct?
  [no]:  y

Enter key password for <jetty>
	(RETURN if same as keystore password): #密码
Re-enter new password: #密码

此时在看web目录之下,多了一个keystore文件。

如果是在别的目录之下进行的这个命令操作,在相应的目录下会有这个文件,只要将这个文件拷贝到web目录下即可。

2.azkaban.properties

此文件在conf目录下:

代码语言:javascript
代码运行次数:0
运行
AI代码解释
复制
cd conf/

由上图可以看到,conf目录下存在四个文件。

代码语言:javascript
代码运行次数:0
运行
AI代码解释
复制
cp azkaban.properties azkban.properties.model #复制一份,以免出错
vim azkaban.properties

如下图,为原始的azkaban.properties文件中的内容:

下面进行内容修改:

代码语言:javascript
代码运行次数:0
运行
AI代码解释
复制
# Azkaban Personalization Settings
azkaban.name=#按规划填写
azkaban.label=#按规划填写
azkaban.color=#FF3601
azkaban.default.servlet.path=/index
web.resource.dir=/opt/azkaban/azkaban-web-server-3.66.0-6-ge20c886/web/
default.timezone.id=Asia/Shanghai
# Azkaban UserManager class
user.manager.class=azkaban.user.XmlUserManager
user.manager.xml.file=/opt/azkaban/azkaban-web-server-3.66.0-6-ge20c886/conf/azkaban-users.xml
# Loader for projects
executor.global.properties=conf/global.properties
azkaban.project.dir=projects
# Velocity dev mode
velocity.dev.mode=false
# Azkaban Jetty server properties.
jetty.maxThreads=25
jetty.port=8081
jetty.ssl.port=8443
jetty.keystore=keystore
jetty.password=azkaban
jetty.keypassword=azkaban
jetty.truststore=keystore
jetty.trustpassword=azkaban
# Project Manager settings
project.temp.dir=/temp
project.version.retention=3
# Azkaban Executor settings
executor.port=12321
# mail settings
mail.sender=xxxxx@xxx.xx
mail.host=smtp.263.net
mail.user=xxxx@xxx.xx
mail.password=*********
# 以下两项可以不填
job.failure.email=
job.success.email=

lockdown.create.projects=false
cache.directory=cache
# JMX stats
jetty.connector.stats=true
executor.connector.stats=true
# Azkaban plugin settings
azkaban.jobtype.plugin.dir=plugins/jobtypes

# Azkaban mysql settings by default. Users should configure their own username and password.
database.type=mysql
mysql.port=3306
mysql.host=ip地址
mysql.database=azkaban66
mysql.user=azkaban
mysql.password=azkaban
mysql.numconnections=100
#Multiple Executor
azkaban.use.multiple.executors=true
azkaban.executorselector.filters=StaticRemainingFlowSize,MinimumFreeMemory,CpuStatus
azkaban.executorselector.comparator.NumberOfAssignedFlowComparator=1
azkaban.executorselector.comparator.Memory=1

在web的home目录下创建文件plugins/jobtypes,命令如下:

代码语言:javascript
代码运行次数:0
运行
AI代码解释
复制
midir –p plugins/jobtypes

3.azkaban-users.xml

添加azkaban的用户,在此文件中操作,文件原始内容如下图:

如果要添加用户,就按照<user/>的格式添加即可。

4.log4j.properties

此文件和exec中的内容是一样的。

6、web配置的坑

1.第一坑

  • web.resource.dir项的值要使用绝对路径,否则web页面会没有美丽的界面。
  • user.manager.xml.file项的值要使用绝对路径,否则启动的时候会报找不到文件的错误。

2.第二坑:邮箱预警的坑

mail.sender、mail.host、mail.user、mail.password这四项每一项配置都不能少,端口可以不配置,而且mail.sender和mail.user的值是一样的,少一项或者配错一项都会报出错误,错误信息如下:

代码语言:javascript
代码运行次数:0
运行
AI代码解释
复制
2018/12/28 15:56:01.187 +0800 ERROR [EmailMessage] [Azkaban] Connecting to SMTP server failed, attempt: 0
javax.mail.AuthenticationFailedException: 500 Error: bad syntax

        at com.sun.mail.smtp.SMTPTransport$Authenticator.authenticate(SMTPTransport.java:823)
        at com.sun.mail.smtp.SMTPTransport.authenticate(SMTPTransport.java:756)
        at com.sun.mail.smtp.SMTPTransport.protocolConnect(SMTPTransport.java:673)
        at javax.mail.Service.connect(Service.java:295)
        at azkaban.utils.JavaxMailSender.connect(JavaxMailSender.java:34)
        at azkaban.utils.EmailMessage.connectToSMTPServer(EmailMessage.java:220)
        at azkaban.utils.EmailMessage.retryConnectToSMTPServer(EmailMessage.java:230)
        at azkaban.utils.EmailMessage.sendEmail(EmailMessage.java:213)
        at azkaban.utils.Emailer.sendEmail(Emailer.java:220)
        at azkaban.utils.Emailer.alertOnSuccess(Emailer.java:153)
        at azkaban.executor.selector.ExecutionControllerUtils.alertUser(ExecutionControllerUtils.java:123)
        at azkaban.executor.ExecutionFinalizer.finalizeFlow(ExecutionFinalizer.java:98)
        at azkaban.executor.RunningExecutionsUpdater.updateExecutions(RunningExecutionsUpdater.java:131)
        at azkaban.executor.RunningExecutionsUpdaterThread.run(RunningExecutionsUpdaterThread.java:54)

在网上看到一个说这个错误信息解决方法的,要改源码,其实是配置信息写错了。

3.第三坑

azkaban.jobtype.plugin.dir=plugins/jobtypes这一项一定要配置,并且创建文件夹,不然会报错,错误信息如下:

代码语言:javascript
代码运行次数:0
运行
AI代码解释
复制
2018/12/28 15:50:30.898 +0800 ERROR [FlowTriggerScheduler] [Azkaban] unable to get scheduled flow triggers
java.lang.NullPointerException
        at azkaban.flowtrigger.quartz.FlowTriggerScheduler.getScheduledFlowTriggerJobs(FlowTriggerScheduler.java:132)
        at azkaban.webapp.servlet.FlowTriggerServlet.handlePage(FlowTriggerServlet.java:140)
        at azkaban.webapp.servlet.FlowTriggerServlet.handleGet(FlowTriggerServlet.java:55)
        at azkaban.webapp.servlet.LoginAbstractAzkabanServlet.doGet(LoginAbstractAzkabanServlet.java:123)
        at javax.servlet.http.HttpServlet.service(HttpServlet.java:668)
        at javax.servlet.http.HttpServlet.service(HttpServlet.java:770)
        at org.mortbay.jetty.servlet.ServletHolder.handle(ServletHolder.java:511)
        at org.mortbay.jetty.servlet.ServletHandler.handle(ServletHandler.java:401)
        at org.mortbay.jetty.servlet.SessionHandler.handle(SessionHandler.java:182)
        at org.mortbay.jetty.handler.ContextHandler.handle(ContextHandler.java:766)
        at org.mortbay.jetty.handler.HandlerWrapper.handle(HandlerWrapper.java:152)
        at org.mortbay.jetty.Server.handle(Server.java:326)
        at org.mortbay.jetty.HttpConnection.handleRequest(HttpConnection.java:542)
        at org.mortbay.jetty.HttpConnection$RequestHandler.headerComplete(HttpConnection.java:928)
        at org.mortbay.jetty.HttpParser.parseNext(HttpParser.java:549)
        at org.mortbay.jetty.HttpParser.parseAvailable(HttpParser.java:212)
        at org.mortbay.jetty.HttpConnection.handle(HttpConnection.java:404)
        at org.mortbay.jetty.bio.SocketConnector$Connection.run(SocketConnector.java:228)
        at org.mortbay.jetty.security.SslSocketConnector$SslConnection.run(SslSocketConnector.java:713)
        at org.mortbay.thread.QueuedThreadPool$PoolThread.run(QueuedThreadPool.java:582)

4.第四坑

Multiple Executor的几项必须配置,不然的话会报出以下错误:

代码语言:javascript
代码运行次数:0
运行
AI代码解释
复制
2018/12/28 15:43:28.406 +0800 ERROR [StdOutErrRedirect] [Azkaban] Exception in thread "main"
2018/12/28 15:43:28.406 +0800 ERROR [StdOutErrRedirect] [Azkaban] java.lang.IllegalArgumentException: azkaban.use.multiple.executors must be true. Single executor mode is not supported any more.
2018/12/28 15:43:28.407 +0800 ERROR [StdOutErrRedirect] [Azkaban]       at azkaban.executor.ExecutorManager.checkMultiExecutorMode(ExecutorManager.java:240)
2018/12/28 15:43:28.407 +0800 ERROR [StdOutErrRedirect] [Azkaban]       at azkaban.executor.ExecutorManager.setupExecutors(ExecutorManager.java:229)
2018/12/28 15:43:28.407 +0800 ERROR [StdOutErrRedirect] [Azkaban]       at azkaban.executor.ExecutorManager.initialize(ExecutorManager.java:155)
2018/12/28 15:43:28.407 +0800 ERROR [StdOutErrRedirect] [Azkaban]       at azkaban.executor.ExecutorManager.start(ExecutorManager.java:168)
2018/12/28 15:43:28.407 +0800 ERROR [StdOutErrRedirect] [Azkaban]       at azkaban.webapp.AzkabanWebServer.launch(AzkabanWebServer.java:235)
2018/12/28 15:43:28.407 +0800 ERROR [StdOutErrRedirect] [Azkaban]       at azkaban.webapp.AzkabanWebServer.main(AzkabanWebServer.java:226)

5.第五坑:CDH集成

如果使用的是CDH平台安装的hadoop相关的软件,那么在启动Azkaban的时候日志第一行会出现如下的错误信息:

代码语言:javascript
代码运行次数:0
运行
AI代码解释
复制
Error: HADOOP_HOME is not set. Hadoop job types will not run properly.

这个错误不影响Azkaban正常的执行hadoop相关的脚本。

这是因为CDH平台集成的Hadoop没有在profile中添加环境变量,这里需要在profile文件中添加两个环境变量。操作如下:

代码语言:javascript
代码运行次数:0
运行
AI代码解释
复制
vim /etc/profile

要添加的内容如下:

代码语言:javascript
代码运行次数:0
运行
AI代码解释
复制
export HADOOP_HOME=/opt/cloudera/parcels/CDH
export HADOOP_CONF_DIR=/etc/hadoop/conf.cloudera.yarn

添加完成source,让文件生效。

代码语言:javascript
代码运行次数:0
运行
AI代码解释
复制
source /etc/profile

以上两条变量的值是CDH的目录,填写的时候,查看一下,自己的CDH安装是否是这两个目录,如果不是,值要根据自己的目录进行修改。

然后重启Azkaban web,日志中的错误消失,取代是如下内容:

代码语言:javascript
代码运行次数:0
运行
AI代码解释
复制
Using Hadoop from /opt/cloudera/parcels/CDH

7、启动web

启动命令如下:

代码语言:javascript
代码运行次数:0
运行
AI代码解释
复制
bin/start-web.sh

8、登录检测

在浏览器中输入:ip:8443,会出现如下图的登录界面:

由上图可以看出,红块的地方是填写的azkaban.name和azkaban.labe两项的值,这里本人打了码,配置完成你们即可看到自己的成果。

9、job测试

以下是本人准备的一个简答的脚本的job文件,weather.job:

代码语言:javascript
代码运行次数:0
运行
AI代码解释
复制
type=command
command=/usr/java/default/jdk/bin/java -jar /home/script/Weather.jar
failure.emails=xxx@xxx.xx
success.emails=xxx@xxx.xx

上面两项邮箱相关的,一项是执行成功发送邮件,一项是执行失败发送邮件。邮箱自行填写。如果这里不填写邮箱,那么就不会给你发送执行结果。

将文件打成zip的压缩包上传到测试项目中,选择执行。

执行成功,也有邮件发送。

以上为整个Two Server模式配置的整个过程和踩过的坑。

本文参与 腾讯云自媒体同步曝光计划,分享自作者个人站点/博客。
原始发表:2018/12/29 ,如有侵权请联系 cloudcommunity@tencent.com 删除

本文分享自 作者个人站点/博客 前往查看

如有侵权,请联系 cloudcommunity@tencent.com 删除。

本文参与 腾讯云自媒体同步曝光计划  ,欢迎热爱写作的你一起参与!

评论
登录后参与评论
暂无评论
推荐阅读
SpringBoot整合零一万物模型API进行多轮对话
只提供了http接口和python的sdk。 所以Java如果想使用,可以采用http接口调用。
leehao
2025/02/11
980
DB-GPT v0.4.0 使用通义千问 API Chat Excel
DB-GPT[1] 是一个使用本地大模型(或在线 API)与数据交互的开源项目,Demo[2] 中使用 ChatGPT 3.5 的接口,效果很吸引人。
AlphaHinex
2024/04/09
1.7K0
DB-GPT v0.4.0 使用通义千问 API Chat Excel
Spring AI 开发专属于你的AI聊天机器人
聊天机器人不仅提高了效率,还改善了用户体验,它们可以24/7不间断地为客户提供服务,解答常见问题
菜菜的后端私房菜
2024/11/08
2771
AI办公自动化:用通义千问Qwen-Long批量总结PDF长文档内容
Qwen-Long是在通义千问针对超长上下文处理场景的大语言模型,支持中文、英文等不同语言输入,支持最长1000万tokens(约1500万字或1.5万页文档)的超长上下文对话。配合同步上线的文档服务,可支持word、pdf、markdown、epub、mobi等多种文档格式的解析和对话。借助Qwen-Long可以批量总结长文档。
AIGC部落
2024/06/24
1.1K0
AI办公自动化:用通义千问Qwen-Long批量总结PDF长文档内容
初识langchain[1]:Langchain实战教学,利用qwen2.1与GLM-4大模型构建智能解决方案[含Agent、tavily面向AI搜索]
大模型三大重点:算力、数据、算法,ReAct (reason推理+act行动)–思维链
汀丶人工智能
2024/07/25
1.6K0
初识langchain[1]:Langchain实战教学,利用qwen2.1与GLM-4大模型构建智能解决方案[含Agent、tavily面向AI搜索]
总结|哪些平台有大模型知识库的Web API服务
截止2023/12/6 笔者个人的调研,有三家有大模型知识库的web api服务:
悟乙己
2023/12/07
9380
总结|哪些平台有大模型知识库的Web API服务
BaiChuan13B多轮对话微调范例
前方干货预警:这可能是你能够找到的,最容易理解,最容易跑通的,适用于多轮对话数据集的大模型高效微调范例。
lyhue1991
2023/09/05
1.2K0
BaiChuan13B多轮对话微调范例
【黄啊码】Gradio配合Openai接口实现机器人问答对话
本文将介绍如何使用Gradio和OpenAI API来实现一个流式问答机器人。通过这个教程,你将学会如何构建一个可以处理文本输入并返回连续响应的聊天机器人。
黄啊码
2024/08/09
6280
使用SSE对接清华chatGLM模型
用户10136162
2023/12/14
5970
【机器学习】Qwen2大模型原理、训练及推理部署实战
刚刚写完【机器学习】Qwen1.5-14B-Chat大模型训练与推理实战 ,阿里Qwen就推出了Qwen2,相较于Qwen1.5中0.5B、1.8B、4B、7B、14B、32B、72B、110B等8个Dense模型以及1个14B(A2.7B)MoE模型共计9个模型,Qwen2包含了0.5B、1.5B、7B、57B-A14B和72B共计5个尺寸模型。从尺寸上来讲,最关键的就是推出了57B-A14B这个更大尺寸的MoE模型,有人问为什么删除了14B这个针对32G显存的常用尺寸,其实对于57B-A14B剪枝一下就可以得到。
LDG_AGI
2024/08/13
2.7K0
【机器学习】Qwen2大模型原理、训练及推理部署实战
用 Spring AI 调用 OpenAI 对话接口
从 https://start.spring.io/ 下载一个包含 Spring Web 依赖的 Maven 工程:
AlphaHinex
2024/12/03
5150
用 Spring AI 调用 OpenAI 对话接口
实现免费ChatGPT前后端SpringBoot&Vue
第四步:复制密钥值,替换上面代码中的sk-*******,替换后的代码如下所示:.header(“Authorization”, “Bearer sk-1234567890123456789”)
知识浅谈
2024/05/25
3490
实现免费ChatGPT前后端SpringBoot&Vue
使用Java在国内不访问国外网站调用Chatgpt API实现问答对话
OpenAI开放的api接口调用很简单,只要用post请求就可以了。但是因为地区限制,国内无法直接使用这个方法。但我们可以通过Cloudflare来进行套壳转发请求来完成国内对openai的访问。
I Teach You 我教你
2023/07/18
1.5K0
使用Java在国内不访问国外网站调用Chatgpt API实现问答对话
OpenAI调用接口多轮对话Multi Turn Multi Agent 多轮多角色对话调试和可视化工具Dialogue Visualization
伴随着生成式人工智能技术发展,进2年涌现出大语言模型LLM/Agent系统/AI推理等众多方向的技术项目和论文。其中对话系统,智能体交互是用户通过UX界面和AI系统进行交互,这种交互有时候也是多模态(用户输入文字/语音/图像)等等。在调用OpenAI 的对话接口时候,有时候需要把对话结果打印出来检查是否有bug,JSON数据格式就比较难看出来了,尤其是有多角色的多轮对话。这个时候可以借助一些在线的"对话"可视化的工具 (Online Dialogue Visualization Tool) DeepNLP Dialogue Visualization Tool,方便产品经理,算法研发,学术研究过程中可视化多智能体多轮对话 ( Multi-Agent Multi-TurnDialogue Visualization)。用户只用把多轮对话的Json数据输入,前端渲染的图片和分享H5 链接可以方便加到产品原型文档,学术论文,技术博客中。
用户11310872
2024/10/11
1K0
OpenAI调用接口多轮对话Multi Turn Multi Agent 多轮多角色对话调试和可视化工具Dialogue Visualization
大模型探索:阿里向量检索服务DashVector
大模型无疑是这两年最火的概念,国内外各厂商都不甘示弱纷纷推出自己的大模型能力和应用。废话不多说,在实际的大模型应用中,向量检索服务无疑是目前不可缺少的一个重要部分,几乎所有的prompt工程都离不开,因此这里从阿里的DashVector入手,从实际应用角度来了解什么是向量检索服务,以及怎样使用。
程序员架构进阶
2024/05/06
1.4K0
大模型探索:阿里向量检索服务DashVector
【GPT-3.5】通过python调用ChatGPT API与ChatGPT对话交流
​ AIGC即AI Generated Content,利用人工智能技术来生成内容,是继UGC、PGC之后的新型内容生产方式,AI写作、AI绘画、AI作曲、AI剪辑、AI动画、AI交互等都属于AIGC的分支。AIGC是一种利用机器智能创作内容的新技术,它不同于UGC,它有自己的技术特点,比如数据量化、创造力、跨模态融合和认知交互等。这些技术特点使得AIGC成为不可替代的新一代内容生成方式。
宝耶需努力
2023/11/26
9400
【GPT-3.5】通过python调用ChatGPT API与ChatGPT对话交流
【零基础】Python开发调用 ChatGPT API 的命令行工具
本文章针对python初学者,介绍如何使用命令行调用ChatGPT API来实现最基本的聊天功能。
Mirza Zhao
2023/11/10
1.8K1
【零基础】Python开发调用 ChatGPT API 的命令行工具
大模型开发落地实战-长上下文多模态场景大模型运用实战
如何从零开始实现 AI 项目的落地?这是每个开发者和企业在迈向智能化时都会面临的核心问题。在本人创建的《人工智能项目落地实战指南》专栏中,我从实践角度出发,为大家梳理了大模型技术在市场应用中的三大方向,并根据 AI 运用的深浅程度进行分类。
fanstuck
2025/01/07
8832
大模型开发落地实战-长上下文多模态场景大模型运用实战
ChatGPT模型请求参数学习
请求url: POST https://api.openai.com/v1/chat/completions
用户11097514
2024/05/31
4520
20分钟上手DeepSeek开发:SpringBoot + Vue2快速构建AI对话系统
在生成式AI技术蓬勃发展的今天,大语言模型已成为企业智能化转型和个人效率提升的核心驱动力。作为国产大模型的优秀代表,DeepSeek凭借其卓越的中文语义理解能力和开发者友好的API生态,正在成为构建本土化AI应用的首选平台。本文将以Spring Boot3+Vue2全栈技术为基础,手把手带你打造一个具备以下特性的AI对话系统:
全干程序员demo
2025/03/18
4900
20分钟上手DeepSeek开发:SpringBoot + Vue2快速构建AI对话系统
推荐阅读
相关推荐
SpringBoot整合零一万物模型API进行多轮对话
更多 >
LV.1
这个人很懒,什么都没有留下~
目录
  • Azkaban Two Server模式部署
    • 1、准备工作
      • 1.结点规划
      • 2.服务器准备
    • 2、MySQL相关操作
      • 1.拷贝建表文件
      • 2.建库
      • 3.创建用户
      • 5.建表
      • 6.修改字符集
      • 7.修改上传文件限制
    • 3、拷贝文件
    • 4、配置exec
      • 1.azkaban.properties
      • 2.log4j.properties
      • 3.启动
      • 4.激活执行器
    • 5、配置Web
      • 1.生成keystore文件
      • 2.azkaban.properties
      • 3.azkaban-users.xml
      • 4.log4j.properties
    • 6、web配置的坑
      • 1.第一坑
      • 2.第二坑:邮箱预警的坑
      • 3.第三坑
      • 4.第四坑
      • 5.第五坑:CDH集成
    • 7、启动web
    • 8、登录检测
    • 9、job测试
领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档