Ruby on rails GitLab 7.4.3 HTTP代码500:无法连接到服务器

Ruby on rails GitLab 7.4.3 HTTP代码500:无法连接到服务器,ruby-on-rails,nginx,gitlab,Ruby On Rails,Nginx,Gitlab,我用omnibus安装程序安装了GitLab,现在我遇到了一个问题,当我尝试访问该网站时,我变成了一个http错误500。我使用nginx作为web服务器,在端口8000下可以访问gitlab 这是我在production.log中看到的错误消息: ==> ./gitlab/gitlab-rails/production.log <== Started GET "/" for 212.227.35.68 at 2014-11-14 10:15:07 -0600 PG::Error

我用omnibus安装程序安装了GitLab,现在我遇到了一个问题,当我尝试访问该网站时,我变成了一个http错误500。我使用nginx作为web服务器,在端口8000下可以访问gitlab

这是我在production.log中看到的错误消息:

==> ./gitlab/gitlab-rails/production.log <==
Started GET "/" for 212.227.35.68 at 2014-11-14 10:15:07 -0600

PG::Error (could not connect to server: No such file or directory
Is the server running locally and accepting
connections on Unix domain socket "/tmp/.s.PGSQL.5432"?
):

activerecord (4.1.1) lib/active_record/connection_adapters/postgresql_adapter.rb:881:in `initialize'
activerecord (4.1.1) lib/active_record/connection_adapters/postgresql_adapter.rb:881:in `new'
activerecord (4.1.1) lib/active_record/connection_adapters/postgresql_adapter.rb:881:in `connect'
activerecord (4.1.1) lib/active_record/connection_adapters/postgresql_adapter.rb:568:in `initialize'
activerecord (4.1.1) lib/active_record/connection_adapters/postgresql_adapter.rb:41:in `new'
activerecord (4.1.1) lib/active_record/connection_adapters/postgresql_adapter.rb:41:in `postgresql_connection'
activerecord (4.1.1) lib/active_record/connection_adapters/abstract/connection_pool.rb:435:in `new_connection'
activerecord (4.1.1) lib/active_record/connection_adapters/abstract/connection_pool.rb:445:in `checkout_new_connection'
activerecord (4.1.1) lib/active_record/connection_adapters/abstract/connection_pool.rb:416:in `acquire_connection'
activerecord (4.1.1) lib/active_record/connection_adapters/abstract/connection_pool.rb:351:in `block in checkout'
/opt/gitlab/embedded/lib/ruby/2.1.0/monitor.rb:211:in `mon_synchronize'
activerecord (4.1.1) lib/active_record/connection_adapters/abstract/connection_pool.rb:350:in `checkout'
activerecord (4.1.1) lib/active_record/connection_adapters/abstract/connection_pool.rb:265:in `block in connection'
/opt/gitlab/embedded/lib/ruby/2.1.0/monitor.rb:211:in `mon_synchronize'
activerecord (4.1.1) lib/active_record/connection_adapters/abstract/connection_pool.rb:264:in `connection'
activerecord (4.1.1) lib/active_record/connection_adapters/abstract/connection_pool.rb:541:in `retrieve_connection'
activerecord (4.1.1) lib/active_record/connection_handling.rb:113:in  `retrieve_connection'
activerecord (4.1.1) lib/active_record/connection_handling.rb:87:in `connection'
activerecord (4.1.1) lib/active_record/query_cache.rb:51:inn`restore_query_cache_settings'
activerecord (4.1.1) lib/active_record/query_cache.rb:43:in `rescue in call'
activerecord (4.1.1) lib/active_record/query_cache.rb:32:in `call'
activerecord (4.1.1) lib/active_record/connection_adapters/abstract/connection_pool.rb:621:in `call'
actionpack (4.1.1) lib/action_dispatch/middleware/callbacks.rb:29:in `block in call'
activesupport (4.1.1) lib/active_support/callbacks.rb:82:in `run_callbacks'
actionpack (4.1.1) lib/action_dispatch/middleware/callbacks.rb:27:in `call'
actionpack (4.1.1) lib/action_dispatch/middleware/remote_ip.rb:76:in `call'
actionpack (4.1.1) lib/action_dispatch/middleware/debug_exceptions.rb:17:in `call'
actionpack (4.1.1) lib/action_dispatch/middleware/show_exceptions.rb:30:in `call'
railties (4.1.1) lib/rails/rack/logger.rb:38:in `call_app'
railties (4.1.1) lib/rails/rack/logger.rb:20:in `block in call'
activesupport (4.1.1) lib/active_support/tagged_logging.rb:68:in `block in tagged'
activesupport (4.1.1) lib/active_support/tagged_logging.rb:26:in `tagged'
activesupport (4.1.1) lib/active_support/tagged_logging.rb:68:in `tagged'
railties (4.1.1) lib/rails/rack/logger.rb:20:in `call'
actionpack (4.1.1) lib/action_dispatch/middleware/request_id.rb:21:in `call'
rack (1.5.2) lib/rack/methodoverride.rb:21:in `call'
rack (1.5.2) lib/rack/runtime.rb:17:in `call'
rack (1.5.2) lib/rack/lock.rb:17:in `call'
rack (1.5.2) lib/rack/sendfile.rb:112:in `call'
railties (4.1.1) lib/rails/engine.rb:514:in `call'
railties (4.1.1) lib/rails/application.rb:144:in `call'
railties (4.1.1) lib/rails/railtie.rb:194:in `public_send'
railties (4.1.1) lib/rails/railtie.rb:194:in `method_missing'
rack (1.5.2) lib/rack/builder.rb:138:in `call'
rack (1.5.2) lib/rack/urlmap.rb:65:in `block in call'
rack (1.5.2) lib/rack/urlmap.rb:50:in `each'
rack (1.5.2) lib/rack/urlmap.rb:50:in `call'
unicorn (4.6.3) lib/unicorn/http_server.rb:552:in `process_client'
unicorn-worker-killer (0.4.2) lib/unicorn/worker_killer.rb:51:in `process_client'
unicorn (4.6.3) lib/unicorn/http_server.rb:632:in `worker_loop'
unicorn (4.6.3) lib/unicorn/http_server.rb:500:in `spawn_missing_workers'
unicorn (4.6.3) lib/unicorn/http_server.rb:142:in `start'
unicorn (4.6.3) bin/unicorn:126:in `<top (required)>'
/opt/gitlab/embedded/service/gem/ruby/2.1.0/bin/unicorn:23:in `load'
/opt/gitlab/embedded/service/gem/ruby/2.1.0/bin/unicorn:23:in `<main>'
以及gitlab.rb配置文件:

# Change the external_url to the address your users will type in their browser
external_url 'http://gitlab.domain.com:8000'

# External URL to reach the GitLab CI Coordinator at
ci_external_url 'http://ci.domain.com:8000'
一切都在Debian 7服务器上运行,我安装了ActualGitlab 7.4.3版。 安装过程完成后,我修改了gitlab.rb,并开始重新配置gitlab
gitlab ctl重新配置
。之后,我用
gitlab ctl start
启动了gitlab

编辑:
我已经测试过为CI打开网站,但是出现了相同的错误消息。

数据库服务器中的问题。Rails应用程序尝试通过Unix域套接字“/tmp/.s.PGSQL.5432”访问if

显示PG设置和database.yml
PG可能只侦听TCP套接字,而不侦听UNIX。您应该对其进行配置。

我已找到此问题的解决方案,但我创建了一个新问题。 首先是解决方案:

gitlab安装程序在
/tmp/.s.PGSQL.5432
下搜索该文件,我可以在
/var/run/postgresql/.s.PGSQL.5432
下找到该文件,因此我创建了一个与
ln-s/var/run/postgresql/.s.PGSQL.5432
的链接,现在该错误不再出现


下一个错误是没有用于postgresql的gitlab用户,但我已经创建了一个。看看这篇帖子:

我也遇到了同样的问题,找到了一种更为激进的方法:

sudo gitlab-ctl stop

mv /var/opt/gitlab/postgresql /var/opt/gitlab/postgresql.bak

sudo gitlab-ctl reconfigure
sudo gitlab-ctl start

由于PostgreSQL文件在某种程度上是“损坏的”,Gitlab只是重新生成它们。我所有的旧数据(设置、用户、存储库和注释)仍然存在。

可能相关:如果只发生在自定义端口上,请将其添加到标题中。不,这对我没有帮助。错误是相同的,防火墙不会产生任何问题。Database.yml:
#此文件由gitlab ctl管理。手动更改将被删除!要更改以下内容,请编辑/etc/gitlab/gitlab.rb#并运行“sudo gitlab ctl reconfigure”。生产:适配器:postgresql编码:unicode数据库:gitlab HQ_生产池:10用户名:'gitlab'密码:主机:端口:5432套接字:
,因此您应该编辑database.yml以使用tcp,通过Gitlab设置的主机和端口,当我将其设置为tcp时,postgresql无法再启动。显示您的数据库。yml
#此文件由Gitlab ctl管理。手动更改将被删除!要更改以下内容,请编辑/etc/gitlab/gitlab.rb#并运行“sudo gitlab ctl reconfigure”。生产:适配器:postgresql编码:unicode数据库:gitlabhq_生产池:10用户名:“gitlab”密码:主机:端口:5432套接字:“tcp”
sudo gitlab-ctl stop

mv /var/opt/gitlab/postgresql /var/opt/gitlab/postgresql.bak

sudo gitlab-ctl reconfigure
sudo gitlab-ctl start