Exemplo de um build.xml para um OUVIDO que implanta no WebSphere 6
-
08-06-2019 - |
Pergunta
Eu estou tentando convencer meus fornecedores para usar FORMIGA, em vez de Racional, o Desenvolvimento de Aplicativo para que qualquer pessoa pode recompilar, verifique novamente, reimplantar a solução de qualquer lugar, a qualquer hora, de qualquer maneira.:P
Eu comecei um build.xml para um projeto que gera um arquivo JAR, mas parou lá e eu preciso de exemplos reais para comparar as notas.Meus bons amigos!Eu não tenho alguém perto de conversar sobre isso!
Esta é a minha build.xml até agora.
(*) Eu editei a minha pergunta com base no sugestão de usar o pastebin.autoridade de certificação
Solução
Meu Ambiente:O Fedora 8;FOI de 6,1 (instalado com o Rational Application Developer 7)
A documentação é muito pobre nesta área e há uma escassez de exemplos práticos.
Utilizando o WebSphere Application Server (was) Ant tarefas
Para executar tal como descrito aqui, você precisa executá-los a partir de seu servidor perfil bin usando o ws_ant.sh ou ws_ant.bat comandos.
<?xml version="1.0"?>
<project name="project" default="wasListApps" basedir=".">
<description>
Script for listing installed apps.
Example run from:
/opt/IBM/SDP70/runtimes/base_v61/profiles/AppSrv01/bin
</description>
<property name="was_home"
value="/opt/IBM/SDP70/runtimes/base_v61/">
</property>
<path id="was.runtime">
<fileset dir="${was_home}/lib">
<include name="**/*.jar" />
</fileset>
<fileset dir="${was_home}/plugins">
<include name="**/*.jar" />
</fileset>
</path>
<property name="was_cp" value="${toString:was.runtime}"></property>
<property environment="env"></property>
<target name="wasListApps">
<taskdef name="wsListApp"
classname="com.ibm.websphere.ant.tasks.ListApplications"
classpath="${was_cp}">
</taskdef>
<wsListApp wasHome="${was_home}" />
</target>
</project>
Comando:
./ws_ant.sh -buildfile ~/IBM/rationalsdp7.0/workspace/mywebappDeploy/applist.xml
Um Script De Implantação
<?xml version="1.0"?>
<project name="project" default="default" basedir=".">
<description>
Build/Deploy an EAR to WebSphere Application Server 6.1
</description>
<property name="was_home" value="/opt/IBM/SDP70/runtimes/base_v61/" />
<path id="was.runtime">
<fileset dir="${was_home}/lib">
<include name="**/*.jar" />
</fileset>
<fileset dir="${was_home}/plugins">
<include name="**/*.jar" />
</fileset>
</path>
<property name="was_cp" value="${toString:was.runtime}" />
<property environment="env" />
<property name="ear" value="${env.HOME}/IBM/rationalsdp7.0/workspace/mywebappDeploy/mywebappEAR.ear" />
<target name="default" depends="deployEar">
</target>
<target name="generateWar" depends="compileWarClasses">
<jar destfile="mywebapp.war">
<fileset dir="../mywebapp/WebContent">
</fileset>
</jar>
</target>
<target name="compileWarClasses">
<echo message="was_cp=${was_cp}" />
<javac srcdir="../mywebapp/src" destdir="../mywebapp/WebContent/WEB-INF/classes" classpath="${was_cp}">
</javac>
</target>
<target name="generateEar" depends="generateWar">
<mkdir dir="./earbin/META-INF"/>
<move file="mywebapp.war" todir="./earbin" />
<copy file="../mywebappEAR/META-INF/application.xml" todir="./earbin/META-INF" />
<jar destfile="${ear}">
<fileset dir="./earbin" />
</jar>
</target>
<!-- http://publib.boulder.ibm.com/infocenter/wasinfo/v6r1/index.jsp?topic=/com.ibm.websphere.javadoc.doc/public_html/api/com/ibm/websphere/ant/tasks/package-summary.html -->
<target name="deployEar" depends="generateEar">
<taskdef name="wsInstallApp" classname="com.ibm.websphere.ant.tasks.InstallApplication" classpath="${was_cp}"/>
<wsInstallApp ear="${ear}"
failonerror="true"
debug="true"
taskname=""
washome="${was_home}" />
</target>
</project>
Notas:
- Você só pode executar esta vez!Você não pode instalar se o nome do app está em utilização - consulte outras tarefas como wsUninstallApp
- Provavelmente não iniciar o aplicativo ou
- Você precisa executar esse no servidor e o script é bastante frágil
Alternativas
Eu provavelmente usaria Java Management Extensions (JMX).Você poderia escrever um arquivo de upload servlet que aceita uma ORELHA e usa a implantação de MBeans para implantar o OUVIDO no servidor.Você só ia POSTAR o arquivo via HTTP.Para evitar quaisquer FOI API dependências no seu dev/build máquina e poderia ser independente de qualquer projeto.
Outras dicas
Aqui está um pouco da mesma funcionalidade, se você não tem o FOI ant tarefas disponíveis ou não quer correr was_ant.morcego.Isto baseia-se na wsadmin.bat existentes no caminho.
<property name="websphere.home.dir" value="${env.WS6_HOME}" />
<property name="was.server.name" value="server1" />
<property name="wsadmin.base.command" value="wsadmin.bat" />
<property name="ws.list.command" value="$AdminApp list" />
<property name="ws.install.command" value="$AdminApp install" />
<property name="ws.uninstall.command" value="$AdminApp uninstall" />
<property name="ws.save.command" value="$AdminConfig save" />
<property name="ws.setManager.command" value="set appManager [$AdminControl queryNames cell=${env.COMPUTERNAME}Node01Cell,node=${env.COMPUTERNAME}Node01,type=ApplicationManager,process=${was.server.name},*]" />
<property name="ws.startapp.command" value="$AdminControl invoke $appManager startApplication" />
<property name="ws.stopapp.command" value="$AdminControl invoke $appManager stopApplication" />
<property name="ws.conn.type" value="SOAP" />
<property name="ws.host.name" value="localhost" />
<property name="ws.port.name" value="8880" />
<property name="ws.user.name" value="username" />
<property name="ws.password.name" value="password" />
<property name="app.deployed.name" value="${artifact.filename}" />
<property name="app.contextroot.name" value="/${artifact.filename}" />
<target name="websphere-list-applications">
<exec dir="${websphere.home.dir}/bin" executable="${wsadmin.base.command}" output="waslist.txt" logError="true">
<arg line="-conntype ${ws.conn.type}" />
<arg line="-host ${ws.host.name}" />
<arg line="-port ${ws.port.name}" />
<arg line="-username ${ws.user.name}" />
<arg line="-password ${ws.password.name}" />
<arg line="-c" />
<arg value="${ws.list.command}" />
</exec>
</target>
<target name="websphere-install-application" depends="websphere-uninstall-application">
<exec executable="${websphere.home.dir}/bin/${wsadmin.base.command}" logError="true" outputproperty="websphere.install.output" failonerror="true">
<arg line="-conntype ${ws.conn.type}" />
<arg line="-host ${ws.host.name}" />
<arg line="-port ${ws.port.name}" />
<arg line="-username ${ws.user.name}" />
<arg line="-password ${ws.password.name}" />
<arg line="-c" />
<arg value="${ws.install.command} ${dist.dir}/${artifact.filename}.war {-appname ${app.deployed.name} -server ${was.server.name} -contextroot ${app.contextroot.name}}" />
<arg line="-c" />
<arg value="${ws.save.command}" />
<arg line="-c" />
<arg value="${ws.setManager.command}" />
<arg line="-c" />
<arg value="${ws.startapp.command} ${app.deployed.name}" />
<arg line="-c" />
<arg value="${ws.save.command}" />
</exec>
<echo message="${websphere.install.output}" />
</target>
<target name="websphere-uninstall-application">
<exec executable="${websphere.home.dir}/bin/${wsadmin.base.command}" logError="true" outputproperty="websphere.uninstall.output" failonerror="false">
<arg line="-conntype ${ws.conn.type}" />
<arg line="-host ${ws.host.name}" />
<arg line="-port ${ws.port.name}" />
<arg line="-username ${ws.user.name}" />
<arg line="-password ${ws.password.name}" />
<arg line="-c" />
<arg value="${ws.setManager.command}" />
<arg line="-c" />
<arg value="${ws.stopapp.command} ${app.deployed.name}" />
<arg line="-c" />
<arg value="${ws.save.command}" />
<arg line="-c" />
<arg value="${ws.uninstall.command} ${app.deployed.name}" />
<arg line="-c" />
<arg value="${ws.save.command}" />
</exec>
<echo message="${websphere.uninstall.output}" />
</target>
um bom ponto de partida, poderia ser esse o maven pluggin, não para usá-lo, ou talvez sim, mas isso maven é construir mais de formiga tarefa.Se você ver WAS5+Plugin+Mojo.zip\src\main\scripts\was5.build.xml
Ou como disse "McDowell", você pode usar "do WebSphere Application Server (was) Ant tarefas", mas diretamente como uma FORMIGA tarefa.
<path id="classpath">
<fileset file="com.ibm.websphere.v61_6.1.100.ws_runtime.jar"/>
</path>
<taskdef name="wsStartApp" classname="com.ibm.websphere.ant.tasks.StartApplication" classpathref="classpath" />
<taskdef name="wsStopApp" classname="com.ibm.websphere.ant.tasks.StopApplication" classpathref="classpath" />
<taskdef name="wsInstallApp" classname="com.ibm.websphere.ant.tasks.InstallApplication" classpathref="classpath" />
<taskdef name="wsUninstallApp" classname="com.ibm.websphere.ant.tasks.UninstallApplication" classpathref="classpath" />
<target name="startWebApp1" depends="installEar">
<wsStartApp wasHome="${wasHome.dir}"
application="${remoteAppName}"
server="${clusterServerName}"
conntype="${remoteProdConnType}"
host="${remoteProdHostName}"
port="${remoteProdPort}"
user="${remoteProdUserId}"
password="${remoteProdPassword}" />
</target>
<target name="stopWebApp1" depends="prepare">
<wsStopApp wasHome="${wasHome.dir}"
application="${remoteAppName}"
server="${clusterServerName}"
conntype="${remoteConnType}"
host="${remoteHostName}"
port="${remotePort}"
user="${remoteUserId}"
password="${remotePassword}"/>
</target>
<target name="uninstallEar" depends="stopWebApp1">
<wsUninstallApp wasHome="${wasHome.dir}"
application="${remoteAppName}"
options="-cell uatNetwork -cluster DOL"
conntype="${remoteConnType}"
host="${remoteHostName}"
port="${remoteDmgrPort}"
user="${remoteUserId}"
password="${remotePassword}"/>
</target>
<target name="installEar" depends="prepare">
<wsInstallApp ear="${existingEar.dir}/${existingEar}"
wasHome="${wasHome.dir}"
options="${install_app_options}"
conntype="${remoteConnType}"
host="${remoteHostName}"
port="${remoteDmgrPort}"
user="${remoteUserId}"
password="${remotePassword}" />
</target>
Outro link útil poderia ser este.
Se você só quer brincar, por que não usar o netbeans IDE para gerar seu ouvido arquivos.Se você criar um projeto de empresa irá gerar automaticamente a formiga arquivos para você.Bom para prototipagem e apenas começando :-)
Há até mesmo um plugin que permite a implantação automatizada no entanto, este parece muito shakey!