Loading [MathJax]/jax/output/CommonHTML/config.js
首页
学习
活动
专区
圈层
工具
发布
首页
学习
活动
专区
圈层
工具
社区首页 >问答首页 >通过HTTP替换通配符上的部署

通过HTTP替换通配符上的部署
EN

Stack Overflow用户
提问于 2014-04-09 23:17:37
回答 3查看 5.1K关注 0票数 7

我们希望用curl替换现有的app.war部署。下面的文章为部署war文件提供了一种很好的方法。只要没有部署相同名称的war文件,它就能正常工作。但是,如果已经有了部署,它就失败了。我们是否可以通过curl替换现有的部署?

http://blog.arungupta.me/2014/01/deploy-to-wildfly-using-curl-tech-tip-10/

是否有方法获取通配符的HTTP的完整接口文档

EN

回答 3

Stack Overflow用户

回答已采纳

发布于 2014-04-11 01:56:20

为了实现这一点,我们编写了一个小Shell脚本:

代码语言:javascript
运行
AI代码解释
复制
#!/bin/bash
echo "Undeploy old war"
curl -S -H "content-Type: application/json" -d '{"operation":"undeploy", "address":[{"deployment":"old.war"}]}' --digest http://user:password@hostname:9990/management
echo ""

echo "Remove old war"
curl -S -H "content-Type: application/json" -d '{"operation":"remove", "address":[{"deployment":"old.war"}]}' --digest http://user:password@hostname:9990/management
echo ""

echo "Upload new war"
bytes_value=`curl -F "file=@/path/to/new.war" --digest http://user:password@$hostname:9990/management/add-content | perl -pe 's/^.*"BYTES_VALUE"\s*:\s*"(.*)".*$/$1/'`
echo $bytes_value

json_string_start='{"content":[{"hash": {"BYTES_VALUE" : "'
json_string_end='"}}], "address": [{"deployment":"new.war"}], "operation":"add", "enabled":"true"}'
json_string="$json_string_start$bytes_value$json_string_end"

echo "Deploy new war"
result=`curl -S -H "Content-Type: application/json" -d "$json_string" --digest http://user:password@hostname:9990/management | perl -pe 's/^.*"outcome"\s*:\s*"(.*)".*$/$1/'`
echo $result

if [ "$result" != "success" ]; then
  exit -1
fi

首先,旧的战争档案将被移除。在此之后,新的存档将被上传和部署。对于我们来说,即使还没有部署任何内容,这也是可行的。在这种情况下,前两个调用将失败,但是无论如何,新的内容都将被部署。

我们能够将部署时间从大约20分钟缩短到4分钟,方法是从Wildfly Maven插件切换到这个脚本!

希望这能有所帮助。干杯

票数 15
EN

Stack Overflow用户

发布于 2016-09-19 11:54:33

非常感谢@nioe的剧本!下面是一个带有静音curl的可配置版本,它更适合CI脚本编写:

代码语言:javascript
运行
AI代码解释
复制
#!/bin/bash

# Deploys given WAR to WildFly server, pass full path to WAR as argument

set -e
set -u

[[ -f "$1" ]] || { >&2 echo "Usage: $0 WAR-filename ('$1' is not a file)"; exit 1; }

WILDFLY_MANAGEMENT_URL=http://username:password@hostname:9990
WAR_NAME=`basename $1`
WAR_PATH=`dirname $1`

echo "Deploying '$WAR_NAME' from '$WAR_PATH' to '$WILDFLY_MANAGEMENT_URL'"
echo '-------------------'

echo "-> Undeploy old war"
curl -sS -H "content-Type: application/json" -d '{"operation":"undeploy", "address":[{"deployment":"'"${WAR_NAME}"'"}]}' --digest ${WILDFLY_MANAGEMENT_URL}/management
echo ""

echo "-> Remove old war"
curl -sS -H "content-Type: application/json" -d '{"operation":"remove", "address":[{"deployment":"'"${WAR_NAME}"'"}]}' --digest ${WILDFLY_MANAGEMENT_URL}/management
echo ""

