質問編集履歴

6

githubリポジトリ名を隠す

2022/05/30 00:23

投稿

otdsh9432
otdsh9432

スコア55

test CHANGED
File without changes
test CHANGED
@@ -1,347 +1,174 @@
1
1
  ### 実現したいこと
2
-
3
2
  ローカルのDockerコンテナ内に作成したRailsアプリを、AWSのEC2サーバにデプロイしたいです。
4
3
 
5
-
6
-
7
4
  ### 表示されているエラー
8
-
9
5
  dockerのRailsコンテナ内で「bundle exec cap production deploy」すると、以下のエラーが出ます。
10
6
 
11
-
7
+ ```
12
-
8
+ SSHKit::Runner::ExecuteError: Exception while executing as ec2-user@(IPアドレス): Authentication failed for user ec2-user@(IPアドレス)
13
9
  ```
14
10
 
15
- SSHKit::Runner::ExecuteError: Exception while executing as ec2-user@(IPアドレス): Authentication failed for user ec2-user@(IPアドレス)
16
-
17
- ```
18
-
19
-
20
-
21
11
  エラー全文
22
-
23
12
  ![エラー内容](a95457eb65bc3b03cbfcbc0195129fa0.png)
24
13
 
25
-
26
-
27
14
  ### 困っていること
28
-
29
15
  エラー内容から、SSHの鍵の問題かと思って調査中ですが、
30
-
31
16
  鍵の部分の知識も不足しており、具体的な原因、解決方法をご教示いただきたいと考えています。
32
-
33
17
  **「鍵は、dockerからホストドライブをマウントして渡すべき」** という記事も見かけたのですが、
34
-
35
18
  この文章の意味がわかっておらず、何も実施できていません。
36
-
37
-
38
19
 
39
20
  ### 現状のCapistrano設定ファイル
40
21
 
41
-
42
-
43
22
  ### Capfile
44
-
45
23
  ```Ruby
46
-
47
24
  require "capistrano/setup"
48
-
49
25
  require "capistrano/deploy"
50
26
 
51
-
52
-
53
27
  require 'capistrano/scm/git'
54
-
55
28
  install_plugin Capistrano::SCM::Git
56
29
 
57
-
58
-
59
30
  # add requires
60
-
61
31
  require 'capistrano/bundler'
62
-
63
32
  require 'capistrano/rbenv'
64
-
65
33
  require 'capistrano/rails/assets'
66
-
67
34
  require 'capistrano/rails/migrations'
68
-
69
35
  require 'capistrano/puma'
70
36
 
71
-
72
-
73
37
  # Load custom tasks from `lib/capistrano/tasks` if you have any defined
74
-
75
38
  Dir.glob("lib/capistrano/tasks/*.rake").each { |r| import r }
76
-
77
39
  ```
78
-
79
-
80
40
 
81
41
  ### config/deploy.rb
82
42
 
83
-
84
-
85
43
  ```Ruby
86
-
87
44
  lock "3.7.0"
88
45
 
89
-
90
-
91
46
  # Capistranoのログの表示に利用する
92
-
93
47
  set :application, "myfavrest-app"
94
48
 
95
-
96
-
97
49
  # どのリポジトリからアプリをpullするかを指定する
98
-
99
- set :repo_url, "git@github.com:gcp632dsh/myfavrest-app.git"
50
+ set :repo_url, "git@github.com:(リポジトリ名)/(アプリ名).git"
100
-
101
-
102
51
 
103
52
  # サーバ上でのソースの配置先
104
-
105
53
  set :deploy_to, "/var/www/apps/myapp"
106
54
 
107
-
108
-
109
55
  # Rubyをrbenv経由で使う
110
-
111
56
  set :rbenv_type, :system
112
-
113
57
  set :rbenv_ruby, File.read('.ruby-version').strip
114
-
115
58
  set :rbenv_prefix, "RBENV_ROOT=#{fetch(:rbenv_path)} #{fetch(:rbenv_path)}/bin/rbenv exec"
116
59
 
117
-
118
-
119
60
  # アプリケーションで使用するgemをリリース間で共有
120
-
121
61
  append :linked_dirs, '.bundle'
122
62
 
123
-
124
-
125
63
  # サーバの並列数
126
-
127
64
  set :bundle_jobs, 2
128
65
 
129
-
130
-
131
66
  # リリース間での共有リソース定義
132
-
133
67
  append :linked_files, "config/master.key"
134
-
135
68
  append :linked_dirs, "log", "tmp/pids", "tmp/cache", "tmp/sockets"
