pom.xml 22 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350351352353354355356357358359360361362363364365366367368369370371372373374375376377378379380381382383384385386387388389390391392393394395396397398399400401402403404405406407408409410411412413414415416417418419420421422423424425426427428429430431432433434435436437438439440441442443444445446447448449450451452453454455456457458459460461462463464465466467468469470471472473474475476477478479480481482483484485486487488489490491492493494495496497498499500501502503504505506507508509510511512513514515516517518519520521522523524525526527528
  1. <?xml version="1.0"?>
  2. <!--
  3. Licensed to the Apache Software Foundation (ASF) under one or more
  4. contributor license agreements. See the NOTICE file distributed with
  5. this work for additional information regarding copyright ownership.
  6. The ASF licenses this file to You under the Apache License, Version 2.0
  7. (the "License"); you may not use this file except in compliance with
  8. the License. You may obtain a copy of the License at
  9. http://www.apache.org/licenses/LICENSE-2.0
  10. Unless required by applicable law or agreed to in writing, software
  11. distributed under the License is distributed on an "AS IS" BASIS,
  12. WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
  13. See the License for the specific language governing permissions and
  14. limitations under the License.
  15. -->
  16. <project xmlns="http://maven.apache.org/POM/4.0.0"
  17. xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance"
  18. xsi:schemaLocation="http://maven.apache.org/POM/4.0.0 http://maven.apache.org/xsd/maven-4.0.0.xsd">
  19. <parent>
  20. <artifactId>ambari-logsearch</artifactId>
  21. <groupId>org.apache.ambari</groupId>
  22. <version>2.5.0.0.0</version>
  23. </parent>
  24. <name>Ambari Logsearch Assembly</name>
  25. <url>http://maven.apache.org</url>
  26. <modelVersion>4.0.0</modelVersion>
  27. <properties>
  28. <mapping.base.path>/usr/lib</mapping.base.path>
  29. <solr.tar>http://archive.apache.org/dist/lucene/solr/${solr.version}/solr-${solr.version}.tgz</solr.tar>
  30. <solr.mapping.path>${mapping.base.path}/ambari-infra-solr</solr.mapping.path>
  31. <solr.package.name>ambari-infra-solr</solr.package.name>
  32. <solr.client.package.name>ambari-infra-solr-client</solr.client.package.name>
  33. <solr.client.mapping.path>${mapping.base.path}/${solr.client.package.name}</solr.client.mapping.path>
  34. <solr.client.dir>${project.basedir}/../ambari-logsearch-solr-client</solr.client.dir>
  35. <logsearch.portal.package.name>ambari-logsearch-portal</logsearch.portal.package.name>
  36. <logsearch.portal.mapping.path>${mapping.base.path}/ambari-logsearch-portal</logsearch.portal.mapping.path>
  37. <logsearch.portal.dir>${project.basedir}/../ambari-logsearch-portal</logsearch.portal.dir>
  38. <logsearch.logfeeder.package.name>ambari-logsearch-logfeeder</logsearch.logfeeder.package.name>
  39. <logsearch.logfeeder.mapping.path>${mapping.base.path}/ambari-logsearch-logfeeder</logsearch.logfeeder.mapping.path>
  40. <logsearch.logfeeder.dir>${project.basedir}/../ambari-logsearch-logfeeder</logsearch.logfeeder.dir>
  41. <logsearch.portal.conf.mapping.path>/etc/${logsearch.portal.package.name}/conf</logsearch.portal.conf.mapping.path>
  42. <logsearch.logfeeder.conf.mapping.path>/etc/${logsearch.logfeeder.package.name}/conf
  43. </logsearch.logfeeder.conf.mapping.path>
  44. </properties>
  45. <artifactId>ambari-logsearch-assembly</artifactId>
  46. <profiles>
  47. <profile>
  48. <id>rpm</id>
  49. <properties>
  50. <download.solr>true</download.solr>
  51. </properties>
  52. <activation>
  53. <property>
  54. <name>build-rpm</name>
  55. </property>
  56. </activation>
  57. <build>
  58. <plugins>
  59. <plugin>
  60. <groupId>org.codehaus.mojo</groupId>
  61. <artifactId>rpm-maven-plugin</artifactId>
  62. <version>2.1.4</version>
  63. <configuration>
  64. <copyright>2012, Apache Software Foundation</copyright>
  65. <group>Development</group>
  66. <description>Maven Recipe: RPM Package.</description>
  67. <autoRequires>false</autoRequires>
  68. <prefix>/</prefix>
  69. <needarch>x86_64</needarch>
  70. <version>${package-version}</version>
  71. <release>${package-release}</release>
  72. <defaultUsername>root</defaultUsername>
  73. <defaultGroupname>root</defaultGroupname>
  74. </configuration>
  75. <executions>
  76. <execution>
  77. <id>logsearch-solr</id>
  78. <phase>package</phase>
  79. <goals>
  80. <goal>rpm</goal>
  81. </goals>
  82. <configuration>
  83. <group>Development</group>
  84. <name>${solr.package.name}</name>
  85. <mappings>
  86. <mapping>
  87. <directory>${solr.mapping.path}</directory>
  88. <sources>
  89. <source>
  90. <location>${project.build.directory}/solr</location>
  91. </source>
  92. </sources>
  93. </mapping>
  94. </mappings>
  95. </configuration>
  96. </execution>
  97. <execution>
  98. <id>logsearch-solr-client</id>
  99. <phase>package</phase>
  100. <goals>
  101. <goal>rpm</goal>
  102. </goals>
  103. <configuration>
  104. <group>Development</group>
  105. <name>${solr.client.package.name}</name>
  106. <mappings>
  107. <mapping>
  108. <directory>${solr.client.mapping.path}</directory>
  109. <sources>
  110. <source>
  111. <location>${solr.client.dir}/target/package</location>
  112. </source>
  113. </sources>
  114. </mapping>
  115. </mappings>
  116. </configuration>
  117. </execution>
  118. <execution>
  119. <id>logsearch-portal</id>
  120. <phase>package</phase>
  121. <goals>
  122. <goal>rpm</goal>
  123. </goals>
  124. <configuration>
  125. <group>Development</group>
  126. <name>${logsearch.portal.package.name}</name>
  127. <mappings>
  128. <mapping>
  129. <directory>${logsearch.portal.mapping.path}</directory>
  130. <sources>
  131. <source>
  132. <location>${logsearch.portal.dir}/target/package</location>
  133. <excludes>
  134. <exclude>classes/log4j.xml</exclude>
  135. <exclude>classes/logsearch.properties</exclude>
  136. <exclude>classes/user_pass.json</exclude>
  137. <exclude>classes/HadoopServiceConfig.json</exclude>
  138. <exclude>solr_configsets/**</exclude>
  139. </excludes>
  140. </source>
  141. </sources>
  142. </mapping>
  143. <mapping>
  144. <directory>${logsearch.portal.conf.mapping.path}</directory>
  145. <sources>
  146. <source>
  147. <location>${logsearch.portal.dir}/target/package/classes</location>
  148. <includes>
  149. <include>log4j.xml</include>
  150. <include>logsearch.properties</include>
  151. <include>user_pass.json</include>
  152. </includes>
  153. </source>
  154. </sources>
  155. </mapping>
  156. <mapping>
  157. <directory>${logsearch.portal.conf.mapping.path}/solr_configsets</directory>
  158. <sources>
  159. <source>
  160. <location>${logsearch.portal.dir}/target/package/solr_configsets</location>
  161. </source>
  162. </sources>
  163. </mapping>
  164. </mappings>
  165. </configuration>
  166. </execution>
  167. <execution>
  168. <id>logsearch-logfeeder</id>
  169. <phase>package</phase>
  170. <goals>
  171. <goal>rpm</goal>
  172. </goals>
  173. <configuration>
  174. <group>Development</group>
  175. <name>${logsearch.logfeeder.package.name}</name>
  176. <mappings>
  177. <mapping>
  178. <directory>${logsearch.logfeeder.mapping.path}</directory>
  179. <sources>
  180. <source>
  181. <location>${logsearch.logfeeder.dir}/target/package</location>
  182. <excludes>
  183. <exclude>classes/log4j.xml</exclude>
  184. <exclude>classes/logfeeder.properties</exclude>
  185. <exclude>classes/grok-patterns</exclude>
  186. </excludes>
  187. </source>
  188. </sources>
  189. </mapping>
  190. <mapping>
  191. <directory>${logsearch.logfeeder.conf.mapping.path}</directory>
  192. <sources>
  193. <source>
  194. <location>${logsearch.logfeeder.dir}/target/package/classes</location>
  195. <includes>
  196. <include>log4j.xml</include>
  197. <include>logfeeder.properties</include>
  198. <include>grok-patterns</include>
  199. </includes>
  200. </source>
  201. </sources>
  202. </mapping>
  203. </mappings>
  204. </configuration>
  205. </execution>
  206. </executions>
  207. </plugin>
  208. <plugin>
  209. <groupId>org.apache.maven.plugins</groupId>
  210. <artifactId>maven-antrun-plugin</artifactId>
  211. <version>1.7</version>
  212. <executions>
  213. <execution>
  214. <phase>generate-resources</phase>
  215. <goals>
  216. <goal>run</goal>
  217. </goals>
  218. <configuration>
  219. <target name="Download Solr">
  220. <get
  221. src="${solr.tar}"
  222. dest="${project.build.directory}/solr.tgz"
  223. usetimestamp="true"
  224. />
  225. <untar
  226. src="${project.build.directory}/solr.tgz"
  227. dest="${project.build.directory}/"
  228. compression="gzip"
  229. />
  230. <move todir="${project.build.directory}/solr">
  231. <fileset dir="${project.build.directory}/solr-${solr.version}"/>
  232. </move>
  233. <copy file="${project.basedir}/src/main/resources/solr" toDir="${project.build.directory}/solr/bin/" />
  234. <chmod file="${project.build.directory}/solr/bin/**" perm="755"/>
  235. <chmod file="${project.build.directory}/solr/server/scripts/**" perm="755"/>
  236. </target>
  237. </configuration>
  238. </execution>
  239. </executions>
  240. </plugin>
  241. </plugins>
  242. </build>
  243. </profile>
  244. <profile>
  245. <id>deb</id>
  246. <activation>
  247. <property>
  248. <name>build-deb</name>
  249. </property>
  250. </activation>
  251. <build>
  252. <plugins>
  253. <plugin>
  254. <artifactId>maven-resources-plugin</artifactId>
  255. <version>2.7</version>
  256. <executions>
  257. <execution>
  258. <id>copy-resources</id>
  259. <phase>package</phase>
  260. <goals>
  261. <goal>copy-resources</goal>
  262. </goals>
  263. <configuration>
  264. <outputDirectory>${project.build.directory}/resources/deb</outputDirectory>
  265. <resources>
  266. <resource>
  267. <directory>${project.basedir}/src/main/package/deb</directory>
  268. <excludes>
  269. <exclude>solr/postinst</exclude>
  270. <exclude>solr-client/postinst</exclude>
  271. <exclude>portal/postinst</exclude>
  272. <exclude>logfeeder/postinst</exclude>
  273. </excludes>
  274. <filtering>false</filtering>
  275. </resource>
  276. <resource>
  277. <directory>${project.basedir}/src/main/package/deb</directory>
  278. <includes>
  279. <include>solr/postinst</include>
  280. <include>solr-client/postinst</include>
  281. <include>portal/postinst</include>
  282. <include>logfeeder/postinst</include>
  283. </includes>
  284. <filtering>true</filtering>
  285. </resource>
  286. </resources>
  287. </configuration>
  288. </execution>
  289. </executions>
  290. </plugin>
  291. <plugin>
  292. <groupId>org.vafer</groupId>
  293. <artifactId>jdeb</artifactId>
  294. <version>1.4</version>
  295. <executions>
  296. <execution>
  297. <phase>package</phase>
  298. <id>jdeb-solr</id>
  299. <goals>
  300. <goal>jdeb</goal>
  301. </goals>
  302. <configuration>
  303. <controlDir>${basedir}/src/main/package/deb/solr</controlDir>
  304. <deb>${basedir}/target/${solr.package.name}_${package-version}-${package-release}.deb</deb>
  305. <skip>false</skip>
  306. <skipPOMs>false</skipPOMs>
  307. <dataSet>
  308. <data>
  309. <src>${project.build.directory}/solr</src>
  310. <type>directory</type>
  311. <mapper>
  312. <type>perm</type>
  313. <user>root</user>
  314. <group>root</group>
  315. <prefix>${solr.mapping.path}</prefix>
  316. </mapper>
  317. <excludes>
  318. bin/**,server/scripts/**
  319. </excludes>
  320. </data>
  321. <data>
  322. <src>${project.build.directory}/solr</src>
  323. <type>directory</type>
  324. <mapper>
  325. <type>perm</type>
  326. <user>root</user>
  327. <group>root</group>
  328. <filemode>755</filemode>
  329. <prefix>${solr.mapping.path}</prefix>
  330. </mapper>
  331. <includes>
  332. bin/**,server/scripts/**
  333. </includes>
  334. </data>
  335. </dataSet>
  336. </configuration>
  337. </execution>
  338. <execution>
  339. <phase>package</phase>
  340. <id>jdeb-solr-client</id>
  341. <goals>
  342. <goal>jdeb</goal>
  343. </goals>
  344. <configuration>
  345. <controlDir>${basedir}/src/main/package/deb/solr-client</controlDir>
  346. <deb>${basedir}/target/${solr.client.package.name}_${package-version}-${package-release}.deb</deb>
  347. <skip>false</skip>
  348. <skipPOMs>false</skipPOMs>
  349. <dataSet>
  350. <data>
  351. <src>${solr.client.dir}/target/ambari-logsearch-solr-client.tar.gz</src>
  352. <type>archive</type>
  353. <mapper>
  354. <type>perm</type>
  355. <user>root</user>
  356. <group>root</group>
  357. <prefix>${solr.client.mapping.path}</prefix>
  358. </mapper>
  359. </data>
  360. </dataSet>
  361. </configuration>
  362. </execution>
  363. <execution>
  364. <id>jdeb-portal</id>
  365. <phase>package</phase>
  366. <goals>
  367. <goal>jdeb</goal>
  368. </goals>
  369. <configuration>
  370. <controlDir>${basedir}/src/main/package/deb/portal</controlDir>
  371. <deb>${basedir}/target/${logsearch.portal.package.name}_${package-version}-${package-release}.deb
  372. </deb>
  373. <skip>false</skip>
  374. <skipPOMs>false</skipPOMs>
  375. <dataSet>
  376. <data>
  377. <src>${logsearch.portal.dir}/target/ambari-logsearch-portal.tar.gz</src>
  378. <type>archive</type>
  379. <mapper>
  380. <prefix>${logsearch.portal.mapping.path}</prefix>
  381. <type>perm</type>
  382. <user>root</user>
  383. <group>root</group>
  384. </mapper>
  385. <excludes>
  386. classes/log4j.xml,classes/logsearch.properties,classes/user_pass.json,classes/HadoopServiceConfig.json,solr_configsets/**
  387. </excludes>
  388. </data>
  389. <data>
  390. <src>${logsearch.portal.dir}/target/package/classes</src>
  391. <type>directory</type>
  392. <mapper>
  393. <prefix>${logsearch.portal.conf.mapping.path}</prefix>
  394. <type>perm</type>
  395. <user>root</user>
  396. <group>root</group>
  397. <filemode>644</filemode>
  398. </mapper>
  399. <includes>
  400. log4j.xml,logsearch.properties,user_pass.json
  401. </includes>
  402. </data>
  403. <data>
  404. <src>${logsearch.portal.dir}/target/package/solr_configsets</src>
  405. <type>directory</type>
  406. <mapper>
  407. <prefix>${logsearch.portal.conf.mapping.path}/solr_configsets</prefix>
  408. <type>perm</type>
  409. <user>root</user>
  410. <group>root</group>
  411. </mapper>
  412. </data>
  413. </dataSet>
  414. </configuration>
  415. </execution>
  416. <execution>
  417. <id>jdeb-logfeeder</id>
  418. <phase>package</phase>
  419. <goals>
  420. <goal>jdeb</goal>
  421. </goals>
  422. <configuration>
  423. <controlDir>${basedir}/src/main/package/deb/logfeeder</controlDir>
  424. <deb>${basedir}/target/${logsearch.logfeeder.package.name}_${package-version}-${package-release}.deb
  425. </deb>
  426. <skip>false</skip>
  427. <skipPOMs>false</skipPOMs>
  428. <dataSet>
  429. <data>
  430. <src>${logsearch.logfeeder.dir}/target/ambari-logsearch-logfeeder.tgz</src>
  431. <type>archive</type>
  432. <mapper>
  433. <prefix>${logsearch.logfeeder.mapping.path}</prefix>
  434. <type>perm</type>
  435. <user>root</user>
  436. <group>root</group>
  437. </mapper>
  438. <excludes>
  439. classes/log4j.xml,classes/logfeeder.properties,classes/grok-patterns
  440. </excludes>
  441. </data>
  442. <data>
  443. <src>${logsearch.logfeeder.dir}/target/package/classes</src>
  444. <type>directory</type>
  445. <mapper>
  446. <prefix>${logsearch.logfeeder.conf.mapping.path}</prefix>
  447. <type>perm</type>
  448. <user>root</user>
  449. <group>root</group>
  450. <filemode>644</filemode>
  451. </mapper>
  452. <includes>
  453. log4j.xml,logfeeder.properties,grok-patterns
  454. </includes>
  455. </data>
  456. </dataSet>
  457. </configuration>
  458. </execution>
  459. </executions>
  460. </plugin>
  461. <plugin>
  462. <groupId>org.apache.maven.plugins</groupId>
  463. <artifactId>maven-antrun-plugin</artifactId>
  464. <version>1.7</version>
  465. <executions>
  466. <execution>
  467. <phase>generate-resources</phase>
  468. <goals>
  469. <goal>run</goal>
  470. </goals>
  471. <configuration>
  472. <target name="Download Solr">
  473. <get
  474. src="${solr.tar}"
  475. dest="${project.build.directory}/solr.tgz"
  476. usetimestamp="true"
  477. />
  478. <untar
  479. src="${project.build.directory}/solr.tgz"
  480. dest="${project.build.directory}/"
  481. compression="gzip"
  482. />
  483. <move todir="${project.build.directory}/solr">
  484. <fileset dir="${project.build.directory}/solr-${solr.version}"/>
  485. </move>
  486. <copy file="${project.basedir}/src/main/resources/solr" toDir="${project.build.directory}/solr/bin/" />
  487. <chmod file="${project.build.directory}/solr/bin/**" perm="755"/>
  488. <chmod file="${project.build.directory}/solr/server/scripts/**" perm="755"/>
  489. </target>
  490. </configuration>
  491. </execution>
  492. </executions>
  493. </plugin>
  494. </plugins>
  495. </build>
  496. </profile>
  497. </profiles>
  498. <dependencies>
  499. <dependency>
  500. <groupId>org.apache.ambari</groupId>
  501. <artifactId>ambari-logsearch-portal</artifactId>
  502. <version>${project.version}</version>
  503. </dependency>
  504. <dependency>
  505. <groupId>org.apache.ambari</groupId>
  506. <artifactId>ambari-logsearch-logfeeder</artifactId>
  507. <version>${project.version}</version>
  508. </dependency>
  509. <dependency>
  510. <groupId>org.apache.ambari</groupId>
  511. <artifactId>ambari-logsearch-solr-client</artifactId>
  512. <version>${project.version}</version>
  513. </dependency>
  514. </dependencies>
  515. </project>