Closed13
GCRにプッシュしたイメージをCloud Runにデプロイしたい!!!
data:image/s3,"s3://crabby-images/408cf/408cf6729fa8976cafec21af4a4e31378aa5dc53" alt="キュリオ"
GCRにプッシュまではOKだがCloud Runでデプロイエラー
start
. Routing traffic...
✓ Setting IAM Policy...
Deployment failed
ERROR: (gcloud.run.deploy) Cloud Run error: The user-provided container failed to start and listen on the port defined provided by the PORT=8080 environment variable. Logs for this revision might contain more information.
やりたいことゴール
data:image/s3,"s3://crabby-images/408cf/408cf6729fa8976cafec21af4a4e31378aa5dc53" alt="キュリオ"
コード(下記引用してる)
FROM node:14-alpine3.14
ENV PORT 8080
ENV HOST 0.0.0.0
COPY . .
RUN yarn install
EXPOSE 8080
CMD ["node","hello.js"]
const express = require('express');
const app = express();
const port = process.env.PORT || 3002;
app.get('/test' , (req,res)=>{
res.send('hello express');
});
app.listen(port, (err)=>{
if (err) {
console.error('error happened');
throw err;
}
console.log(`http://0.0.0.0:${port}/test`);
});
data:image/s3,"s3://crabby-images/408cf/408cf6729fa8976cafec21af4a4e31378aa5dc53" alt="キュリオ"
なんでかわからんで、下記を発見
わいもM1なのでこれかも??
Rosseta2有効にしてもう一度ローカルビルド
data:image/s3,"s3://crabby-images/408cf/408cf6729fa8976cafec21af4a4e31378aa5dc53" alt="キュリオ"
結果変わらず!!!なんで!!!!!
data:image/s3,"s3://crabby-images/408cf/408cf6729fa8976cafec21af4a4e31378aa5dc53" alt="キュリオ"
Cloud Buildつかえばうまくいくのかな?
ログ見る限りはDockerfileが悪そうに思うが何が原因かさっぱりわからん
terminated: Application failed to start: Failed to create init process: failed to load /usr/local/bin/docker-entrypoint.sh: exec format error
data:image/s3,"s3://crabby-images/408cf/408cf6729fa8976cafec21af4a4e31378aa5dc53" alt="キュリオ"
ローカルではビルドと実行どっちもできる
data:image/s3,"s3://crabby-images/408cf/408cf6729fa8976cafec21af4a4e31378aa5dc53" alt="キュリオ"
うーんやっぱりローカルでビルドしてるのがよくないみたい
これ参考にやってみよう!
data:image/s3,"s3://crabby-images/408cf/408cf6729fa8976cafec21af4a4e31378aa5dc53" alt="キュリオ"
こっちのが良さげ?
data:image/s3,"s3://crabby-images/408cf/408cf6729fa8976cafec21af4a4e31378aa5dc53" alt="キュリオ"
まあとりあえずGCRにプッシュすること目標に
data:image/s3,"s3://crabby-images/408cf/408cf6729fa8976cafec21af4a4e31378aa5dc53" alt="キュリオ"
これ通りにビルドファイルを作って実行
docker run gcr.io/pj_name/image_name
これでソースコードが実行されていることが確認できた
data:image/s3,"s3://crabby-images/408cf/408cf6729fa8976cafec21af4a4e31378aa5dc53" alt="キュリオ"
次はCloud Runだ
data:image/s3,"s3://crabby-images/408cf/408cf6729fa8976cafec21af4a4e31378aa5dc53" alt="キュリオ"
ちょっとコマンドでエラー見るの心折れそうだったのでUIで
でぎだ
CLIでもいけると思う
data:image/s3,"s3://crabby-images/408cf/408cf6729fa8976cafec21af4a4e31378aa5dc53" alt="キュリオ"
ちょっと一手間かかるけどローカルビルドはしないほうが良いね
Cloud BuildだとRosseta入れなくてもいい感じに互換してくれる
このスクラップは2022/04/16にクローズされました