Hadoop1.1.2 Eclipse 插件编译
可以直接下载我编译好的插件 hadoop-eclipse-plugin-1.1.2 http://download.csdn.net/detail/wind520/5784389 1:方法一: copy src\contrib\build-contrib.xml 到src\contrib\eclipse-plugin目录下,然后修改 ?xml version=1.0?!-- Licensed to the Apache S
可以直接下载我编译好的插件
hadoop-eclipse-plugin-1.1.2
http://download.csdn.net/detail/wind520/5784389
1:方法一:
copy src\contrib\build-contrib.xml 到src\contrib\eclipse-plugin目录下,然后修改
<?xml version="1.0"?> <!-- Licensed to the Apache Software Foundation (ASF) under one or more contributor license agreements. See the NOTICE file distributed with this work for additional information regarding copyright ownership. The ASF licenses this file to You under the Apache License, Version 2.0 (the "License"); you may not use this file except in compliance with the License. You may obtain a copy of the License at http://www.apache.org/licenses/LICENSE-2.0 Unless required by applicable law or agreed to in writing, software distributed under the License is distributed on an "AS IS" BASIS, WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. See the License for the specific language governing permissions and limitations under the License. --> <!-- Imported by contrib/*/build.xml files to share generic targets. --> <project name="hadoopbuildcontrib" xmlns:ivy="antlib:org.apache.ivy.ant"> <property name="name" value="${ant.project.name}"></property> <property name="eclipse.home" location="D:/oracle/get/eclipse"></property> <property name="version" value="1.1.2"></property> <property name="root" value="${basedir}"></property> <property name="hadoop.root" location="${root}/../../../"></property> <!-- Load all the default properties, and any the user wants --> <!-- to contribute (without having to type -D or edit this file --> <property file="${user.home}/${name}.build.properties"></property> <property file="${root}/build.properties"></property> <property file="${hadoop.root}/build.properties"></property> <property name="src.dir" location="${root}/src/java"></property> <property name="src.test" location="${root}/src/test"></property> <property name="src.test.data" location="${root}/src/test/data"></property> <!-- Property added for contrib system tests --> <property name="build-fi.dir" location="${hadoop.root}/build-fi"></property> <property name="system-test-build-dir" location="${build-fi.dir}/system"></property> <property name="src.test.system" location="${root}/src/test/system"></property> <property name="src.examples" location="${root}/src/examples"></property> <available file="${src.examples}" type="dir" property="examples.available"></available> <available file="${src.test}" type="dir" property="test.available"></available> <!-- Property added for contrib system tests --> <available file="${src.test.system}" type="dir" property="test.system.available"></available> <property name="conf.dir" location="${hadoop.root}/conf"></property> <property name="test.junit.output.format" value="plain"></property> <property name="test.output" value="no"></property> <property name="test.timeout" value="900000"></property> <property name="build.contrib.dir" location="${hadoop.root}/build/contrib"></property> <property name="build.dir" location="${hadoop.root}/build/contrib/${name}"></property> <property name="build.classes" location="${build.dir}/classes"></property> <property name="build.test" location="${build.dir}/test"></property> <property name="build.examples" location="${build.dir}/examples"></property> <property name="hadoop.log.dir" location="${build.dir}/test/logs"></property> <!-- all jars together --> <property name="javac.deprecation" value="off"></property> <property name="javac.debug" value="on"></property> <property name="build.ivy.lib.dir" value="${hadoop.root}/build/ivy/lib"></property> <property name="javadoc.link" value="http://java.sun.com/j2se/1.4/docs/api/"></property> <property name="build.encoding" value="ISO-8859-1"></property> <fileset id="lib.jars" dir="${root}" includes="lib/*.jar"></fileset> <!-- Property added for contrib system tests --> <property name="build.test.system" location="${build.dir}/system"></property> <property name="build.system.classes" location="${build.test.system}/classes"></property> <!-- IVY properties set here --> <property name="ivy.dir" location="ivy"></property> <property name="ivysettings.xml" location="${hadoop.root}/ivy/ivysettings.xml"></property> <loadproperties srcfile="${ivy.dir}/libraries.properties"></loadproperties> <loadproperties srcfile="${hadoop.root}/ivy/libraries.properties"></loadproperties> <property name="ivy.jar" location="${hadoop.root}/ivy/ivy-${ivy.version}.jar"></property> <property name="ivy_repo_url" value="http://repo2.maven.org/maven2/org/apache/ivy/ivy/${ivy.version}/ivy-${ivy.version}.jar"></property> <property name="build.dir" location="build"></property> <property name="build.ivy.dir" location="${build.dir}/ivy"></property> <property name="build.ivy.lib.dir" location="${build.ivy.dir}/lib"></property> <property name="build.ivy.report.dir" location="${build.ivy.dir}/report"></property> <property name="common.ivy.lib.dir" location="${build.ivy.lib.dir}/${ant.project.name}/common"></property> <!--this is the naming policy for artifacts we want pulled down--> <property name="ivy.artifact.retrieve.pattern" value="${ant.project.name}/[conf]/[artifact]-[revision].[ext]"></property> <!-- the normal classpath --> <path id="contrib-classpath"> <pathelement location="${build.classes}"></pathelement> <pathelement location="${hadoop.root}/build/tools"></pathelement> <fileset refid="lib.jars"></fileset> <pathelement location="${hadoop.root}/build/classes"></pathelement> <fileset dir="${hadoop.root}/lib"> <include name="**/*.jar"></include> </fileset> <path refid="${ant.project.name}.common-classpath"></path> <pathelement path="${clover.jar}"></pathelement> </path> <!-- the unit test classpath --> <path id="test.classpath"> <pathelement location="${build.test}"></pathelement> <pathelement location="${hadoop.root}/build/test/classes"></pathelement> <pathelement location="${hadoop.root}/src/contrib/test"></pathelement> <pathelement location="${conf.dir}"></pathelement> <pathelement location="${hadoop.root}/build"></pathelement> <pathelement location="${build.examples}"></pathelement> <pathelement location="${hadoop.root}/build/examples"></pathelement> <path refid="contrib-classpath"></path> </path> <!-- The system test classpath --> <path id="test.system.classpath"> <pathelement location="${hadoop.root}/src/contrib/${name}/src/test/system"></pathelement> <pathelement location="${build.test.system}"></pathelement> <pathelement location="${build.test.system}/classes"></pathelement> <pathelement location="${build.examples}"></pathelement> <pathelement location="${hadoop.root}/build-fi/system/classes"></pathelement> <pathelement location="${hadoop.root}/build-fi/system/test/classes"></pathelement> <pathelement location="${hadoop.root}/build-fi"></pathelement> <pathelement location="${hadoop.root}/build-fi/tools"></pathelement> <pathelement location="${hadoop.home}"></pathelement> <pathelement location="${hadoop.conf.dir}"></pathelement> <pathelement location="${hadoop.conf.dir.deployed}"></pathelement> <pathelement location="${hadoop.root}/build"></pathelement> <pathelement location="${hadoop.root}/build/examples"></pathelement> <pathelement location="${hadoop.root}/build-fi/test/classes"></pathelement> <path refid="contrib-classpath"></path> <fileset dir="${hadoop.root}/src/test/lib"> <include name="**/*.jar"></include> <exclude name="**/excluded/"></exclude> </fileset> <fileset dir="${hadoop.root}/build-fi/system"> <include name="**/*.jar"></include> <exclude name="**/excluded/"></exclude> </fileset> <fileset dir="${hadoop.root}/build-fi/test/testjar"> <include name="**/*.jar"></include> <exclude name="**/excluded/"></exclude> </fileset> <fileset dir="${hadoop.root}/build/contrib/${name}"> <include name="**/*.jar"></include> <exclude name="**/excluded/"></exclude> </fileset> </path> <!-- to be overridden by sub-projects --> <target name="check-contrib"></target> <target name="init-contrib"></target> <!-- ====================================================== --> <!-- Stuff needed by all targets --> <!-- ====================================================== --> <target name="init" depends="check-contrib" unless="skip.contrib"> <echo message="contrib: ${name}"></echo> <mkdir dir="${build.dir}"></mkdir> <mkdir dir="${build.classes}"></mkdir> <mkdir dir="${build.test}"></mkdir> <!-- The below two tags added for contrib system tests --> <mkdir dir="${build.test.system}"></mkdir> <mkdir dir="${build.system.classes}"></mkdir> <mkdir dir="${build.examples}"></mkdir> <mkdir dir="${hadoop.log.dir}"></mkdir> <antcall target="init-contrib"></antcall> </target> <!-- ====================================================== --> <!-- Compile a Hadoop contrib's files --> <!-- ====================================================== --> <target name="compile" depends="init, ivy-retrieve-common" unless="skip.contrib"> <echo message="contrib: ${name}"></echo> <javac encoding="${build.encoding}" srcdir="${src.dir}" includes="**/*.java" destdir="${build.classes}" debug="${javac.debug}" deprecation="${javac.deprecation}"> <classpath refid="contrib-classpath"></classpath> </javac> </target> <!-- ======================================================= --> <!-- Compile a Hadoop contrib's example files (if available) --> <!-- ======================================================= --> <target name="compile-examples" depends="compile" if="examples.available"> <echo message="contrib: ${name}"></echo> <javac encoding="${build.encoding}" srcdir="${src.examples}" includes="**/*.java" destdir="${build.examples}" debug="${javac.debug}"> <classpath refid="contrib-classpath"></classpath> </javac> </target> <!-- ================================================================== --> <!-- Compile test code --> <!-- ================================================================== --> <target name="compile-test" depends="compile-examples" if="test.available"> <echo message="contrib: ${name}"></echo> <javac encoding="${build.encoding}" srcdir="${src.test}" includes="**/*.java" excludes="system/**/*.java" destdir="${build.test}" debug="${javac.debug}"> <classpath refid="test.classpath"></classpath> </javac> </target> <!-- ================================================================== --> <!-- Compile system test code --> <!-- ================================================================== --> <target name="compile-test-system" depends="compile-examples" if="test.system.available"> <echo message="contrib: ${name}"></echo> <javac encoding="${build.encoding}" srcdir="${src.test.system}" includes="**/*.java" destdir="${build.system.classes}" debug="${javac.debug}"> <classpath refid="test.system.classpath"></classpath> </javac> </target> <!-- ====================================================== --> <!-- Make a Hadoop contrib's jar --> <!-- ====================================================== --> <target name="jar" depends="compile" unless="skip.contrib"> <echo message="contrib: ${name}"></echo> <jar jarfile="${build.dir}/hadoop-${name}-${version}.jar" basedir="${build.classes}"></jar> </target> <!-- ====================================================== --> <!-- Make a Hadoop contrib's examples jar --> <!-- ====================================================== --> <target name="jar-examples" depends="compile-examples" if="examples.available" unless="skip.contrib"> <echo message="contrib: ${name}"></echo> <jar jarfile="${build.dir}/hadoop-${name}-examples-${version}.jar"> <fileset dir="${build.classes}"> </fileset> <fileset dir="${build.examples}"> </fileset> </jar> </target> <!-- ====================================================== --> <!-- Package a Hadoop contrib --> <!-- ====================================================== --> <target name="package" depends="jar, jar-examples" unless="skip.contrib"> <mkdir dir="${dist.dir}/contrib/${name}"></mkdir> <copy todir="${dist.dir}/contrib/${name}" includeemptydirs="false" flatten="true"> <fileset dir="${build.dir}"> <include name="hadoop-${name}-${version}.jar"></include> </fileset> </copy> </target> <!-- ================================================================== --> <!-- Run unit tests --> <!-- ================================================================== --> <target name="test" depends="compile-test, compile" if="test.available"> <echo message="contrib: ${name}"></echo> <delete dir="${hadoop.log.dir}"></delete> <mkdir dir="${hadoop.log.dir}"></mkdir> <junit printsummary="yes" showoutput="${test.output}" haltonfailure="no" fork="yes" maxmemory="512m" errorproperty="tests.failed" failureproperty="tests.failed" timeout="${test.timeout}"> <sysproperty key="test.build.data" value="${build.test}/data"></sysproperty> <sysproperty key="build.test" value="${build.test}"></sysproperty> <sysproperty key="src.test.data" value="${src.test.data}"></sysproperty> <sysproperty key="contrib.name" value="${name}"></sysproperty> <!-- requires fork=yes for: relative File paths to use the specified user.dir classpath to use build/contrib/*.jar --> <sysproperty key="user.dir" value="${build.test}/data"></sysproperty> <sysproperty key="fs.default.name" value="${fs.default.name}"></sysproperty> <sysproperty key="hadoop.test.localoutputfile" value="${hadoop.test.localoutputfile}"></sysproperty> <sysproperty key="hadoop.log.dir" value="${hadoop.log.dir}"></sysproperty> <sysproperty key="taskcontroller-path" value="${taskcontroller-path}"></sysproperty> <sysproperty key="taskcontroller-ugi" value="${taskcontroller-ugi}"></sysproperty> <classpath refid="test.classpath"></classpath> <formatter type="${test.junit.output.format}"></formatter> <batchtest todir="${build.test}" unless="testcase"> <fileset dir="${src.test}" includes="**/Test*.java" excludes="**/${test.exclude}.java, system/**/*.java"></fileset> </batchtest> <batchtest todir="${build.test}" if="testcase"> <fileset dir="${src.test}" includes="**/${testcase}.java" excludes="system/**/*.java"></fileset> </batchtest> </junit> <antcall target="checkfailure"></antcall> </target> <!-- ================================================================== --> <!-- Run system tests --> <!-- ================================================================== --> <target name="test-system" depends="compile, compile-test-system, jar" if="test.system.available"> <delete dir="${build.test.system}/extraconf"></delete> <mkdir dir="${build.test.system}/extraconf"></mkdir> <property name="test.src.dir" location="${hadoop.root}/src/test"></property> <property name="test.junit.printsummary" value="yes"></property> <property name="test.junit.haltonfailure" value="no"></property> <property name="test.junit.maxmemory" value="512m"></property> <property name="test.junit.fork.mode" value="perTest"></property> <property name="test.all.tests.file" value="${test.src.dir}/all-tests"></property> <property name="test.build.dir" value="${hadoop.root}/build/test"></property> <property name="basedir" value="${hadoop.root}"></property> <property name="test.timeout" value="900000"></property> <property name="test.junit.output.format" value="plain"></property> <property name="test.tools.input.dir" value="${basedir}/src/test/tools/data"></property> <property name="c++.src" value="${basedir}/src/c++"></property> <property name="test.include" value="Test*"></property> <property name="c++.libhdfs.src" value="${c++.src}/libhdfs"></property> <property name="test.build.data" value="${build.test.system}/data"></property> <property name="test.cache.data" value="${build.test.system}/cache"></property> <property name="test.debug.data" value="${build.test.system}/debug"></property> <property name="test.log.dir" value="${build.test.system}/logs"></property> <patternset id="empty.exclude.list.id"></patternset> <exec executable="sed" inputstring="${os.name}" outputproperty="nonspace.os"> <arg value="s/ /_/g"></arg> </exec> <property name="build.platform" value="${nonspace.os}-${os.arch}-${sun.arch.data.model}"></property> <property name="build.native" value="${hadoop.root}/build/native/${build.platform}"></property> <property name="lib.dir" value="${hadoop.root}/lib"></property> <property name="install.c++.examples" value="${hadoop.root}/build/c++-examples/${build.platform}"></property> <condition property="tests.testcase"> <and> <isset property="testcase"></isset> </and> </condition> <property name="test.junit.jvmargs" value="-ea"></property> <macro-system-test-runner test.file="${test.all.tests.file}" classpath="test.system.classpath" test.dir="${build.test.system}" fileset.dir="${hadoop.root}/src/contrib/${name}/src/test/system" hadoop.conf.dir.deployed="${hadoop.conf.dir.deployed}"> </macro-system-test-runner> </target> <macrodef name="macro-system-test-runner"> <attribute name="test.file"></attribute> <attribute name="classpath"></attribute> <attribute name="test.dir"></attribute> <attribute name="fileset.dir"></attribute> <attribute name="hadoop.conf.dir.deployed" default=""></attribute> <sequential> <delete dir="@{test.dir}/data"></delete> <mkdir dir="@{test.dir}/data"></mkdir> <delete dir="@{test.dir}/logs"></delete> <mkdir dir="@{test.dir}/logs"></mkdir> <copy file="${test.src.dir}/hadoop-policy.xml" todir="@{test.dir}/extraconf"></copy> <copy file="${test.src.dir}/fi-site.xml" todir="@{test.dir}/extraconf"></copy> <junit showoutput="${test.output}" printsummary="${test.junit.printsummary}" haltonfailure="${test.junit.haltonfailure}" fork="yes" forkmode="${test.junit.fork.mode}" maxmemory="${test.junit.maxmemory}" dir="${basedir}" timeout="${test.timeout}" errorproperty="tests.failed" failureproperty="tests.failed"> <jvmarg value="${test.junit.jvmargs}"></jvmarg> <sysproperty key="java.net.preferIPv4Stack" value="true"></sysproperty> <sysproperty key="test.build.data" value="@{test.dir}/data"></sysproperty> <sysproperty key="test.tools.input.dir" value="${test.tools.input.dir}"></sysproperty> <sysproperty key="test.cache.data" value="${test.cache.data}"></sysproperty> <sysproperty key="test.debug.data" value="${test.debug.data}"></sysproperty> <sysproperty key="hadoop.log.dir" value="@{test.dir}/logs"></sysproperty> <sysproperty key="test.src.dir" value="@{fileset.dir}"></sysproperty> <sysproperty key="taskcontroller-path" value="${taskcontroller-path}"></sysproperty> <sysproperty key="taskcontroller-ugi" value="${taskcontroller-ugi}"></sysproperty> <sysproperty key="test.build.extraconf" value="@{test.dir}/extraconf"></sysproperty> <sysproperty key="hadoop.policy.file" value="hadoop-policy.xml"></sysproperty> <sysproperty key="java.library.path" value="${build.native}/lib:${lib.dir}/native/${build.platform}"></sysproperty> <sysproperty key="install.c++.examples" value="${install.c++.examples}"></sysproperty> <syspropertyset dynamic="no"> <propertyref name="hadoop.tmp.dir"></propertyref> </syspropertyset> <!-- set compile.c++ in the child jvm only if it is set --> <syspropertyset dynamic="no"> <propertyref name="compile.c++"></propertyref> </syspropertyset> <!-- Pass probability specifications to the spawn JVM --> <syspropertyset id="FaultProbabilityProperties"> <propertyref regex="fi.*"></propertyref> </syspropertyset> <sysproperty key="test.system.hdrc.deployed.hadoopconfdir" value="@{hadoop.conf.dir.deployed}"></sysproperty> <classpath refid="@{classpath}"></classpath> <formatter type="${test.junit.output.format}"></formatter> <batchtest todir="@{test.dir}" unless="testcase"> <fileset dir="@{fileset.dir}" excludes="**/${test.exclude}.java aop/** system/**"> <patternset> <includesfile name="@{test.file}"></includesfile> </patternset> </fileset> </batchtest> <batchtest todir="@{test.dir}" if="testcase"> <fileset dir="@{fileset.dir}" includes="**/${testcase}.java"></fileset> </batchtest> </junit> <antcall target="checkfailure"></antcall> </sequential> </macrodef> <target name="checkfailure" if="tests.failed"> <touch file="${build.contrib.dir}/testsfailed"></touch> <fail unless="continueOnFailure">Contrib Tests failed!</fail> </target> <!-- ================================================================== --> <!-- Clean. Delete the build files, and their directories --> <!-- ================================================================== --> <target name="clean"> <echo message="contrib: ${name}"></echo> <delete dir="${build.dir}"></delete> </target> <target name="ivy-probe-antlib"> <condition property="ivy.found"> <typefound uri="antlib:org.apache.ivy.ant" name="cleancache"></typefound> </condition> </target> <target name="ivy-download" description="To download ivy " unless="offline"> <get src="%24%7Bivy_repo_url%7D" dest="${ivy.jar}" usetimestamp="true"></get> </target> <target name="ivy-init-antlib" depends="ivy-download,ivy-probe-antlib" unless="ivy.found"> <typedef uri="antlib:org.apache.ivy.ant" onerror="fail" loaderref="ivyLoader"> <classpath> <pathelement location="${ivy.jar}"></pathelement> </classpath> </typedef> <fail> <condition> <not> <typefound uri="antlib:org.apache.ivy.ant" name="cleancache"></typefound> </not> </condition> You need Apache Ivy 2.0 or later from http://ant.apache.org/ It could not be loaded from ${ivy_repo_url} </fail> </target> <target name="ivy-init" depends="ivy-init-antlib"> <configure settingsid="${ant.project.name}.ivy.settings" file="${ivysettings.xml}"></configure> </target> <target name="ivy-resolve-common" depends="ivy-init"> <resolve settingsref="${ant.project.name}.ivy.settings" conf="common"></resolve> </target> <target name="ivy-retrieve-common" depends="ivy-resolve-common" description="Retrieve Ivy-managed artifacts for the compile/test configurations"> <retrieve settingsref="${ant.project.name}.ivy.settings" pattern="${build.ivy.lib.dir}/${ivy.artifact.retrieve.pattern}" sync="true"></retrieve> <cachepath pathid="${ant.project.name}.common-classpath" conf="common"></cachepath> </target> </project>
修改 eclipse-plugin目录下的build.xml 文件
<?xml version="1.0" encoding="UTF-8" standalone="no"?> <!-- Licensed to the Apache Software Foundation (ASF) under one or more contributor license agreements. See the NOTICE file distributed with this work for additional information regarding copyright ownership. The ASF licenses this file to You under the Apache License, Version 2.0 (the "License"); you may not use this file except in compliance with the License. You may obtain a copy of the License at http://www.apache.org/licenses/LICENSE-2.0 Unless required by applicable law or agreed to in writing, software distributed under the License is distributed on an "AS IS" BASIS, WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. See the License for the specific language governing permissions and limitations under the License. --> <project default="jar" name="eclipse-plugin"> <import file="build-contrib.xml"></import> <path id="eclipse-sdk-jars"> <fileset dir="${eclipse.home}/plugins/"> <include name="org.eclipse.ui*.jar"></include> <include name="org.eclipse.jdt*.jar"></include> <include name="org.eclipse.core*.jar"></include> <include name="org.eclipse.equinox*.jar"></include> <include name="org.eclipse.debug*.jar"></include> <include name="org.eclipse.osgi*.jar"></include> <include name="org.eclipse.swt*.jar"></include> <include name="org.eclipse.jface*.jar"></include> <include name="org.eclipse.team.cvs.ssh2*.jar"></include> <include name="com.jcraft.jsch*.jar"></include> </fileset> </path> <!-- Override classpath to include Eclipse SDK jars --> <path id="classpath"> <pathelement location="${build.classes}"></pathelement> <pathelement location="${hadoop.root}/hadoop-core-1.1.2.jar"></pathelement> <pathelement location="${hadoop.root}/build/classes"></pathelement> <path refid="eclipse-sdk-jars"></path> </path> <!-- Skip building if eclipse.home is unset. --> <target name="check-contrib" unless="eclipse.home"> <property name="skip.contrib" value="yes"></property> <echo message="eclipse.home unset: skipping eclipse plugin"></echo> </target> <target name="compile" depends="init, ivy-retrieve-common" unless="skip.contrib"> <echo message="contrib: ${name}"></echo> <javac encoding="${build.encoding}" srcdir="${src.dir}" includes="**/*.java" destdir="${build.classes}" debug="${javac.debug}" deprecation="${javac.deprecation}"> <classpath refid="classpath"></classpath> </javac> </target> <!-- Override jar target to specify manifest --> <target name="jar" depends="compile" unless="skip.contrib"> <mkdir dir="${build.dir}/lib"></mkdir> <copy file="${hadoop.root}/hadoop-core-${version}.jar" tofile="${build.dir}/lib/hadoop-core.jar" verbose="true"></copy> <copy file="${hadoop.root}/lib/commons-cli-1.2.jar" todir="${build.dir}/lib" verbose="true"></copy> <copy file="${hadoop.root}/lib/commons-configuration-1.6.jar" todir="${build.dir}/lib" verbose="true"></copy> <copy file="${hadoop.root}/lib/commons-httpclient-3.0.1.jar" todir="${build.dir}/lib" verbose="true"></copy> <copy file="${hadoop.root}/lib/jackson-core-asl-1.8.8.jar" todir="${build.dir}/lib" verbose="true"></copy> <copy file="${hadoop.root}/lib/commons-lang-2.4.jar" todir="${build.dir}/lib" verbose="true"></copy> <copy file="${hadoop.root}/lib/jackson-mapper-asl-1.8.8.jar" todir="${build.dir}/lib" verbose="true"></copy> <jar jarfile="${build.dir}/hadoop-${name}-${version}.jar" manifest="${root}/META-INF/MANIFEST.MF"> <fileset dir="${build.dir}" includes="classes/ lib/"></fileset> <fileset dir="${root}" includes="resources/ plugin.xml"></fileset> </jar> </target> </project>
修改src\contrib\eclipse-plugin\META-INF下的MANIFEST.MF
Manifest-Version: 1.0 Bundle-ManifestVersion: 2 Bundle-Name: MapReduce Tools for Eclipse Bundle-SymbolicName: org.apache.hadoop.eclipse;singleton:=true Bundle-Version: 0.18 Bundle-Activator: org.apache.hadoop.eclipse.Activator Bundle-Localization: plugin Require-Bundle: org.eclipse.ui, org.eclipse.core.runtime, org.eclipse.jdt.launching, org.eclipse.debug.core, org.eclipse.jdt, org.eclipse.jdt.core, org.eclipse.core.resources, org.eclipse.ui.ide, org.eclipse.jdt.ui, org.eclipse.debug.ui, org.eclipse.jdt.debug.ui, org.eclipse.core.expressions, org.eclipse.ui.cheatsheets, org.eclipse.ui.console, org.eclipse.ui.navigator, org.eclipse.core.filesystem, org.apache.commons.logging Eclipse-LazyStart: true Bundle-ClassPath: classes/,lib/hadoop-core.jar,lib/commons-cli-1.2.jar,lib/commons-configuration-1.6.jar,lib/commons-httpclient-3.0.1.jar,lib/commons-lang-2.4.jar,lib/jackson-core-asl-1.8.8.jar,lib/jackson-mapper-asl-1.8.8.jar Bundle-Vendor: Apache Hadoop
编译:
Buildfile: E:\big\Hadoop\hadoop-1.1.2\src\contrib\eclipse-plugin\build.xml check-contrib: init: [echo] contrib: eclipse-plugin [mkdir] Created dir: E:\big\Hadoop\hadoop-1.1.2\build\contrib\eclipse-plugin [mkdir] Created dir: E:\big\Hadoop\hadoop-1.1.2\build\contrib\eclipse-plugin\classes [mkdir] Created dir: E:\big\Hadoop\hadoop-1.1.2\build\contrib\eclipse-plugin\test [mkdir] Created dir: E:\big\Hadoop\hadoop-1.1.2\build\contrib\eclipse-plugin\system [mkdir] Created dir: E:\big\Hadoop\hadoop-1.1.2\build\contrib\eclipse-plugin\system\classes [mkdir] Created dir: E:\big\Hadoop\hadoop-1.1.2\build\contrib\eclipse-plugin\examples [mkdir] Created dir: E:\big\Hadoop\hadoop-1.1.2\build\contrib\eclipse-plugin\test\logs init-contrib: ivy-download: [get] Getting: http://repo2.maven.org/maven2/org/apache/ivy/ivy/2.1.0/ivy-2.1.0.jar [get] To: E:\big\Hadoop\hadoop-1.1.2\ivy\ivy-2.1.0.jar [get] Not modified - so not downloaded ivy-probe-antlib: ivy-init-antlib: ivy-init: [ivy:configure] :: Ivy 2.1.0 - 20090925235825 :: http://ant.apache.org/ivy/ :: [ivy:configure] :: loading settings :: file = E:\big\Hadoop\hadoop-1.1.2\ivy\ivysettings.xml ivy-resolve-common: [ivy:resolve] :: resolving dependencies :: org.apache.hadoop#eclipse-plugin;working@lenovo-PC [ivy:resolve] confs: [common] [ivy:resolve] found commons-logging#commons-logging;1.0.4 in maven2 [ivy:resolve] found log4j#log4j;1.2.15 in maven2 [ivy:resolve] :: resolution report :: resolve 335ms :: artifacts dl 8ms --------------------------------------------------------------------- | | modules || artifacts | | conf | number| search|dwnlded|evicted|| number|dwnlded| --------------------------------------------------------------------- | common | 2 | 0 | 0 | 0 || 2 | 0 | --------------------------------------------------------------------- ivy-retrieve-common: [ivy:retrieve] :: retrieving :: org.apache.hadoop#eclipse-plugin [sync] [ivy:retrieve] confs: [common] [ivy:retrieve] 2 artifacts copied, 0 already retrieved (419kB/114ms) [ivy:cachepath] DEPRECATED: 'ivy.conf.file' is deprecated, use 'ivy.settings.file' instead [ivy:cachepath] :: loading settings :: file = E:\big\Hadoop\hadoop-1.1.2\ivy\ivysettings.xml compile: [echo] contrib: eclipse-plugin [javac] E:\big\Hadoop\hadoop-1.1.2\src\contrib\eclipse-plugin\build.xml:62: warning: 'includeantruntime' was not set, defaulting to build.sysclasspath=last; set to false for repeatable builds [javac] Compiling 45 source files to E:\big\Hadoop\hadoop-1.1.2\build\contrib\eclipse-plugin\classes [javac] 注意:某些输入文件使用或覆盖了已过时的 API。 [javac] 注意:要了解详细信息,请使用 -Xlint:deprecation 重新编译。 [javac] 注意:某些输入文件使用了未经检查或不安全的操作。 [javac] 注意:要了解详细信息,请使用 -Xlint:unchecked 重新编译。 jar: [mkdir] Created dir: E:\big\Hadoop\hadoop-1.1.2\build\contrib\eclipse-plugin\lib [copy] Copying 1 file to E:\big\Hadoop\hadoop-1.1.2\build\contrib\eclipse-plugin\lib [copy] Copying E:\big\Hadoop\hadoop-1.1.2\hadoop-core-1.1.2.jar to E:\big\Hadoop\hadoop-1.1.2\build\contrib\eclipse-plugin\lib\hadoop-core.jar [copy] Copying 1 file to E:\big\Hadoop\hadoop-1.1.2\build\contrib\eclipse-plugin\lib [copy] Copying E:\big\Hadoop\hadoop-1.1.2\lib\commons-cli-1.2.jar to E:\big\Hadoop\hadoop-1.1.2\build\contrib\eclipse-plugin\lib\commons-cli-1.2.jar [copy] Copying 1 file to E:\big\Hadoop\hadoop-1.1.2\build\contrib\eclipse-plugin\lib [copy] Copying E:\big\Hadoop\hadoop-1.1.2\lib\commons-configuration-1.6.jar to E:\big\Hadoop\hadoop-1.1.2\build\contrib\eclipse-plugin\lib\commons-configuration-1.6.jar [copy] Copying 1 file to E:\big\Hadoop\hadoop-1.1.2\build\contrib\eclipse-plugin\lib [copy] Copying E:\big\Hadoop\hadoop-1.1.2\lib\commons-httpclient-3.0.1.jar to E:\big\Hadoop\hadoop-1.1.2\build\contrib\eclipse-plugin\lib\commons-httpclient-3.0.1.jar [copy] Copying 1 file to E:\big\Hadoop\hadoop-1.1.2\build\contrib\eclipse-plugin\lib [copy] Copying E:\big\Hadoop\hadoop-1.1.2\lib\jackson-core-asl-1.8.8.jar to E:\big\Hadoop\hadoop-1.1.2\build\contrib\eclipse-plugin\lib\jackson-core-asl-1.8.8.jar [copy] Copying 1 file to E:\big\Hadoop\hadoop-1.1.2\build\contrib\eclipse-plugin\lib [copy] Copying E:\big\Hadoop\hadoop-1.1.2\lib\commons-lang-2.4.jar to E:\big\Hadoop\hadoop-1.1.2\build\contrib\eclipse-plugin\lib\commons-lang-2.4.jar [copy] Copying 1 file to E:\big\Hadoop\hadoop-1.1.2\build\contrib\eclipse-plugin\lib [copy] Copying E:\big\Hadoop\hadoop-1.1.2\lib\jackson-mapper-asl-1.8.8.jar to E:\big\Hadoop\hadoop-1.1.2\build\contrib\eclipse-plugin\lib\jackson-mapper-asl-1.8.8.jar [jar] Building jar: E:\big\Hadoop\hadoop-1.1.2\build\contrib\eclipse-plugin\hadoop-eclipse-plugin-1.1.2.jar BUILD SUCCESSFUL Total time: 10 seconds
方法2:
修改 eclipse-plugin目录下的build.xml 文件
<?xml version="1.0" encoding="UTF-8" standalone="no"?> <project default="jar" name="eclipse-plugin"> <property name="name" value="${ant.project.name}"></property> <property name="root" value="${basedir}"></property> <property name="hadoop.root" location="E:/big/Hadoop/hadoop-1.1.2"></property> <property name="version" value="1.1.2"></property> <property name="eclipse.home" location="D:/oracle/get/eclipse"></property> <property name="build.dir" location="${hadoop.root}/build/contrib/${name}"></property> <property name="build.classes" location="${build.dir}/classes"></property> <property name="src.dir" location="${root}/src/java"></property> <path id="eclipse-sdk-jars"> <fileset dir="${eclipse.home}/plugins/"> <include name="org.eclipse.ui*.jar"></include> <include name="org.eclipse.jdt*.jar"></include> <include name="org.eclipse.core*.jar"></include> <include name="org.eclipse.equinox*.jar"></include> <include name="org.eclipse.debug*.jar"></include> <include name="org.eclipse.osgi*.jar"></include> <include name="org.eclipse.swt*.jar"></include> <include name="org.eclipse.jface*.jar"></include> <include name="org.eclipse.team.cvs.ssh2*.jar"></include> <include name="com.jcraft.jsch*.jar"></include> </fileset> </path> <!-- Override classpath to include Eclipse SDK jars --> <path id="classpath"> <fileset dir="${hadoop.root}"> <include name="*.jar"></include> </fileset> <path refid="eclipse-sdk-jars"></path> </path> <target name="compile"> <mkdir dir="${build.dir}/classes"></mkdir> <javac encoding="ISO-8859-1" srcdir="${src.dir}" includes="**/*.java" destdir="${build.classes}" debug="on" deprecation="off"> <classpath refid="classpath"></classpath> </javac> </target> <!-- Override jar target to specify manifest--> <target name="jar" depends="compile"> <mkdir dir="${build.dir}/lib"></mkdir> <copy file="${hadoop.root}/hadoop-core-${version}.jar" tofile="${build.dir}/lib/hadoop-core.jar" verbose="true"></copy> <copy file="${hadoop.root}/lib/commons-cli-1.2.jar" todir="${build.dir}/lib" verbose="true"></copy> <copy file="${hadoop.root}/lib/commons-configuration-1.6.jar" todir="${build.dir}/lib" verbose="true"></copy> <copy file="${hadoop.root}/lib/commons-httpclient-3.0.1.jar" todir="${build.dir}/lib" verbose="true"></copy> <copy file="${hadoop.root}/lib/jackson-core-asl-1.8.8.jar" todir="${build.dir}/lib" verbose="true"></copy> <copy file="${hadoop.root}/lib/commons-lang-2.4.jar" todir="${build.dir}/lib" verbose="true"></copy> <copy file="${hadoop.root}/lib/jackson-mapper-asl-1.8.8.jar" todir="${build.dir}/lib" verbose="true"></copy> <jar jarfile="${build.dir}/hadoop-${name}-${version}.jar" manifest="${root}/META-INF/MANIFEST.MF"> <fileset dir="${build.dir}" includes="classes/ lib/"></fileset> <fileset dir="${root}" includes="resources/ plugin.xml"></fileset> </jar> </target> </project>
修改src\contrib\eclipse-plugin\META-INF下的MANIFEST.MF
同方法一的
为了和方法一步冲突,我修改buildOK.xml
编译:
Buildfile: E:\big\Hadoop\hadoop-1.1.2\src\contrib\eclipse-plugin\buildOK.xml compile: [mkdir] Created dir: E:\big\Hadoop\hadoop-1.1.2\build\contrib\eclipse-plugin\classes [javac] E:\big\Hadoop\hadoop-1.1.2\src\contrib\eclipse-plugin\buildOK.xml:42: warning: 'includeantruntime' was not set, defaulting to build.sysclasspath=last; set to false for repeatable builds [javac] Compiling 45 source files to E:\big\Hadoop\hadoop-1.1.2\build\contrib\eclipse-plugin\classes [javac] 注意:某些输入文件使用或覆盖了已过时的 API。 [javac] 注意:要了解详细信息,请使用 -Xlint:deprecation 重新编译。 [javac] 注意:某些输入文件使用了未经检查或不安全的操作。 [javac] 注意:要了解详细信息,请使用 -Xlint:unchecked 重新编译。 jar: [mkdir] Created dir: E:\big\Hadoop\hadoop-1.1.2\build\contrib\eclipse-plugin\lib [copy] Copying 1 file to E:\big\Hadoop\hadoop-1.1.2\build\contrib\eclipse-plugin\lib [copy] Copying E:\big\Hadoop\hadoop-1.1.2\hadoop-core-1.1.2.jar to E:\big\Hadoop\hadoop-1.1.2\build\contrib\eclipse-plugin\lib\hadoop-core.jar [copy] Copying 1 file to E:\big\Hadoop\hadoop-1.1.2\build\contrib\eclipse-plugin\lib [copy] Copying E:\big\Hadoop\hadoop-1.1.2\lib\commons-cli-1.2.jar to E:\big\Hadoop\hadoop-1.1.2\build\contrib\eclipse-plugin\lib\commons-cli-1.2.jar [copy] Copying 1 file to E:\big\Hadoop\hadoop-1.1.2\build\contrib\eclipse-plugin\lib [copy] Copying E:\big\Hadoop\hadoop-1.1.2\lib\commons-configuration-1.6.jar to E:\big\Hadoop\hadoop-1.1.2\build\contrib\eclipse-plugin\lib\commons-configuration-1.6.jar [copy] Copying 1 file to E:\big\Hadoop\hadoop-1.1.2\build\contrib\eclipse-plugin\lib [copy] Copying E:\big\Hadoop\hadoop-1.1.2\lib\commons-httpclient-3.0.1.jar to E:\big\Hadoop\hadoop-1.1.2\build\contrib\eclipse-plugin\lib\commons-httpclient-3.0.1.jar [copy] Copying 1 file to E:\big\Hadoop\hadoop-1.1.2\build\contrib\eclipse-plugin\lib [copy] Copying E:\big\Hadoop\hadoop-1.1.2\lib\jackson-core-asl-1.8.8.jar to E:\big\Hadoop\hadoop-1.1.2\build\contrib\eclipse-plugin\lib\jackson-core-asl-1.8.8.jar [copy] Copying 1 file to E:\big\Hadoop\hadoop-1.1.2\build\contrib\eclipse-plugin\lib [copy] Copying E:\big\Hadoop\hadoop-1.1.2\lib\commons-lang-2.4.jar to E:\big\Hadoop\hadoop-1.1.2\build\contrib\eclipse-plugin\lib\commons-lang-2.4.jar [copy] Copying 1 file to E:\big\Hadoop\hadoop-1.1.2\build\contrib\eclipse-plugin\lib [copy] Copying E:\big\Hadoop\hadoop-1.1.2\lib\jackson-mapper-asl-1.8.8.jar to E:\big\Hadoop\hadoop-1.1.2\build\contrib\eclipse-plugin\lib\jackson-mapper-asl-1.8.8.jar [jar] Building jar: E:\big\Hadoop\hadoop-1.1.2\build\contrib\eclipse-plugin\hadoop-eclipse-plugin-1.1.2.jar BUILD SUCCESSFUL Total time: 2 seconds