echo "-> Upload new war"
bytes_value=`curl -sF "file=@${WAR_PATH}/${WAR_NAME}" --digest ${WILDFLY_MANAGEMENT_URL}/management/add-content | perl -pe 's/^.*"BYTES_VALUE"\s*:\s*"(.*)".*$/$1/'`
echo $bytes_value

json_string_start='{"content":[{"hash": {"BYTES_VALUE" : "'
json_string_end='"}}], "address": [{"deployment":"'"${WAR_NAME}"'"}], "operation":"add", "enabled":"true"}'
json_string="$json_string_start$bytes_value$json_string_end"

echo "-> Deploy new war"
result=`curl -sS -H "Content-Type: application/json" -d "$json_string" --digest ${WILDFLY_MANAGEMENT_URL}/management | perl -pe 's/^.*"outcome"\s*:\s*"(.*)".*$/$1/'`
echo $result

if [ "$result" != "success" ]; then
  exit -1
fi
票数 5
EN

Stack Overflow用户

发布于 2014-04-10 15:03:43

查看整个管理模型的文档

http://wildscribe.github.io/

没有可取代部署的直接行动。

部署资源的看见可能的属性/操作

因此,您可以做的是删除部署,如果有,然后添加新的部署。或者您可以在新名称下添加新部署,禁用旧部署并启用新部署。

你可以做很多选择。对于start,我建议您通过在bin文件夹中启动jboss-cli.sh|bat -c来简单地连接到服务器上的默认实例来查看jboss。

通过导航CLI,您还可以找到可以操作的一整套属性/操作/资源。

一些关于这个主题的文档

https://docs.jboss.org/author/display/WFLY8/CLI+Recipes

https://docs.jboss.org/author/display/WFLY8/Management+API+reference

票数 3
EN
页面原文内容由Stack Overflow提供。腾讯云小微IT领域专用引擎提供翻译支持
原文链接:

https://stackoverflow.com/questions/22981199

