1.环境

本文使用VMWare虚拟机进行实验。

  • 2核CPU,4GB内存,20GB硬盘,IP:192.168.159.131
  • CentOS 7.2最小安装(CentOS-7-x86_64-Minimal-1511.iso)

2.需求

Gerrit支持多种数据库、多种认证方式(参考官网手册),这里使用

  • mariadb数据库
  • http认证
  • Apache http server作为web服务器,提供反向代理
  • gitweb作为Repository Browser

3.安装

3.1 安装软件

yum -y install git gitweb httpd mariadb-server

3.2 配置数据库

systemctl start mariadb
mysql

键入如下内容,这里密码是secret

CREATE USER 'gerrit2'@'localhost' IDENTIFIED BY 'secret';
CREATE DATABASE reviewdb DEFAULT CHARACTER SET 'utf8';
GRANT ALL ON reviewdb.* TO 'gerrit2'@'localhost';
FLUSH PRIVILEGES;

3.3 配置httpd反向代理

vim /etc/httpd/conf.d/gerrit.conf

键入如下内容

<VirtualHost *>
ServerName 192.168.159.131 ProxyRequests Off
ProxyVia Off
ProxyPreserveHost On <Proxy *>
Order deny,allow
Allow from all
</Proxy> <Location /login/>
AuthType Basic
AuthName "Gerrit Code Review"
AuthBasicProvider file
AuthUserFile /gerrit.password
Require valid-user
</Location> AllowEncodedSlashes On
ProxyPass / http://127.0.0.1:8081/
</VirtualHost>

注意,

  • ServerName根据自己实际情况来定, 我用的本机IP
  • gerrit的http认证方式,需要使用HTTP基本认证,这里使用文件(/gerrit.password,httpd要有访问权限才行)方式认证。
  • 反向代理设置,从根目录"/",代理到"http://127.0.0.1:8081/",注意端口8001后面有个斜线。8081是gerrit监听的端口,后面会提到。

启动httpd,将监听80端口(反向代理到8081端口)

systemctl start httpd

3.4 添加HTTP认证用户

touch /gerrit.passwd
htpasswd /gerrit.passwd "root"
New password:
Re-type new password:
Adding password for user root

这里添加了用户root,密码123456(跟Linux本地用户没有关系!)

这样首次访问gerrit时的用户将成为gerrit的管理员,若想再添加用户,需要先在/gerrit.passwd中添加,再登录gerrit。

3.5 安装JRE

官网下载Java SE Runtime Environment 8u162 Linux x64

jre-8u162-linux-x64.tar

tar zxvf jre-8u162-linux-x64.tar -C /opt
export JAVA_HOME=/opt/jre1.8.0_162
export PATH=$JAVA_HOME/bin:$PATH
export CLASSPATH=.:$JAVA_HOME/lib/dt.jar:$JAVA_HOME/lib/toos.jar

3.6 安装gerrit

3.6.1 添加用户
sudo adduser gerrit2
sudo su gerrit2

官网下载gerrit的war包gerrit-2.14.6.war,这里放至gerrit2的home目录

3.6.2 创建工作目录
mv gerrit-2.14.6.war gerrit.war
mkdir gerrit-test
3.6.3 安装

进入交互命令,蓝色粗体表示输入的内容