热AI工具

Undresser.AI Undress
人工智能驱动的应用程序,用于创建逼真的裸体照片

AI Clothes Remover
用于从照片中去除衣服的在线人工智能工具。

Undress AI Tool
免费脱衣服图片

Clothoff.io
AI脱衣机

AI Hentai Generator
免费生成ai无尽的。

热门文章

热工具

记事本++7.3.1
好用且免费的代码编辑器

SublimeText3汉化版
中文版,非常好用

禅工作室 13.0.1
功能强大的PHP集成开发环境

Dreamweaver CS6
视觉化网页开发工具

SublimeText3 Mac版
神级代码编辑软件(SublimeText3)

如何在Eclipse中设置背景颜色?Eclipse是广受开发人员欢迎的集成开发环境(IDE),可用于各种编程语言的开发。它非常强大且灵活,可以通过设置来自定义界面及编辑器的外观。本文将介绍如何在Eclipse中设置背景颜色,并提供具体的代码示例。一、更改编辑器背景颜色打开Eclipse,并进入“Windows”菜单。选择“Preferences”。在左侧导航

PyCharm是一款功能强大且受欢迎的Python集成开发环境(IDE),提供了丰富的功能和工具,使得开发者们可以更加高效地编写代码。而PyCharm的插件机制更是其功能扩展的利器,通过安装不同的插件,可以为PyCharm增加各种功能和定制化的特性。因此,对于PyCharm新手来说,了解并熟练安装插件是至关重要的。本文将为你详细介绍PyCharm插件安装的全
![在Illustrator中加载插件时出错[修复]](https://img.php.cn/upload/article/000/465/014/170831522770626.jpg?x-oss-process=image/resize,m_fill,h_207,w_330)
启动AdobeIllustrator时是否会弹出加载插件时出错的消息?一些Illustrator用户在打开该应用程序时遇到了此错误。消息后面紧跟着一系列有问题的插件。该错误提示表明已安装的插件存在问题,但也可能是由于VisualC++DLL文件损坏或首选项文件受损等其他原因引起。如果遇到此错误,我们将在本文中指导您修复问题,请继续阅读以下内容。在Illustrator中加载插件时出错如果您在尝试启动AdobeIllustrator时收到“加载插件时出错”的错误消息,您可以使用以下用途:以管理员身

专业指导:Eclipse安装Lombok插件的专家建议和步骤,需要具体代码示例摘要:Lombok是一种Java库,能够通过注解的方式简化Java代码的编写,并提供了一些功能强大的工具。本文将向读者介绍如何在Eclipse中安装和配置Lombok插件的步骤,并提供一些具体的代码示例,以便读者能够更好地理解和使用Lombok插件。下载Lombok插件首先,我们需

Chrome的插件扩展程序安装目录是什么?正常情况下,Chrome插件扩展程序的默认安装目录如下:1、windowsxp中chrome插件默认安装目录位置:C:\DocumentsandSettings\用户名\LocalSettings\ApplicationData\Google\Chrome\UserData\Default\Extensions2、windows7中chrome插件默认安装目录位置:C:\Users\用户名\AppData\Local\Google\Chrome\User

用户使用Edge浏览器的过程中可能会添加一些插件来满足自己更多的使用需求。但是在添加插件时显示不支持此插件,这该如何解决?今日小编就来给大家分享三种解决办法,快来试试吧。 方法一:尝试用其他的浏览器。 方法二:浏览器上的FlashPlayer可能过时或者丢失,导致此插件不受支持状态,可在官网下载最新版本。 方法三:同时按下“Ctrl+Shift+Delete”键。 点击“清除数据”,重新打开浏览器即可。

Eclipse代码运行问题解决方案大揭秘:帮你排除各种代码运行错误,需要具体代码示例导言:Eclipse是一种常用的集成开发环境(IDE),被广泛用于Java开发。尽管Eclipse有着强大的功能和友好的用户界面,但是在编写和调试代码时,难免会遇到各种运行问题。本文将揭示一些常见的Eclipse代码运行问题,并提供解决方案。请注意,为了更好地帮助读者理解,本

如何在Eclipse中自定义快捷键设置?作为一名开发人员,在使用Eclipse进行编码时,熟练掌握快捷键是提高效率的关键之一。Eclipse作为一款强大的集成开发环境,不仅提供了许多默认的快捷键,还允许用户根据自己的偏好进行个性化的定制。本文将介绍如何在Eclipse中自定义快捷键设置,并给出具体的代码示例。打开Eclipse首先,打开Eclipse,并进入
