opengrok部署
1. 前言
本文介绍如何在ubuntu 20.04.6下部署opengrok 1.13.1,系统环境如下:
opengrok = "1.13.1"
tomcat = "10.1.18"
uctags = "6.1.0"
linux = "ubuntu server 20.04.6"
2. 准备
2.1. 配置java环境
opengrok和tomcat是一个基于java的应用,需要安装jre和jdk。opengrok 1.13.1要求java版本大于11。
apt install openjdk-11-jdk openjdk-11-jre
2.2. 下载opengrok
https://github.com/OpenGrok/OpenGrok/releases
2.3. 下载tomcat
https://tomcat.apache.org/
tomcat官网提供了已经编译好的可执行程序和源码,建议直接下载编译好的。编译好的分类中又包含core Full documentation Deployer Embedded,直接从core分类中下载对应系统坂本即可。
2.4. 下载uctags
https://github.com/universal-ctags
ctgas github官网提供了2种仓库:universal-ctags和ctags-nightly-build,其中universal-ctags是ctags源码,ctags-nightly-build是ctags以编译好的。为了部署方便,建议下载ctags-nightly-build。
3. 部署
3.1. 构建opengrok目录
mkdir /opengrok/{src,data,dist,etc,log}
3.2. 解压opengrok到dist目录
tar -C /opengrok/dist --strip-components=1 -xzf opengrok-1.13.1.tar.gz
3.3. 配置opengrok log
3.3.1. 拷贝log配置文件
cp /opengrok/dist/doc/logging.properties /opengrok/etc
3.3.2. 修改log配置
java.util.logging.FileHandler.pattern = /opengrok/log/opengrok%g.%u.log
3.4. 配置web application
3.4.1. 拷贝opengrok war文件到tomcat目录下**
cp /opengrok/dist/lib/source.war /apache-tomcat-10.1.18/webapps/opengrok.war
3.4.2. 启动tomcat
cd /apache-tomcat-10.1.18/bin
./startup.sh
当启动tomcat时,tomcat会自动检测war文件,然后解压war文件,并运行解压后war文件中的web文件。客户端可以通过http://localhost:8080/opengrok访问。
3.4.3. 修改web文件
tomcat会从web文件中解析CONFIGURATION参数的值,该参数的值是opengrok的configuration.xml文件路径。默认情况下是/opengrok/etc/configuration.xml,需要根据实际情况修改。
<display-name>OpenGrok</display-name>
<description>A wicked fast source browser</description>
<context-param>
<description>Full path to the configuration file where OpenGrok can read its configuration</description>
<param-name>CONFIGURATION</param-name>
<param-value>/opengrok/etc/configuration.xml</param-value>
</context-param>
<listener>
<listener-class>org.opengrok.web.WebappListener</listener-class>
</listener>
3.5. 配置indexer
3.5.1. 添加代码到src目录中
添加代码有很多方式,可以直接解压源码压缩包,也可以使用git拉取,本案例中使用git方式。
git clone https://github.com/OpenGrok/OpenGrok
3.5.2. 创建索引
java \
-Djava.util.logging.config.file=/opengrok/etc/logging.properties \
-jar /opengrok/dist/lib/opengrok.jar \
-c /uctags-2024.01.24-linux-x86_64/bin/ctags \
-s /opengrok/src -d /opengrok/data -H -P -S -G \
-W /opengrok/etc/configuration.xml -U http://localhost:8080/opengrok
/uctags-2024.01.24-linux-x86_64/bin/ctags是ctags路径,http://localhost:8080/opengrok是tomcat应用服务地址。创建索引的过程时间可能比较久,和添加代码的量有关。
为了加快创建索引,可以做进一步修改,关闭识别git等选项。
java \
-Djava.util.logging.config.file=/opengrok/etc/logging.properties \
-jar /opengrok/dist/lib/opengrok.jar \
-c /opengrok/uctags-2024.01.24-linux-x86_64/bin/ctags \
-s /opengrok/src -d /opengrok/data -P -S \
-W /opengrok/etc/configuration.xml -U http://localhost:8080/opengrok \
--ignoreHistoryCacheFailures \
--disableRepository git \
--historyBased off \
--progress
- 如果想要再添加源码或者删除源码时,只需要再次执行上面创建索引的命令即可,它会自动从
/opengrok/etc/configuration.xml中添加或者删除相关源码信息。
成功部署后,再次访问http://localhost:8080/opengrok便可以显示出opengrok界面。