[gerrit2@ted ~]$ java -jar gerrit.war init -d gerrit-test/
Using secure store: com.google.gerrit.server.securestore.DefaultSecureStore
[-- ::,] [main] INFO com.google.gerrit.server.config.GerritServerConfigProvider : No /home/gerrit2/gerrit-test/etc/gerrit.config; assuming defaults *** Gerrit Code Review 2.14.
*** Create '/home/gerrit2/gerrit-test' [Y/n]y *** Git Repositories
*** Location of Git repositories [git]: #回车 *** SQL Database
*** Database server type [h2]: mariadb Gerrit Code Review is not shipped with MariaDB Connector/J 1.5.
** This library is required for your configuration. **
Download and install it now [Y/n]? y
Downloading https://repo1.maven.org/maven2/org/mariadb/jdbc/mariadb-java-client/1.5.9/mariadb-java-client-1.5.9.jar ... OK
Checksum mariadb-java-client-1.5..jar OK
Server hostname [localhost]: #回车
Server port [(mariadb default)]: #回车
Database name [reviewdb]: #回车
Database username [gerrit2]: #回车
gerrit2's password : #secret
confirm password : #secret *** Index
*** Type [lucene/?]: #回车 *** User Authentication
*** Authentication method [openid/?]: http
Get username from custom HTTP header [y/N]? #回车
SSO logout URL : #回车
Enable signed push support [y/N]? #回车 *** Review Labels
*** Install Verified label [y/N]? #回车 *** Email Delivery
*** SMTP server hostname [localhost]: #回车
SMTP server port [(default)]: #回车
SMTP encryption [none/?]: #回车
SMTP username : co3@qq.com
co3@qq.com's password : #123456
confirm password : #123456
*** Container Process
*** Run as [gerrit2]: #回车
Java runtime [/opt/jre1..0_162]: #回车
Copy gerrit.war to gerrit-test/bin/gerrit.war [Y/n]? #回车
Copying gerrit.war to gerrit-test/bin/gerrit.war *** SSH Daemon
*** Listen on address [*]: #回车
Listen on port []: #回车
Generating SSH host key ... rsa... dsa... ed25519... ecdsa ... ecdsa ... ecdsa ... done *** HTTP Daemon
*** Behind reverse proxy [y/N]? y
Proxy uses SSL (https://) [y/N]? #回车
Subdirectory on proxy server [/]: #回车
Listen on address [*]: 127.0.0.1
Listen on port []: #回车
Canonical URL [http://localhost/]: http://192.168.159.131 *** Cache
*** *** Plugins
*** Installing plugins.
Install plugin commit-message-length-validator version v2.14.6 [y/N]? y
Installed commit-message-length-validator v2.14.6
Install plugin download-commands version v2.14.6 [y/N]? y
Installed download-commands v2.14.6
Install plugin hooks version v2.14.6 [y/N]? y
Installed hooks v2.14.6
Install plugin replication version v2.14.6 [y/N]? y
Installed replication v2.14.6
Install plugin reviewnotes version v2.14.6 [y/N]? y
Installed reviewnotes v2.14.6
Install plugin singleusergroup version v2.14.6 [y/N]? y
Installed singleusergroup v2.14.6
Initializing plugins. Initialized /home/gerrit2/gerrit-test
Executing /home/gerrit2/gerrit-test/bin/gerrit.sh start
Starting Gerrit Code Review: OK
Waiting for server on 192.168.118.158:80 ... OK
Opening http://192.168.118.158/#/admin/projects/ ...FAILED #(因为还没有用户,所以failed,不影响)
Open Gerrit with a JavaScript capable browser:
http://192.168.118.158/#/admin/projects/
[gerrit2@ted ~]$

完成后查看端口情况

[root@ted ~]# netstat -ltnp
Active Internet connections (only servers)
Proto Recv-Q Send-Q Local Address Foreign Address State PID/Program name
tcp 0.0.0.0: 0.0.0.0:* LISTEN /mysqld
tcp 0.0.0.0: 0.0.0.0:* LISTEN /sshd
tcp 127.0.0.1: 0.0.0.0:* LISTEN /master
tcp6 0 0 :::29418 :::* LISTEN 3118/GerritCodeRevi
tcp6
0 0 :::80 :::* LISTEN 2465/httpd
tcp6
0 0 127.0.0.1:8081 :::* LISTEN 3118/GerritCodeRevi
tcp6 ::: :::* LISTEN /sshd
tcp6 ::: :::* LISTEN /master
[root@ted ~]#

这样初始化好后,gerrit的配置文件(gerrit-test/etc/gerrit.config)

[gerrit]
basePath = git
serverId = 70a67d2b-e12e-42b9-a978-705d7685654d
canonicalWebUrl = http://192.168.118.145
[database]
type = mariadb
hostname = localhost
database = reviewdb
username = gerrit2
[index]
type = LUCENE
[auth]
type = HTTP
[receive]
enableSignedPush = false
[sendemail]
smtpServer = localhost
smtpUser = co3@qq.com
[container]
user = gerrit2
javaHome = /opt/jre1.8.0_162
[sshd]
listenAddress = *:29418
[httpd]
listenUrl = proxy-http://127.0.0.1:8081/
[cache]
directory = cache

4.测试

使用浏览器访问canonicalWebUrl ,

http://192.168.118.145

提示输入用户密码,就是/gerrit.password里的http认证用户密码

登录成功后,将看到gerrit用户信息登记界面(添Full Name什么的),然后进入主界面

管理命令如下

./gerrit-test/bin/gerrit.sh start
./gerrit-test/bin/gerrit.sh stop
./gerrit-test/bin/gerrit.sh status

5.配置gitweb

参考官网手册,可以使用命令行实现,我这里直接编辑配置文件,

vi gerrit-test/etc/gerrit.config

添加如下gitweb配置

[gitweb]
cgi = /var/www/git/gitweb.cgi
type = gitweb

注意!此处有坑!如果按官网手册用命令配置,type是没有值的,而默认是disabled,不会显示gitweb超链接!必须手动设置!)

重启gerrit,退出web窗口,重新认证登录,可以看见gitweb超链接了

浏览hey项目,

6.配置邮箱验证

如果按前面默认配置,使用本机smtp发送邮件,这样如果发到公网邮箱(qq、163等),会被判定为垃圾邮件,发不出去。

如果是实验性质的话,可以在局域网搭建postfix+dovecot+dnsmasq简单邮件系统,进行邮箱注册。

(gerrit的账号必须注册邮箱,添加ssh公钥/http密码,git 配置邮箱必须跟注册邮箱一致,才能push)

我再看看其他解决垃圾邮件方法...

CentOS 7.2 安装Gerrit 2.14.6的更多相关文章

  1. Python之——CentOS 6.5安装Python2.7.14

    Python之——CentOS 6.5安装Python2.7.14   版权声明:本文为博主原创文章,未经博主允许不得转载. https://blog.csdn.net/l1028386804/art ...

  2. CentOS 7.4安装Nginx 1.14.0

    一.安装所需环境   1.gcc 安装         yum install gcc-c++    

  3. Centos 7.5安装 Nginx 1.14.1

    1. 准备工作 查看系统版本 输入命令 cat /etc/redhat-release 我的Centos版本 CentOS Linux release 7.5.1804 (Core) 安装nginx所 ...

  4. CentOS 6.9编译安装Python-2.7.14(python升级)

    参考 Python官网:https://www.python.org/ 阿里云 https://www.aliyun.com/jiaocheng/517192.html 一.查看CentOS版本和系统 ...

  5. Centos、Ubuntu 安装 Mono、Jexus

    Mono是.NET的跨平台实现 在众多关于语言的争论中,.NET一直被以不能跨平台而诟病,Mono改变了这一现状. 有人当心Mono会涉及版权啥的问题.高深的偶不懂,不过我觉得Unity3D都能用,为 ...

  6. centos下编译安装mysql5.5/5.6

    2013年11月16日 19:39:13 centos 6 mysql 5.5.28 我只说些我出错的地方: cmake后删除的方法是 xargs rm < install_manifest.t ...

  7. 在CentOS 7中安装与配置Tomcat-8方法

    安装前提 在CentOS 7中安装与配置JDK8 安装tomcat  apache-tomcat-8.0.14.tar.gz文件上传到/usr/local中执行以下操作: [root@localhos ...

  8. CentOS 6.4 安装 Transmission 2.76

    1.安装Transmission 首先打开Transmission下载页:http://www.transmissionbt.com/download/ ,点击CentOS下载项,会跳转到一个叫&qu ...

  9. Linux Centos 系统上安装BT客户端 Transmission

    Linux Centos 系统上安装BT客户端 Transmission   Transmission是一种BitTorrent客户端,特点是一个跨平台的后端和其上的简洁的用户界面,以MIT许可证和G ...

随机推荐

  1. kubernetes---CentOS7安装kubernetes1.11.2图文完整版

    转载请注明出处:kubernetes-CentOS7安装kubernetes1.11.2图文完整版 架构规划 k8s至少需要一个master和一个node才能组成一个可用集群. 本章我们搭建一个mas ...

  2. 洛谷P2483 Bzoj1975 [SDOI2010]魔法猪学院

    题目描述 iPig在假期来到了传说中的魔法猪学院,开始为期两个月的魔法猪训练.经过了一周理论知识和一周基本魔法的学习之后,iPig对猪世界的世界本原有了很多的了解:众所周知,世界是由元素构成的:元素与 ...

  3. 【HDOJ6223】Infinite Fraction Path(后缀数组,倍增)

    题意: 给一个长度为n的字符串s[0..n-1],但i的后继不再是i+1,而是(i*i+1)%n,求所有长度为n的“子串”中,字典序最大的是谁 n<=150000,s[i]=0..9 思路:后缀 ...

  4. MySql将查询结果插入到另外一张表

    今天遇到一个业务需求是这样的:对在职员工超过55岁提醒.我想的思路是查询员工表,然后将超过55岁的人的信息存到另一个表,并且以消息的形式给用户提示,用户处理掉之后此消息失效(在数据库做标记). 不管是 ...

  5. codevs——1570 去看电影

    1570 去看电影  时间限制: 1 s  空间限制: 128000 KB  题目等级 : 黄金 Gold 题解       题目描述 Description 农夫约翰带着他的一些奶牛去看电影.而他的 ...

  6. linux下查看cpu使用情况

    1.在终端输入top 2.ubuntu系统自带有system monitor 3.sudo apt-get install sysstat 然后在终端输入:mpstat

  7. Redis数据库No-SQL的介绍安装和使用

    Redis安装步骤 1.官网下载Redis压缩包http://download.redis.io/releases/redis-5.0.2.tar.gz,然后将下载的redis上传到虚拟机的/usr/ ...

  8. db2 获取自增主键的方法

    1.用SEQUENCES方式 建表语句 CREATE TABLE TEST1( PKEY INTEGER NOT NULL, NAME VARCHAR(100), SEX VARCHAR(100), ...

  9. WebGIS开发之用openlayers加载离线百度地图

    因为项目需要,只有内网环境,没有外网环境,所以需要下载地图瓦片. 一.下载瓦片地图 这个可以自行在网上找一些地图瓦片下载器,下好的瓦片地图是分级的.大概如图这种类型. 二.在地图上显示标记 首先使用o ...

  10. 如何通过SQL注入获取服务器本地文件

    写在前面的话 SQL注入可以称得上是最臭名昭著的安全漏洞了,而SQL注入漏洞也已经给整个网络世界造成了巨大的破坏.针对SQL漏洞,研究人员也已经开发出了多种不同的利用技术来实施攻击,包括非法访问存储在 ...