复制
相关文章
React:Redux怎么处理异步?
redux-thunk 中间件允许你 dispatch 一个函数(即:thunk),异步逻辑就放在这个函数中处理;
WEBJ2EE
2019/07/19
2.7K0
React:Redux怎么处理异步?
React---Redux异步action
(2).何时需要异步action:想要对状态进行操作,但是具体的数据靠异步任务返回。
半指温柔乐
2021/05/06
8600
Redux 异步数据流初探
用React写的项目中各组件的状态依赖关系非常复杂,为了便于管理组件的状态,使用 Redux。
一个会写诗的程序员
2018/12/13
6340
Redux 异步数据流初探
React-Redux 源码解析系列 -- React-Redux的作用
前面的章节讲完了redux的部分,又已经有了react,那为什么还需要有React-Redux呢?这个React-Redux 又帮助我们做了什么呢?
IMWeb前端团队
2019/12/03
7950
React-Redux 源码解析系列 -- React-Redux的作用
React-Redux 源码解析系列 -- React-Redux的作用
摘要总结:本文介绍了React-Redux的代码架构和设计理念,通过代码示例和示意图解释了React-Redux的代码结构和流程。同时,文章还探讨了React-Redux的优缺点,包括连接react和redux的方式、高阶组件的使用、纯组件的使用等。通过本文的讲解,可以更好地理解React-Redux的工作原理和架构设计,对于学习和使用React-Redux具有很高的参考价值。
IMWeb前端团队
2017/12/29
1K0
React-Redux 源码解析系列 -- React-Redux的作用
React:redux-form 应用示例
redux-form 提供了一堆 selector,便于我们从state中获取 form 表单的各种状态数据...
WEBJ2EE
2019/07/19
7180
React:redux-form 应用示例
Redux异步解决方案 1. Redux-Thunk中间件
简单介绍一下thunk,这是一个中间件,是解决redux异步问题产生的。我们都知道,在使用redux的时候,通过dispatch一个action 发生到reducer 然后传递给store修改状态 一系列都是同步的,那如果说我dispatch一个action 这个action帮我请求一下接口数据,你发现接口请求是异步的,没有办法等接口数据返回再传递给reducer 这个时候中间件就产生啦。 redux比较常用的中间件有 redux-saga、redux-thunk、redux-promise等 都是为了解决dispatch action异步处理问题
憧憬博客
2020/07/21
1.3K0
Redux 异步解决方案2. Redux-Saga中间件
因为Generator。结合yield  yield操作符会获取右边表达示的值返回 可以用于异步变同步操作 中间件的特性: 以前的 action -> reducers -> store 现在的 action -> middleware -> reducers -> store
憧憬博客
2020/07/21
1.1K0
Redux异步解决方案之Redux-Thunk原理及源码解析
前段时间,我们写了一篇Redux源码分析的文章,也分析了跟React连接的库React-Redux的源码实现。但是在Redux的生态中还有一个很重要的部分没有涉及到,那就是Redux的异步解决方案。本文会讲解Redux官方实现的异步解决方案----Redux-Thunk,我们还是会从基本的用法入手,再到原理解析,然后自己手写一个Redux-Thunk来替换它,也就是源码解析。
蒋鹏飞
2020/10/15
3.6K0
前端实现异步的几种方式_redux是什么
实际上,这个术语出自康奈尔大学的一篇论文:http://www.cs.cornell.edu/andru/cs711/2002fa/reading/sagas.pdf
全栈程序员站长
2022/10/02
1.8K0
前端实现异步的几种方式_redux是什么
异步发送邮件完整示例
本章使用task异步进程进行邮件发送,来阐述一下以上章节提到的各个知识点。 邮件类 下载swiftmailer composer require "swiftmailer/swiftmailer:^6.0" Mailer.php 与 vender目录 同级 require_once __DIR__ . '/vendor/autoload.php'; class Mailer { public $transport; public $mailer; /** * 发送邮件类
码农编程进阶笔记
2021/07/20
6710
异步发送邮件完整示例
发布者:全栈程序员栈长,转载请注明出处:https://javaforall.cn/111876.html原文链接:https://javaforall.cn
全栈程序员站长
2022/07/11
6200
redux-thunk 中间件的示例
Redux处理异步任务——异步数据流中间件:redux-thunk & action是一个函数,函数内部处理异步任务
用户9914333
2022/07/22
5720
在 redux 应用中使用 GraphQL
在 Redux 应用中获取和管理数据需要做许多工作。正如 Sashko Stubailo 指出的:
疯狂的技术宅
2019/03/28
2K0
在 redux 应用中使用 GraphQL
【Redux】:Redux 指北
Redux 是JavaScript 应用的状态管理容器,提供集中式、可预测的状态管理。
WEBJ2EE
2021/06/15
1.6K0
深入学习 Redux 之中间件与异步操作
上一节,学习了 Redux 的基本用法:用户发出 Action,Reducer 函数算出新的 State,View 重新渲染。
Leophen
2021/07/23
1.1K0
Redux 入门教程(二):中间件与异步操作
上一篇文章,我介绍了 Redux 的基本做法:用户发出 Action,Reducer 函数算出新的 State,View 重新渲染。 但是,一个关键问题没有解决:异步操作怎么办?Action 发出以后
ruanyf
2018/04/12
1.6K0
Redux 入门教程(二):中间件与异步操作
点击加载更多

相似问题

在Firefox上不起作用

10

在firefox上不起作用

11

print()在Firefox上不起作用

14

tinymce在firefox上不起作用

20

空格在Firefox上不起作用

10
添加站长 进交流群

领取专属 10元无门槛券

AI混元助手 在线答疑

扫码加入开发者社群
关注 腾讯云开发者公众号

洞察 腾讯核心技术

剖析业界实践案例

扫码关注腾讯云开发者公众号
领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档