我正在使用8.11.0-ce.1图像找到的GitLab运行这里。我配置了我的坞-撰写卷如下:
volumes:
- './data/config:/etc/gitlab'
- './data/logs:/var/log/gitlab'
- './data/data:/var/opt/gitlab'但是,这个磁盘的大小有限,我希望将这些卷移到/data/gitlab/目录,这个目录要大得多。
为了做到这一点,我尝试了以下步骤: 1.取下码头容器2.将数据卷复制到(cp -r /app/gitlab/ data / data/gitlab) 3上。
volumes:
- '/data/gitlab/config:/etc/gitlab'
- '/data/gitlab/logs:/var/log/gitlab'
- '/data/gitlab/data:/var/opt/gitlab'但是,在重新启动容器时,我会得到一个连续重复的错误(参见下面)。我假设还有一个额外的步骤必须遵循?还是我做得不对?
gitlab_1 | Preparing services...
gitlab_1 | Starting services...
gitlab_1 | Configuring GitLab package...
gitlab_1 | Configuring GitLab...
gitlab_1 | /opt/gitlab/embedded/bin/runsvdir-start: line 24: ulimit: pending signals: cannot modify limit: Operation not permitted
gitlab_1 | /opt/gitlab/embedded/bin/runsvdir-start: line 34: ulimit: max user processes: cannot modify limit: Operation not permitted
gitlab_1 | /opt/gitlab/embedded/bin/runsvdir-start: line 37: /proc/sys/fs/file-max: Read-only file system
gitlab_1 |
gitlab_1 | ================================================================================
gitlab_1 | Error executing action `run` on resource 'execute[/opt/gitlab/embedded/service/gitlab-shell/bin/gitlab-keys check-permissions]'
gitlab_1 | ================================================================================
gitlab_1 |
gitlab_1 | Mixlib::ShellOut::ShellCommandFailed
gitlab_1 | ------------------------------------
gitlab_1 | Expected process to exit with [0], but received '1'
gitlab_1 | ---- Begin output of /opt/gitlab/embedded/service/gitlab-shell/bin/gitlab-keys check-permissions ----
gitlab_1 | STDOUT:
gitlab_1 | STDERR: /opt/gitlab/embedded/lib/ruby/2.3.0/logger.rb:703:in `initialize': Permission denied @ rb_sysopen - /var/log/gitlab/gitlab-shell/gitlab-shell.log (Errno::EACCES)
gitlab_1 | from /opt/gitlab/embedded/lib/ruby/2.3.0/logger.rb:703:in `open'
gitlab_1 | from /opt/gitlab/embedded/lib/ruby/2.3.0/logger.rb:703:in `open_logfile'
gitlab_1 | from /opt/gitlab/embedded/lib/ruby/2.3.0/logger.rb:695:in `set_dev'
gitlab_1 | from /opt/gitlab/embedded/lib/ruby/2.3.0/logger.rb:635:in `initialize'
gitlab_1 | from /opt/gitlab/embedded/lib/ruby/2.3.0/logger.rb:353:in `new'
gitlab_1 | from /opt/gitlab/embedded/lib/ruby/2.3.0/logger.rb:353:in `initialize'
gitlab_1 | from /opt/gitlab/embedded/service/gitlab-shell/lib/gitlab_logger.rb:15:in `new'
gitlab_1 | from /opt/gitlab/embedded/service/gitlab-shell/lib/gitlab_logger.rb:15:in `<top (required)>'
gitlab_1 | from /opt/gitlab/embedded/service/gitlab-shell/lib/gitlab_keys.rb:4:in `require_relative'
gitlab_1 | from /opt/gitlab/embedded/service/gitlab-shell/lib/gitlab_keys.rb:4:in `<top (required)>'
gitlab_1 | from /opt/gitlab/embedded/lib/ruby/site_ruby/2.3.0/rubygems/core_ext/kernel_require.rb:55:in `require'
gitlab_1 | from /opt/gitlab/embedded/lib/ruby/site_ruby/2.3.0/rubygems/core_ext/kernel_require.rb:55:in `require'
gitlab_1 | from /opt/gitlab/embedded/service/gitlab-shell/bin/gitlab-keys:24:in `<main>'
gitlab_1 | ---- End output of /opt/gitlab/embedded/service/gitlab-shell/bin/gitlab-keys check-permissions ----
gitlab_1 | Ran /opt/gitlab/embedded/service/gitlab-shell/bin/gitlab-keys check-permissions returned 1
gitlab_1 |
gitlab_1 | Resource Declaration:
gitlab_1 | ---------------------
gitlab_1 | # In /opt/gitlab/embedded/cookbooks/cache/cookbooks/gitlab/recipes/gitlab-shell.rb
gitlab_1 |
gitlab_1 | 124: execute "#{gitlab_shell_keys_check} check-permissions" do
gitlab_1 | 125: user git_user
gitlab_1 | 126: group git_group
gitlab_1 | 127: end
gitlab_1 | 128:
gitlab_1 |
gitlab_1 | Compiled Resource:
gitlab_1 | ------------------
gitlab_1 | # Declared in /opt/gitlab/embedded/cookbooks/cache/cookbooks/gitlab/recipes/gitlab-shell.rb:124:in `from_file'
gitlab_1 |
gitlab_1 | execute("/opt/gitlab/embedded/service/gitlab-shell/bin/gitlab-keys check-permissions") do
gitlab_1 | action [:run]
gitlab_1 | retries 0
gitlab_1 | retry_delay 2
gitlab_1 | default_guard_interpreter :execute
gitlab_1 | command "/opt/gitlab/embedded/service/gitlab-shell/bin/gitlab-keys check-permissions"
gitlab_1 | backup 5
gitlab_1 | group "git"
gitlab_1 | returns 0
gitlab_1 | user "git"
gitlab_1 | declared_type :execute
gitlab_1 | cookbook_name "gitlab"
gitlab_1 | recipe_name "gitlab-shell"
gitlab_1 | end
gitlab_1 |
gitlab_1 | Platform:
gitlab_1 | ---------
gitlab_1 | x86_64-linux
gitlab_1 |发布于 2016-09-14 13:57:17
TL;博士-尝试使用cp -a而不是cp -r
详细信息:
我在https://docs.gitlab.com/omnibus/docker/#install-gitlab-using-docker-compose上使用撰写文件进行了快速操作。我确实看到了和你一样的错误。这显然是某种许可问题。当容器启动时,我注意到有一个方便的提示,它说:
# docker-compose up
Recreating gitlab2_web_1
Attaching to gitlab2_web_1
web_1 | Thank you for using GitLab Docker Image!
web_1 | Current version: gitlab-ce=8.11.5-ce.0
web_1 |
web_1 | Configure GitLab for your system by editing /etc/gitlab/gitlab.rb file
web_1 | And restart this container to reload settings.
web_1 | To do it use docker exec:
web_1 |
web_1 | docker exec -it gitlab vim /etc/gitlab/gitlab.rb
web_1 | docker restart gitlab
web_1 |
web_1 | For a comprehensive list of configuration options please see the Omnibus GitLab readme
web_1 | https://gitlab.com/gitlab-org/omnibus-gitlab/blob/master/README.md
web_1 |
web_1 | If this container fails to start due to permission problems try to fix it by executing:
web_1 |
web_1 | docker exec -it gitlab update-permissions
web_1 | docker restart gitlab
web_1 |
web_1 | Preparing services...
web_1 | Starting services...我尝试了一些有限的成功..。按指示运行有点棘手,因为容器正在不断地重新启动。但是,由于您是通过compose运行的,所以可以添加:
entrypoint: update-permissions也就是这样的东西:
web:
image: 'gitlab/gitlab-ce:latest'
restart: always
hostname: 'gitlab.example.com'
entrypoint: update-permissions
environment:
GITLAB_OMNIBUS_CONFIG: |
external_url 'https://gitlab.example.com'
# Add any other gitlab.rb configuration here, each on its own line
ports:
- '80:80'
- '443:443'
- '22:22'
volumes:
- '/srv/gitlab/config:/etc/gitlab'
- '/srv/gitlab/logs:/var/log/gitlab'
- '/srv/gitlab/data:/var/opt/gitlab'到相关的服务配置。它会重新创建容器,但这很好。然而,对我来说,在我这样做之后,我似乎仍然对redis有一些问题。
不过,由于这只是磁盘上的文件,所以我想在复制时保留所有权等等,这似乎很好。就你而言,我猜那是:
cp -a /app/gitlab/data/ /data/gitlab发布于 2017-02-19 02:56:35
以下是移动位置的GitLab的步骤:
/srv/ (请参阅步骤1中的卷位置引用):
docker exec -it -u git gitlab /bin/bash -c 'rsync -avz -avz @SERVER_LOCATION:/srv/ gitlab /config /etc/ gitlab /‘docker exec -it -u git /bin/bash -c 'rsync -avz user@SERVER_LOCATION:/srv/gitlab/logs/ /var/log/gitlab/’docker exec -it -u gitlab /bin/bash -c 'rsync user@SERVER_LOCATION:rsync/srv/gitlab/data/ /var/opt/gitlab/ gitlab/
(替换位置服务器的SERVER_LOCATION。如果您的文件位于同一台计算机中,请使用docker cp命令。)https://stackoverflow.com/questions/39480989
复制相似问题