136
-
137
69
  ```
138
70
 
139
-
140
-
141
71
  ### config/deploy/production.rb
142
-
143
72
  ```Ruby
144
-
145
73
  # EC2サーバーのIP、EC2サーバーにログインするユーザー名、サーバーのロールを記述
146
-
147
74
  server '(IPアドレス)', user: 'ec2-user', roles: %w{app db web}
148
75
 
149
-
150
-
151
76
  set :ssh_options, {
152
-
153
77
  # capistranoコマンド実行者の秘密鍵
154
-
155
78
  keys: %w(~/.ssh/id_rsa),
156
-
157
79
  forward_agent: true,
158
-
159
80
  auth_methods: %w(publickey)
160
-
161
81
  }
162
-
163
82
  ```
164
83
 
165
-
166
-
167
84
  ### Gemfile(関連部分のみ抜粋)
168
-
169
85
  ```Ruby
170
-
171
86
  ruby '2.6.5'
172
-
173
87
  gem 'rails', '~> 5.2.4'
174
-
175
88
  gem 'mysql2', '>= 0.4.4', '< 0.6.0'
176
-
177
89
  gem 'puma', '~> 3.11'
178
90
 
179
-
180
-
181
91
  group :development do
182
-
183
92
  gem 'capistrano-rails'
184
-
185
93
  gem 'capistrano-bundler'
186
-
187
94
  gem 'capistrano-rbenv'
188
-
189
95
  gem 'capistrano-rbenv-vars'
190
-
191
96
  gem 'capistrano3-puma'
192
-
193
97
  end
194
-
195
98
  ```
196
99
 
197
-
198
-
199
100
  ### docker-compose.yml
200
-
201
101
  ```yml
202
-
203
102
  version: '3'
204
-
205
103
  services:
206
-
207
104
  db:
208
-
209
105
  image: mysql:5.7
210
-
211
106
  command: mysqld --character-set-server=utf8 --collation-server=utf8_unicode_ci
212
-
213
107
  environment:
214
-
215
108
  (省略)
216
-
217
109
  volumes:
218
-
219
110
  - db-volume:/var/lib/mysql
220
-
221
111
  ports:
222
-
223
112
  - "3306:3306"
224
-
225
113
  app:
226
-
227
114
  build:
228
-
229
115
  context: .
230
-
231
116
  dockerfile: ./docker/rails/Dockerfile
232
-
233
117
  command: bundle exec pumactl start
234
-
235
118
  tty: true
236
-
237
119
  stdin_open: true
238
-
239
120
  volumes:
240
-
241
121
  - .:/myapp
242
-
243
122
  - public-data:/myapp/public
244
-
245
123
  - tmp-data:/myapp/tmp
246
-
247
124
  - log-data:/myapp/log
248
-
249
125
  - sockets:/myapp/tmp/sockets
250
-
251
126
  privileged: true
252
-
253
127
  depends_on:
254
-
255
128
  - db
256
-
257
129
  web:
258
-
259
130
  build:
260
-
261
131
  context: .
262
-
263
132
  dockerfile: ./docker/nginx/Dockerfile
264
-
265
133
  ports:
266
-
267
134
  - '80:80'
268
-
269
135
  volumes:
270
-
271
136
  - public-data:/myapp/public
272
-
273
137
  - tmp-data:/myapp/tmp
274
-
275
138
  - sockets:/myapp/tmp/sockets
276
-
277
139
  depends_on:
278
-
279
140
  - app
280
-
281
141
  volumes:
282
-
283
142
  db-volume:
284
-
285
143
  public-data:
286
-
287
144
  tmp-data:
288
-
289
145
  log-data:
290
-
291
146
  sockets:
292
-
293
147
  ```
294
148
 
295
-
296
-
297
149
  ### 参考にした情報・試したこと
298
-
299
150
  Capistranoの設定は下記記事を参照しました。
300
-
301
151
  [Capistrano 3によるRails 5.2 + puma + nginxのデプロイをステップバイステップで学ぶ](https://qiita.com/tkykmw/items/a34441aae142e0e41b65)
302
152
 
303
-
304
-
305
153
  また、エラー内容から推測し、鍵の設定の問題かと思い、下記の記事を参照して、
306
-
307
154
  deploy/production.rbの:ssh_optionsの箇所を修正し、再びデプロイ実行しましたがエラー内容は変わらずでした。
308
-
309
155
  [capistranoでデプロイする時のssh-key周りのTips](https://qiita.com/Takkiii/items/c4f2cfd143e97e061e66)
310
-
311
156
  →この記事における、**「これだけだとgithubからソースコードを取ってこれないのでgithubの方にも自分の公開鍵を置く必要がある。さらに自分のssh-keyをssh-agentで使用する場合は以下のコマンドをローカル環境で実行する必要がある。」**という文章は、具体的に何の操作をすればいいのか、全くわからず何も出来ていない状態です。。
312
157
 
313
-
314
-
315
158
  「どこの何の鍵を、どこに置けばいいのか?」
316
-
317
159
  「何かの鍵を新しく生成する必要があるのか?」
318
-
319
160
  等、混乱しており、少しずつ調べているところです。
320
161
 
321
-
322
-
323
162
  SSHクライアント(Rlogin)を通じて、EC2にはSSH接続できており(EIPで固定IP化もしています)
324
-
325
163
  var/www/app/myappというデプロイ用ディレクトリも作成しています。
326
164
 
327
-
328
-
329
165
  ### 環境
330
-
331
166
  Ruby 2.6.5
332
-
333
167
  Rails 5.2.4
334
-
335
168
  puma 3.11
336
-
337
169
  EC2のAMIはAmazon Linux 2 (t2.micro)
338
-
339
170
  ホストOS:Windows10 Home
340
-
341
171
  Virtual Box上にDocker-composeを使ってコンテナを構築しており、そちらは問題なく動いており、アプリにもブラウザでアクセスできます。(Puma(Rails)+Nginx+Mysqlのコンテナがそれぞれ存在)
342
172
 
343
-
344
-
345
173
  不明点、不足情報等ございましたら、お手数をお掛けし恐縮ですがご教示いただけますと幸いです。
346
-
347
174
  継続して鍵のことについて勉強・調査中ですが、皆さんのお力添え頂きたく、宜しくお願い致します。

5

エラー解決調査において得た情報について補足しました

2020/07/19 06:15

投稿

otdsh9432
otdsh9432

スコア55

test CHANGED
File without changes
test CHANGED
@@ -30,7 +30,7 @@
30
30
 
31
31
  鍵の部分の知識も不足しており、具体的な原因、解決方法をご教示いただきたいと考えています。
32
32
 
33
- **「dockerからホストドライブをマウントして渡すべき」** という記事も見かけたのですが、
33
+ **「鍵は、dockerからホストドライブをマウントして渡すべき」** という記事も見かけたのですが、
34
34
 
35
35
  この文章の意味がわかっておらず、何も実施できていません。
36
36
 

4

実現したいことを具体的に記載しました。

2020/07/19 06:15

投稿

otdsh9432
otdsh9432

スコア55

test CHANGED
File without changes
test CHANGED
@@ -30,6 +30,10 @@
30
30
 
31
31
  鍵の部分の知識も不足しており、具体的な原因、解決方法をご教示いただきたいと考えています。
32
32
 
33
+ **「dockerからホストドライブをマウントして渡すべき」** という記事も見かけたのですが、
34
+
35
+ この文章の意味がわかっておらず、何も実施できていません。
36
+
33
37
 
34
38
 
35
39
  ### 現状のCapistrano設定ファイル

3

題名を変更しました

2020/07/19 06:12

投稿

otdsh9432
otdsh9432

スコア55

test CHANGED
@@ -1 +1 @@
1
- RailsCapistranoを用いてEC2へのデプロイを実施時、SSHの認証エラーが出てデプロイできない
1
+ RailsコンテナからCapistranoを用いてEC2へのデプロイを実施時、SSHの認証エラーが出てデプロイできない
test CHANGED
File without changes

2

実現したいことを具体的に記載しました。

2020/07/18 13:33

投稿

otdsh9432
otdsh9432

スコア55

test CHANGED
File without changes
test CHANGED
@@ -16,7 +16,9 @@
16
16
 
17
17
  ```
18
18
 
19
+
20
+
19
- 全文
21
+ エラー全文
20
22
 
21
23
  ![エラー内容](a95457eb65bc3b03cbfcbc0195129fa0.png)
22
24
 

1

実現したいことを具体的に記載しました。

2020/07/18 11:21

投稿

otdsh9432
otdsh9432

スコア55

test CHANGED
File without changes
test CHANGED
@@ -18,7 +18,7 @@
18
18
 
19
19
  全文
20
20
 
21
- ![エラー](362408459ba38685757348ffbfe4bff5.png)
21
+ ![エラー内容](a95457eb65bc3b03cbfcbc0195129fa0.png)
22
22
 
23
23
 
24
24