docker里的gitlab报错500修复日记
gitlab500错误修复笔记问题:gitlab其他服务都能正常使用,但是唯独登录web页面的时候报错,返回500,注意是输入了账号密码之后返回500,这时候需要去gitlab容器里查看gitlab日志,定位问题# 1.查询docker的gitlab进程,然后进入到docker里面docker psdocker exec -it gitlab bash# 2.首先查询gitlab的各个服务的状态,
·
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
更多推荐
已为社区贡献3条内容
所有评论(0)