gitlab500错误修复笔记

问题:
gitlab其他服务都能正常使用,但是唯独登录web页面的时候报错,返回500,注意是输入了账号密码之后返回500,这时候需要去gitlab容器里查看gitlab日志,定位问题

# 1.查询docker的gitlab进程,然后进入到docker里面
docker ps 
docker exec -it gitlab bash

# 2.首先查询gitlab的各个服务的状态,是否是run
gitlab-ctl status
# 若有down,那么就尝试启动一下
gitlab-ctl start xxxx
# 如果起不来,建议查下日志
gitlab-ctl tail -f xxxx

# 3.如果都是run,那么直接查询日志,
gitlab-ctl tail -f 

这里最后定位的问题是数据库users表的问题,并且惊奇的发现,users表只要查看整个表的数据就会自动断开数据库的连接!!!!WHAT???什么操作,于是想出了如下解决方案,删除表数据!
这里注意:千万不要硬着头皮把表删了,否则你会发现你要删N多个表!多考虑一下再动手!

尝试解决问题:

# 1.登录gitlab数据库
su - gitlab-psql
psql -h /var/opt/gitlab/postgresql -d gitlabhq_production

# 2.查看表
select * from users;
# 这里在查看该表时就无故断开数据库的连接,那就更加说明该表数据出现了问题,那就逐条确认!

# 3.首先查看该表有几条数据,数据太多逐条确认到啥时候去!
select count(*) from users;
# 一般像这种能出现问题的gitlab都是小的gitlab,数据只要不超过200条就认命吧,逐条查看,逐条确认

# 4.查看数据
select * from users where id = 1;
# 然后一条一条的查,出现问题数据就会直接断开连接的,所以,别担心,直接删除就好了
\q # 输入这个指令退出数据库,然后输入下面的指令再重新进入数据库
psql -h /var/opt/gitlab/postgresql -d gitlabhq_production
# 然后就别客气了,直接把刚才出问题的记录删掉
delete from users where id = 1;

# 5.注意,一般这个表的id是会自动补位的,所以删除之后还要再查看一下这条记录,一般不会有啥问题,然后按顺序删除完所有的问题数据之后,基本上就能恢复了!
select * from users;
# 果然可以查所有数据了,不会再断开连接了!!!感动~

这里记录一下如何远程访问psql,感谢大佬的笔记,收益匪浅:

但是要注意,这个配置了之后,访问数据库就不需要密码了,所以懂得都懂,一定一定要注意数据安全嗷。如果想恢复,那就是提前备份好原来的gitlab.rb文件,之后换回来,再重新加载一次就好了!

配置psql远程访问

1、修改gitlab.rb

vim /etc/gitlab/gitlab.rb

配置为:

postgresql['enable'] = true
postgresql['listen_address'] = '0.0.0.0'
postgresql['port'] = 5432
postgresql['data_dir'] = "/var/opt/gitlab/postgresql/data"

2、继续修改gitlab.rb

vim /etc/gitlab/gitlab.rb
# 加入以下内容
postgresql['custom_pg_hba_entries'] = {
  APPLICATION:[ { # APPLICATION should identify what the settings are used for
    type: "host",
    database: "all",
    user: "all",
    cidr: "0.0.0.0/0",
    method: "trust"
#    option: exmple
    }   
  ]
}

3、使配置生效
gitlab-ctl reconfigure

4、检查是否生效
cat /var/opt/gitlab/postgresql/data/pg_hba.conf

# 会多出如下内容
host all all 0.0.0.0/0 trust
Logo

瓜分20万奖金 获得内推名额 丰厚实物奖励 易参与易上手

更多推荐