У меня есть экземпляр AWS Ubuntu с настройкой GitLab CE. Теперь я хочу настроить GitLab CI для развертывания моего приложения NodeJS после каждой фиксации. У меня нет правильного пошагового решения для этого.Установка GitLab CI для развертывания NodeJS в экземпляре AWS Ubuntu
Моего NodeJS приложения работает в /var/www/mean/my-app
на http://myapp.mydomain.com
и хостинг обрабатывается Apache Proxy,
<VirtualHost *:80>
ServerAdmin [email protected]
ServerName gitlab.mydomain.com
ServerAlias www.gitlab.mydomain.com
ServerSignature Off
ProxyPreserveHost On
AllowEncodedSlashes NoDecode
<Location />
Require all granted
ProxyPassReverse http://localhost:8080
ProxyPassReverse http://gitlab.mydomain.com/
</Location>
RewriteEngine on
RewriteCond %{DOCUMENT_ROOT}/%{REQUEST_FILENAME} !-f [OR]
RewriteCond %{REQUEST_URI} ^/uploads/.*
RewriteRule .* http://127.0.0.1:8080%{REQUEST_URI} [P,QSA,NE]
DocumentRoot /home/git/gitlab/public
LogFormat "%{X-Forwarded-For}i %l %u %t \"%r\" %>s %b" common_forwarded
ErrorLog /var/log/apache2/gitlab_error.log
CustomLog /var/log/apache2/gitlab_forwarded.log common_forwarded
CustomLog /var/log/apache2/gitlab_access.log combined env=!dontlog
CustomLog /var/log/apache2/gitlab.log combined
</VirtualHost>
И приложение бутстрапируемое используя навсегда модуль
forever start app.js
gitlab проверка конфигурации sudo -u git -H bundle exec rake gitlab:check RAILS_ENV=production
дает,
Checking GitLab Shell ...
GitLab Shell version >= 4.0.0 ? ... OK (4.0.0)
Repo base directory exists?
default... yes
Repo storage directories are symlinks?
default... no
Repo paths owned by git:git?
default... yes
Repo paths access is drwxrws---?
default... yes
hooks directories in repos are links: ...
dev/my-app ... ok
Running /home/git/gitlab-shell/bin/check
Check GitLab API access: OK
Access to /home/git/.ssh/authorized_keys: OK
Send ping to redis server: OK
gitlab-shell self-check successful
Checking GitLab Shell ... Finished
Checking Sidekiq ...
Running? ... yes
Number of Sidekiq processes ... 1
Checking Sidekiq ... Finished
Checking Reply by email ...
Reply by email is disabled in config/gitlab.yml
Checking Reply by email ... Finished
Checking LDAP ...
LDAP is disabled in config/gitlab.yml
Checking LDAP ... Finished
Checking GitLab ...
Git configured with autocrlf=input? ... yes
Database config exists? ... yes
All migrations up? ... yes
Database contains orphaned GroupMembers? ... no
GitLab config exists? ... yes
GitLab config outdated? ... no
Log directory writable? ... yes
Tmp directory writable? ... yes
Uploads directory setup correctly? ... yes
Init script exists? ... yes
Init script up-to-date? ... yes
projects have namespace: ...
dev/my-app ... yes
Redis version >= 2.8.0? ... yes
Ruby version >= 2.1.0 ? ... yes (2.3.1)
Your git bin path is "/usr/bin/git"
Git version >= 2.7.3 ? ... yes (2.7.4)
Active users: 1
Checking GitLab ... Finished
Я использовал для входа в систему к экземпляру с помощью SSH из моей системы,
ssh -i API-Key.pem [email protected]
создал ключ, используя команду
ssh-keygen -t rsa
Runner конфигурации на /etc/gitlab-runner/config.toml
concurrent = 1
check_interval = 0
[[runners]]
name = "Production Runner"
url = "http://gitlab.mydomain.com/ci"
token = "xxxxxxxxxxxxxxxxxxxxxxxxxxx"
executor = "ssh"
[runners.ssh]
user = "ubuntu"
host = "ip-XXX-XX-XX-XXX"
identity_file = "/home/ubuntu/.ssh/id_rsa"
[runners.cache]
кодекса .gitlab-ci.yml
test_async:
script:
- npm install
Из-за мою плохую конфигурацию, бегун дает ошибку,
Running with gitlab-ci-multi-runner 1.7.1 (f896af7)
Using SSH executor...
ERROR: Preparation failed: ssh: handshake failed: ssh: unable to authenticate, attempted methods [none publickey], no supported methods remain
Will be retried in 3s ...
Моим неурядиц является:
Что должен быть содержанием .gitlab-ci.yml
файла для развертывания допущенного кода в место приложения?
А как настроить бегун для этого? Если мне нужно использовать бегун ssh
, какими должны быть конфигурации там?
Update:
После предоставления .pem
файла как identity_file
, получает следующее сообщение об ошибке
Running with gitlab-ci-multi-runner 1.7.1 (f896af7)
Using SSH executor...
Running on ip-xxx-xx-xx-xxx via ip-xxx-xx-xx-xxx...
Cloning repository...
Cloning into 'builds/a92f1b91/0/dev/my-app'...
fatal: unable to access 'http://gitlab-ci-token:[email protected]/dev/my-app.git/': The requested URL returned error: 500
ERROR: Build failed: Process exited with: 1. Reason was: ()
Теперь есть проблема, мерзавец клон с HTTP не работает, но SSH клонирования работы.
Примечание: Оба gitlab и строить среды такие же хост (такой же AWS экземпляр)
Bug сообщили в GitLab, а также (HTTP клон вопрос).
В настоящее время мы имеем Gitlab и Gitlab CI и работает только штрафом в АМС, его довольно стандартный. Тем не менее, хотя вы предоставили множество шагов по настройке Gitlab, вы не предоставили никакой информации о своих VPC, группе безопасности, подсети, NACL или каких-либо других сетевых настройках AWS. Подтвердили ли вы базовое подключение через порт 80 или 443? Похоже, у вас есть три системы в игре, Gitlab, Gitlab CI box и ваше приложение. Между каждой из них есть проблемы с подключением. –
@NickSharp в моей группе безопасности VPC, у меня есть входящий и исходящий доступ из любого места. – devo
Как я читал .. Каждый экземпляр GitLab CI имеет встроенный инструмент отладки под названием Lint. Вы можете найти ссылку под/ci/lint вашего экземпляра gitlab. Вы пробовали? – CristiC777